xref: /utopia/UTPA2-700.0.x/projects/tools/lint/mips-linux-gnu_include/linux/raid/md_u.h (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1*53ee8cc1Swenshuai.xi /*
2*53ee8cc1Swenshuai.xi    md_u.h : user <=> kernel API between Linux raidtools and RAID drivers
3*53ee8cc1Swenshuai.xi           Copyright (C) 1998 Ingo Molnar
4*53ee8cc1Swenshuai.xi 
5*53ee8cc1Swenshuai.xi    This program is free software; you can redistribute it and/or modify
6*53ee8cc1Swenshuai.xi    it under the terms of the GNU General Public License as published by
7*53ee8cc1Swenshuai.xi    the Free Software Foundation; either version 2, or (at your option)
8*53ee8cc1Swenshuai.xi    any later version.
9*53ee8cc1Swenshuai.xi 
10*53ee8cc1Swenshuai.xi    You should have received a copy of the GNU General Public License
11*53ee8cc1Swenshuai.xi    (for example /usr/src/linux/COPYING); if not, write to the Free
12*53ee8cc1Swenshuai.xi    Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
13*53ee8cc1Swenshuai.xi */
14*53ee8cc1Swenshuai.xi 
15*53ee8cc1Swenshuai.xi #ifndef _MD_U_H
16*53ee8cc1Swenshuai.xi #define _MD_U_H
17*53ee8cc1Swenshuai.xi 
18*53ee8cc1Swenshuai.xi /* ioctls */
19*53ee8cc1Swenshuai.xi 
20*53ee8cc1Swenshuai.xi /* status */
21*53ee8cc1Swenshuai.xi #define RAID_VERSION		_IOR (MD_MAJOR, 0x10, mdu_version_t)
22*53ee8cc1Swenshuai.xi #define GET_ARRAY_INFO		_IOR (MD_MAJOR, 0x11, mdu_array_info_t)
23*53ee8cc1Swenshuai.xi #define GET_DISK_INFO		_IOR (MD_MAJOR, 0x12, mdu_disk_info_t)
24*53ee8cc1Swenshuai.xi #define PRINT_RAID_DEBUG	_IO (MD_MAJOR, 0x13)
25*53ee8cc1Swenshuai.xi #define RAID_AUTORUN		_IO (MD_MAJOR, 0x14)
26*53ee8cc1Swenshuai.xi #define GET_BITMAP_FILE		_IOR (MD_MAJOR, 0x15, mdu_bitmap_file_t)
27*53ee8cc1Swenshuai.xi 
28*53ee8cc1Swenshuai.xi /* configuration */
29*53ee8cc1Swenshuai.xi #define CLEAR_ARRAY		_IO (MD_MAJOR, 0x20)
30*53ee8cc1Swenshuai.xi #define ADD_NEW_DISK		_IOW (MD_MAJOR, 0x21, mdu_disk_info_t)
31*53ee8cc1Swenshuai.xi #define HOT_REMOVE_DISK		_IO (MD_MAJOR, 0x22)
32*53ee8cc1Swenshuai.xi #define SET_ARRAY_INFO		_IOW (MD_MAJOR, 0x23, mdu_array_info_t)
33*53ee8cc1Swenshuai.xi #define SET_DISK_INFO		_IO (MD_MAJOR, 0x24)
34*53ee8cc1Swenshuai.xi #define WRITE_RAID_INFO		_IO (MD_MAJOR, 0x25)
35*53ee8cc1Swenshuai.xi #define UNPROTECT_ARRAY		_IO (MD_MAJOR, 0x26)
36*53ee8cc1Swenshuai.xi #define PROTECT_ARRAY		_IO (MD_MAJOR, 0x27)
37*53ee8cc1Swenshuai.xi #define HOT_ADD_DISK		_IO (MD_MAJOR, 0x28)
38*53ee8cc1Swenshuai.xi #define SET_DISK_FAULTY		_IO (MD_MAJOR, 0x29)
39*53ee8cc1Swenshuai.xi #define HOT_GENERATE_ERROR	_IO (MD_MAJOR, 0x2a)
40*53ee8cc1Swenshuai.xi #define SET_BITMAP_FILE		_IOW (MD_MAJOR, 0x2b, int)
41*53ee8cc1Swenshuai.xi 
42*53ee8cc1Swenshuai.xi /* usage */
43*53ee8cc1Swenshuai.xi #define RUN_ARRAY		_IOW (MD_MAJOR, 0x30, mdu_param_t)
44*53ee8cc1Swenshuai.xi /*  0x31 was START_ARRAY  */
45*53ee8cc1Swenshuai.xi #define STOP_ARRAY		_IO (MD_MAJOR, 0x32)
46*53ee8cc1Swenshuai.xi #define STOP_ARRAY_RO		_IO (MD_MAJOR, 0x33)
47*53ee8cc1Swenshuai.xi #define RESTART_ARRAY_RW	_IO (MD_MAJOR, 0x34)
48*53ee8cc1Swenshuai.xi 
49*53ee8cc1Swenshuai.xi typedef struct mdu_version_s {
50*53ee8cc1Swenshuai.xi 	int major;
51*53ee8cc1Swenshuai.xi 	int minor;
52*53ee8cc1Swenshuai.xi 	int patchlevel;
53*53ee8cc1Swenshuai.xi } mdu_version_t;
54*53ee8cc1Swenshuai.xi 
55*53ee8cc1Swenshuai.xi typedef struct mdu_array_info_s {
56*53ee8cc1Swenshuai.xi 	/*
57*53ee8cc1Swenshuai.xi 	 * Generic constant information
58*53ee8cc1Swenshuai.xi 	 */
59*53ee8cc1Swenshuai.xi 	int major_version;
60*53ee8cc1Swenshuai.xi 	int minor_version;
61*53ee8cc1Swenshuai.xi 	int patch_version;
62*53ee8cc1Swenshuai.xi 	int ctime;
63*53ee8cc1Swenshuai.xi 	int level;
64*53ee8cc1Swenshuai.xi 	int size;
65*53ee8cc1Swenshuai.xi 	int nr_disks;
66*53ee8cc1Swenshuai.xi 	int raid_disks;
67*53ee8cc1Swenshuai.xi 	int md_minor;
68*53ee8cc1Swenshuai.xi 	int not_persistent;
69*53ee8cc1Swenshuai.xi 
70*53ee8cc1Swenshuai.xi 	/*
71*53ee8cc1Swenshuai.xi 	 * Generic state information
72*53ee8cc1Swenshuai.xi 	 */
73*53ee8cc1Swenshuai.xi 	int utime;		/*  0 Superblock update time		      */
74*53ee8cc1Swenshuai.xi 	int state;		/*  1 State bits (clean, ...)		      */
75*53ee8cc1Swenshuai.xi 	int active_disks;	/*  2 Number of currently active disks	      */
76*53ee8cc1Swenshuai.xi 	int working_disks;	/*  3 Number of working disks		      */
77*53ee8cc1Swenshuai.xi 	int failed_disks;	/*  4 Number of failed disks		      */
78*53ee8cc1Swenshuai.xi 	int spare_disks;	/*  5 Number of spare disks		      */
79*53ee8cc1Swenshuai.xi 
80*53ee8cc1Swenshuai.xi 	/*
81*53ee8cc1Swenshuai.xi 	 * Personality information
82*53ee8cc1Swenshuai.xi 	 */
83*53ee8cc1Swenshuai.xi 	int layout;		/*  0 the array's physical layout	      */
84*53ee8cc1Swenshuai.xi 	int chunk_size;	/*  1 chunk size in bytes		      */
85*53ee8cc1Swenshuai.xi 
86*53ee8cc1Swenshuai.xi } mdu_array_info_t;
87*53ee8cc1Swenshuai.xi 
88*53ee8cc1Swenshuai.xi typedef struct mdu_disk_info_s {
89*53ee8cc1Swenshuai.xi 	/*
90*53ee8cc1Swenshuai.xi 	 * configuration/status of one particular disk
91*53ee8cc1Swenshuai.xi 	 */
92*53ee8cc1Swenshuai.xi 	int number;
93*53ee8cc1Swenshuai.xi 	int major;
94*53ee8cc1Swenshuai.xi 	int minor;
95*53ee8cc1Swenshuai.xi 	int raid_disk;
96*53ee8cc1Swenshuai.xi 	int state;
97*53ee8cc1Swenshuai.xi 
98*53ee8cc1Swenshuai.xi } mdu_disk_info_t;
99*53ee8cc1Swenshuai.xi 
100*53ee8cc1Swenshuai.xi typedef struct mdu_start_info_s {
101*53ee8cc1Swenshuai.xi 	/*
102*53ee8cc1Swenshuai.xi 	 * configuration/status of one particular disk
103*53ee8cc1Swenshuai.xi 	 */
104*53ee8cc1Swenshuai.xi 	int major;
105*53ee8cc1Swenshuai.xi 	int minor;
106*53ee8cc1Swenshuai.xi 	int raid_disk;
107*53ee8cc1Swenshuai.xi 	int state;
108*53ee8cc1Swenshuai.xi 
109*53ee8cc1Swenshuai.xi } mdu_start_info_t;
110*53ee8cc1Swenshuai.xi 
111*53ee8cc1Swenshuai.xi typedef struct mdu_bitmap_file_s
112*53ee8cc1Swenshuai.xi {
113*53ee8cc1Swenshuai.xi 	char pathname[4096];
114*53ee8cc1Swenshuai.xi } mdu_bitmap_file_t;
115*53ee8cc1Swenshuai.xi 
116*53ee8cc1Swenshuai.xi typedef struct mdu_param_s
117*53ee8cc1Swenshuai.xi {
118*53ee8cc1Swenshuai.xi 	int			personality;	/* 1,2,3,4 */
119*53ee8cc1Swenshuai.xi 	int			chunk_size;	/* in bytes */
120*53ee8cc1Swenshuai.xi 	int			max_fault;	/* unused for now */
121*53ee8cc1Swenshuai.xi } mdu_param_t;
122*53ee8cc1Swenshuai.xi 
123*53ee8cc1Swenshuai.xi #endif
124*53ee8cc1Swenshuai.xi 
125