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 **************************************************************************** 11 ****************************************************************************/ 12 #ifndef _MD_K_H 13 #define _MD_K_H 14 15 #include "../../../drivers/md/dm-bio-list.h" 16 17 #define LEVEL_MULTIPATH (-4) 18 #define LEVEL_LINEAR (-1) 19 #define LEVEL_FAULTY (-5) 20 21 #define LEVEL_NONE (-1000000) 22 23 #define MaxSector (~(sector_t)0) 24 #define MD_THREAD_NAME_MAX 14 25 26 typedef struct mddev_s mddev_t; 27 typedef struct mdk_rdev_s mdk_rdev_t; 28 29 #define MAX_MD_DEVS 256 30 31 #define MAX_CHUNK_SIZE (1<<30) 32 33 struct mdk_rdev_s 34 { 35 struct list_head same_set; 36 37 sector_t size; 38 mddev_t *mddev; 39 unsigned long last_events; 40 41 struct block_device *bdev; 42 43 struct page *sb_page; 44 int sb_loaded; 45 __u64 sb_events; 46 sector_t data_offset; 47 sector_t sb_offset; 48 int sb_size; 49 int preferred_minor; 50 51 struct kobject kobj; 52 53 unsigned long flags; 54 #define Faulty 1 55 #define In_sync 2 56 #define WriteMostly 4 57 #define BarriersNotsupp 5 58 59 int desc_nr; 60 int raid_disk; 61 int saved_raid_disk; 62 sector_t recovery_offset; 63 64 atomic_t nr_pending; 65 atomic_t read_errors; 66 atomic_t corrected_errors; 67 }; 68 69 struct mddev_s 70 { 71 void *private; 72 struct mdk_personality *pers; 73 dev_t unit; 74 int md_minor; 75 struct list_head disks; 76 int sb_dirty; 77 int ro; 78 79 struct gendisk *gendisk; 80 81 struct kobject kobj; 82 83 int major_version, 84 minor_version, 85 patch_version; 86 int persistent; 87 int chunk_size; 88 time_t ctime, utime; 89 int level, layout; 90 char clevel[16]; 91 int raid_disks; 92 int max_disks; 93 sector_t size; 94 sector_t array_size; 95 __u64 events; 96 97 char uuid[16]; 98 99 sector_t reshape_position; 100 int delta_disks, new_level, new_layout, new_chunk; 101 102 struct mdk_thread_s *thread; 103 struct mdk_thread_s *sync_thread; 104 sector_t curr_resync; 105 unsigned long resync_mark; 106 sector_t resync_mark_cnt; 107 sector_t curr_mark_cnt; 108 109 sector_t resync_max_sectors; 110 111 sector_t resync_mismatches; 112 113 sector_t suspend_lo; 114 sector_t suspend_hi; 115 116 int sync_speed_min; 117 int sync_speed_max; 118 119 int ok_start_degraded; 120 121 #define MD_RECOVERY_RUNNING 0 122 #define MD_RECOVERY_SYNC 1 123 #define MD_RECOVERY_ERR 2 124 #define MD_RECOVERY_INTR 3 125 #define MD_RECOVERY_DONE 4 126 #define MD_RECOVERY_NEEDED 5 127 #define MD_RECOVERY_REQUESTED 6 128 #define MD_RECOVERY_CHECK 7 129 #define MD_RECOVERY_RESHAPE 8 130 #define MD_RECOVERY_FROZEN 9 131 132 unsigned long recovery; 133 134 int in_sync; 135 struct mutex reconfig_mutex; 136 atomic_t active; 137 138 int changed; 139 int degraded; 140 int barriers_work; 141 struct bio *biolist; 142 143 atomic_t recovery_active; 144 wait_queue_head_t recovery_wait; 145 sector_t recovery_cp; 146 147 spinlock_t write_lock; 148 wait_queue_head_t sb_wait; 149 atomic_t pending_writes; 150 151 unsigned int safemode; 152 unsigned int safemode_delay; 153 struct timer_list safemode_timer; 154 atomic_t writes_pending; 155 request_queue_t *queue; 156 157 atomic_t write_behind; 158 unsigned int max_write_behind; 159 160 struct bitmap *bitmap; 161 struct file *bitmap_file; 162 long bitmap_offset; 163 long default_bitmap_offset; 164 165 struct list_head all_mddevs; 166 }; 167 168 struct md_sysfs_entry { 169 struct attribute attr; 170 ssize_t (*show)(mddev_t *, char *); 171 ssize_t (*store)(mddev_t *, const char *, size_t); 172 }; 173 174 #define ITERATE_RDEV_GENERIC(head,rdev,tmp) for ((tmp) = (head).next; (rdev) = (list_entry((tmp), mdk_rdev_t, same_set)), (tmp) = (tmp)->next, (tmp)->prev != &(head) ; ) 175 #define ITERATE_RDEV(mddev,rdev,tmp) ITERATE_RDEV_GENERIC((mddev)->disks,rdev,tmp) 176 #define ITERATE_RDEV_PENDING(rdev,tmp) ITERATE_RDEV_GENERIC(pending_raid_disks,rdev,tmp) 177 178 #define THREAD_WAKEUP 0 179 180 #define __wait_event_lock_irq(wq, condition, lock, cmd) do { wait_queue_t __wait; init_waitqueue_entry(&__wait, current); add_wait_queue(&wq, &__wait); for (;;) { set_current_state(TASK_UNINTERRUPTIBLE); if (condition) break; spin_unlock_irq(&lock); cmd; schedule(); spin_lock_irq(&lock); } current->state = TASK_RUNNING; remove_wait_queue(&wq, &__wait); } while (0) 181 182 #define wait_event_lock_irq(wq, condition, lock, cmd) do { if (condition) break; __wait_event_lock_irq(wq, condition, lock, cmd); } while (0) 183 184 #endif 185