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