Home | History | Annotate | Download | only in raid
      1 /****************************************************************************
      2  ****************************************************************************
      3  ***
      4  ***   This header was automatically generated from a Linux kernel header
      5  ***   of the same name, to make information necessary for userspace to
      6  ***   call into the kernel available to libc.  It contains only constants,
      7  ***   structures, and macros generated from the original header, and thus,
      8  ***   contains no copyrightable information.
      9  ***
     10  ***   To edit the content of this header, modify the corresponding
     11  ***   source file (e.g. under external/kernel-headers/original/) then
     12  ***   run bionic/libc/kernel/tools/update_all.py
     13  ***
     14  ***   Any manual change here will be lost the next time this script will
     15  ***   be run. You've been warned!
     16  ***
     17  ****************************************************************************
     18  ****************************************************************************/
     19 #ifndef _MD_P_H
     20 #define _MD_P_H
     21 #include <linux/types.h>
     22 #include <asm/byteorder.h>
     23 #define MD_RESERVED_BYTES (64 * 1024)
     24 #define MD_RESERVED_SECTORS (MD_RESERVED_BYTES / 512)
     25 #define MD_NEW_SIZE_SECTORS(x) ((x & ~(MD_RESERVED_SECTORS - 1)) - MD_RESERVED_SECTORS)
     26 #define MD_SB_BYTES 4096
     27 #define MD_SB_WORDS (MD_SB_BYTES / 4)
     28 #define MD_SB_SECTORS (MD_SB_BYTES / 512)
     29 #define MD_SB_GENERIC_OFFSET 0
     30 #define MD_SB_PERSONALITY_OFFSET 64
     31 #define MD_SB_DISKS_OFFSET 128
     32 #define MD_SB_DESCRIPTOR_OFFSET 992
     33 #define MD_SB_GENERIC_CONSTANT_WORDS 32
     34 #define MD_SB_GENERIC_STATE_WORDS 32
     35 #define MD_SB_GENERIC_WORDS (MD_SB_GENERIC_CONSTANT_WORDS + MD_SB_GENERIC_STATE_WORDS)
     36 #define MD_SB_PERSONALITY_WORDS 64
     37 #define MD_SB_DESCRIPTOR_WORDS 32
     38 #define MD_SB_DISKS 27
     39 #define MD_SB_DISKS_WORDS (MD_SB_DISKS * MD_SB_DESCRIPTOR_WORDS)
     40 #define MD_SB_RESERVED_WORDS (1024 - MD_SB_GENERIC_WORDS - MD_SB_PERSONALITY_WORDS - MD_SB_DISKS_WORDS - MD_SB_DESCRIPTOR_WORDS)
     41 #define MD_SB_EQUAL_WORDS (MD_SB_GENERIC_WORDS + MD_SB_PERSONALITY_WORDS + MD_SB_DISKS_WORDS)
     42 #define MD_DISK_FAULTY 0
     43 #define MD_DISK_ACTIVE 1
     44 #define MD_DISK_SYNC 2
     45 #define MD_DISK_REMOVED 3
     46 #define MD_DISK_CLUSTER_ADD 4
     47 #define MD_DISK_CANDIDATE 5
     48 #define MD_DISK_FAILFAST 10
     49 #define MD_DISK_WRITEMOSTLY 9
     50 #define MD_DISK_JOURNAL 18
     51 #define MD_DISK_ROLE_SPARE 0xffff
     52 #define MD_DISK_ROLE_FAULTY 0xfffe
     53 #define MD_DISK_ROLE_JOURNAL 0xfffd
     54 #define MD_DISK_ROLE_MAX 0xff00
     55 typedef struct mdp_device_descriptor_s {
     56   __u32 number;
     57   __u32 major;
     58   __u32 minor;
     59   __u32 raid_disk;
     60   __u32 state;
     61   __u32 reserved[MD_SB_DESCRIPTOR_WORDS - 5];
     62 } mdp_disk_t;
     63 #define MD_SB_MAGIC 0xa92b4efc
     64 #define MD_SB_CLEAN 0
     65 #define MD_SB_ERRORS 1
     66 #define MD_SB_CLUSTERED 5
     67 #define MD_SB_BITMAP_PRESENT 8
     68 typedef struct mdp_superblock_s {
     69   __u32 md_magic;
     70   __u32 major_version;
     71   __u32 minor_version;
     72   __u32 patch_version;
     73   __u32 gvalid_words;
     74   __u32 set_uuid0;
     75   __u32 ctime;
     76   __u32 level;
     77   __u32 size;
     78   __u32 nr_disks;
     79   __u32 raid_disks;
     80   __u32 md_minor;
     81   __u32 not_persistent;
     82   __u32 set_uuid1;
     83   __u32 set_uuid2;
     84   __u32 set_uuid3;
     85   __u32 gstate_creserved[MD_SB_GENERIC_CONSTANT_WORDS - 16];
     86   __u32 utime;
     87   __u32 state;
     88   __u32 active_disks;
     89   __u32 working_disks;
     90   __u32 failed_disks;
     91   __u32 spare_disks;
     92   __u32 sb_csum;
     93 #if defined(__BYTE_ORDER) ? __BYTE_ORDER == __BIG_ENDIAN : defined(__BIG_ENDIAN)
     94   __u32 events_hi;
     95   __u32 events_lo;
     96   __u32 cp_events_hi;
     97   __u32 cp_events_lo;
     98 #elif defined(__BYTE_ORDER)?__BYTE_ORDER==__LITTLE_ENDIAN:defined(__LITTLE_ENDIAN)
     99   __u32 events_lo;
    100   __u32 events_hi;
    101   __u32 cp_events_lo;
    102   __u32 cp_events_hi;
    103 #else
    104 #error unspecified endianness
    105 #endif
    106   __u32 recovery_cp;
    107   __u64 reshape_position;
    108   __u32 new_level;
    109   __u32 delta_disks;
    110   __u32 new_layout;
    111   __u32 new_chunk;
    112   __u32 gstate_sreserved[MD_SB_GENERIC_STATE_WORDS - 18];
    113   __u32 layout;
    114   __u32 chunk_size;
    115   __u32 root_pv;
    116   __u32 root_block;
    117   __u32 pstate_reserved[MD_SB_PERSONALITY_WORDS - 4];
    118   mdp_disk_t disks[MD_SB_DISKS];
    119   __u32 reserved[MD_SB_RESERVED_WORDS];
    120   mdp_disk_t this_disk;
    121 } mdp_super_t;
    122 #define MD_SUPERBLOCK_1_TIME_SEC_MASK ((1ULL << 40) - 1)
    123 struct mdp_superblock_1 {
    124   __le32 magic;
    125   __le32 major_version;
    126   __le32 feature_map;
    127   __le32 pad0;
    128   __u8 set_uuid[16];
    129   char set_name[32];
    130   __le64 ctime;
    131   __le32 level;
    132   __le32 layout;
    133   __le64 size;
    134   __le32 chunksize;
    135   __le32 raid_disks;
    136   union {
    137     __le32 bitmap_offset;
    138     struct {
    139       __le16 offset;
    140       __le16 size;
    141     } ppl;
    142   };
    143   __le32 new_level;
    144   __le64 reshape_position;
    145   __le32 delta_disks;
    146   __le32 new_layout;
    147   __le32 new_chunk;
    148   __le32 new_offset;
    149   __le64 data_offset;
    150   __le64 data_size;
    151   __le64 super_offset;
    152   union {
    153     __le64 recovery_offset;
    154     __le64 journal_tail;
    155   };
    156   __le32 dev_number;
    157   __le32 cnt_corrected_read;
    158   __u8 device_uuid[16];
    159   __u8 devflags;
    160 #define WriteMostly1 1
    161 #define FailFast1 2
    162   __u8 bblog_shift;
    163   __le16 bblog_size;
    164   __le32 bblog_offset;
    165   __le64 utime;
    166   __le64 events;
    167   __le64 resync_offset;
    168   __le32 sb_csum;
    169   __le32 max_dev;
    170   __u8 pad3[64 - 32];
    171   __le16 dev_roles[0];
    172 };
    173 #define MD_FEATURE_BITMAP_OFFSET 1
    174 #define MD_FEATURE_RECOVERY_OFFSET 2
    175 #define MD_FEATURE_RESHAPE_ACTIVE 4
    176 #define MD_FEATURE_BAD_BLOCKS 8
    177 #define MD_FEATURE_REPLACEMENT 16
    178 #define MD_FEATURE_RESHAPE_BACKWARDS 32
    179 #define MD_FEATURE_NEW_OFFSET 64
    180 #define MD_FEATURE_RECOVERY_BITMAP 128
    181 #define MD_FEATURE_CLUSTERED 256
    182 #define MD_FEATURE_JOURNAL 512
    183 #define MD_FEATURE_PPL 1024
    184 #define MD_FEATURE_MULTIPLE_PPLS 2048
    185 #define MD_FEATURE_ALL (MD_FEATURE_BITMAP_OFFSET | MD_FEATURE_RECOVERY_OFFSET | MD_FEATURE_RESHAPE_ACTIVE | MD_FEATURE_BAD_BLOCKS | MD_FEATURE_REPLACEMENT | MD_FEATURE_RESHAPE_BACKWARDS | MD_FEATURE_NEW_OFFSET | MD_FEATURE_RECOVERY_BITMAP | MD_FEATURE_CLUSTERED | MD_FEATURE_JOURNAL | MD_FEATURE_PPL | MD_FEATURE_MULTIPLE_PPLS)
    186 struct r5l_payload_header {
    187   __le16 type;
    188   __le16 flags;
    189 } __attribute__((__packed__));
    190 enum r5l_payload_type {
    191   R5LOG_PAYLOAD_DATA = 0,
    192   R5LOG_PAYLOAD_PARITY = 1,
    193   R5LOG_PAYLOAD_FLUSH = 2,
    194 };
    195 struct r5l_payload_data_parity {
    196   struct r5l_payload_header header;
    197   __le32 size;
    198   __le64 location;
    199   __le32 checksum[];
    200 } __attribute__((__packed__));
    201 enum r5l_payload_data_parity_flag {
    202   R5LOG_PAYLOAD_FLAG_DISCARD = 1,
    203   R5LOG_PAYLOAD_FLAG_RESHAPED = 2,
    204   R5LOG_PAYLOAD_FLAG_RESHAPING = 3,
    205 };
    206 struct r5l_payload_flush {
    207   struct r5l_payload_header header;
    208   __le32 size;
    209   __le64 flush_stripes[];
    210 } __attribute__((__packed__));
    211 enum r5l_payload_flush_flag {
    212   R5LOG_PAYLOAD_FLAG_FLUSH_STRIPE = 1,
    213 };
    214 struct r5l_meta_block {
    215   __le32 magic;
    216   __le32 checksum;
    217   __u8 version;
    218   __u8 __zero_pading_1;
    219   __le16 __zero_pading_2;
    220   __le32 meta_size;
    221   __le64 seq;
    222   __le64 position;
    223   struct r5l_payload_header payloads[];
    224 } __attribute__((__packed__));
    225 #define R5LOG_VERSION 0x1
    226 #define R5LOG_MAGIC 0x6433c509
    227 struct ppl_header_entry {
    228   __le64 data_sector;
    229   __le32 pp_size;
    230   __le32 data_size;
    231   __le32 parity_disk;
    232   __le32 checksum;
    233 } __attribute__((__packed__));
    234 #define PPL_HEADER_SIZE 4096
    235 #define PPL_HDR_RESERVED 512
    236 #define PPL_HDR_ENTRY_SPACE (PPL_HEADER_SIZE - PPL_HDR_RESERVED - 4 * sizeof(__le32) - sizeof(__le64))
    237 #define PPL_HDR_MAX_ENTRIES (PPL_HDR_ENTRY_SPACE / sizeof(struct ppl_header_entry))
    238 struct ppl_header {
    239   __u8 reserved[PPL_HDR_RESERVED];
    240   __le32 signature;
    241   __le32 padding;
    242   __le64 generation;
    243   __le32 entries_count;
    244   __le32 checksum;
    245   struct ppl_header_entry entries[PPL_HDR_MAX_ENTRIES];
    246 } __attribute__((__packed__));
    247 #endif
    248