Blame view
include/linux/raid_class.h
2.08 KB
61a7afa2c [SCSI] embryonic ... |
1 |
/* |
b1081ea6f [SCSI] raid class... |
2 3 4 5 6 |
* raid_class.h - a generic raid visualisation class * * Copyright (c) 2005 - James Bottomley <James.Bottomley@steeleye.com> * * This file is licensed under GPLv2 |
61a7afa2c [SCSI] embryonic ... |
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
*/ #include <linux/transport_class.h> struct raid_template { struct transport_container raid_attrs; }; struct raid_function_template { void *cookie; int (*is_raid)(struct device *); void (*get_resync)(struct device *); void (*get_state)(struct device *); }; enum raid_state { |
b1081ea6f [SCSI] raid class... |
22 23 24 25 26 27 28 29 30 31 32 33 |
RAID_STATE_UNKNOWN = 0, RAID_STATE_ACTIVE, RAID_STATE_DEGRADED, RAID_STATE_RESYNCING, RAID_STATE_OFFLINE, }; enum raid_level { RAID_LEVEL_UNKNOWN = 0, RAID_LEVEL_LINEAR, RAID_LEVEL_0, RAID_LEVEL_1, |
8e32ca49e [SCSI] raid_class... |
34 |
RAID_LEVEL_10, |
f7c95ef02 [SCSI] mpt2sas: A... |
35 |
RAID_LEVEL_1E, |
b1081ea6f [SCSI] raid class... |
36 37 38 |
RAID_LEVEL_3, RAID_LEVEL_4, RAID_LEVEL_5, |
8e32ca49e [SCSI] raid_class... |
39 |
RAID_LEVEL_50, |
b1081ea6f [SCSI] raid class... |
40 |
RAID_LEVEL_6, |
61a7afa2c [SCSI] embryonic ... |
41 42 43 44 45 |
}; struct raid_data { struct list_head component_list; int component_count; |
b1081ea6f [SCSI] raid class... |
46 |
enum raid_level level; |
61a7afa2c [SCSI] embryonic ... |
47 48 49 |
enum raid_state state; int resync; }; |
b1081ea6f [SCSI] raid class... |
50 51 |
/* resync complete goes from 0 to this */ #define RAID_MAX_RESYNC (10000) |
61a7afa2c [SCSI] embryonic ... |
52 53 54 |
#define DEFINE_RAID_ATTRIBUTE(type, attr) \ static inline void \ raid_set_##attr(struct raid_template *r, struct device *dev, type value) { \ |
ee959b00c SCSI: convert str... |
55 |
struct device *device = \ |
61a7afa2c [SCSI] embryonic ... |
56 57 |
attribute_container_find_class_device(&r->raid_attrs.ac, dev);\ struct raid_data *rd; \ |
ee959b00c SCSI: convert str... |
58 59 |
BUG_ON(!device); \ rd = dev_get_drvdata(device); \ |
61a7afa2c [SCSI] embryonic ... |
60 61 62 63 |
rd->attr = value; \ } \ static inline type \ raid_get_##attr(struct raid_template *r, struct device *dev) { \ |
ee959b00c SCSI: convert str... |
64 |
struct device *device = \ |
61a7afa2c [SCSI] embryonic ... |
65 66 |
attribute_container_find_class_device(&r->raid_attrs.ac, dev);\ struct raid_data *rd; \ |
ee959b00c SCSI: convert str... |
67 68 |
BUG_ON(!device); \ rd = dev_get_drvdata(device); \ |
61a7afa2c [SCSI] embryonic ... |
69 70 |
return rd->attr; \ } |
b1081ea6f [SCSI] raid class... |
71 |
DEFINE_RAID_ATTRIBUTE(enum raid_level, level) |
61a7afa2c [SCSI] embryonic ... |
72 73 74 75 76 |
DEFINE_RAID_ATTRIBUTE(int, resync) DEFINE_RAID_ATTRIBUTE(enum raid_state, state) struct raid_template *raid_class_attach(struct raid_function_template *); void raid_class_release(struct raid_template *); |
ed542bed1 [SCSI] raid class... |
77 78 |
int __must_check raid_component_add(struct raid_template *, struct device *, struct device *); |