mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-29 22:06:39 +07:00
8e32ca49ef
Adding defines for RAID10 and RAID50 levels, in preparation of adding RAID Transport support in the mpt fusion drivers. (BTW: IME is RAID10, and IM is RAID1). Signed-off-by: Eric Moore <Eric.Moore@lsil.com> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
82 lines
2.1 KiB
C
82 lines
2.1 KiB
C
/*
|
|
* raid_class.h - a generic raid visualisation class
|
|
*
|
|
* Copyright (c) 2005 - James Bottomley <James.Bottomley@steeleye.com>
|
|
*
|
|
* This file is licensed under GPLv2
|
|
*/
|
|
#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 {
|
|
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,
|
|
RAID_LEVEL_10,
|
|
RAID_LEVEL_3,
|
|
RAID_LEVEL_4,
|
|
RAID_LEVEL_5,
|
|
RAID_LEVEL_50,
|
|
RAID_LEVEL_6,
|
|
};
|
|
|
|
struct raid_data {
|
|
struct list_head component_list;
|
|
int component_count;
|
|
enum raid_level level;
|
|
enum raid_state state;
|
|
int resync;
|
|
};
|
|
|
|
/* resync complete goes from 0 to this */
|
|
#define RAID_MAX_RESYNC (10000)
|
|
|
|
#define DEFINE_RAID_ATTRIBUTE(type, attr) \
|
|
static inline void \
|
|
raid_set_##attr(struct raid_template *r, struct device *dev, type value) { \
|
|
struct class_device *cdev = \
|
|
attribute_container_find_class_device(&r->raid_attrs.ac, dev);\
|
|
struct raid_data *rd; \
|
|
BUG_ON(!cdev); \
|
|
rd = class_get_devdata(cdev); \
|
|
rd->attr = value; \
|
|
} \
|
|
static inline type \
|
|
raid_get_##attr(struct raid_template *r, struct device *dev) { \
|
|
struct class_device *cdev = \
|
|
attribute_container_find_class_device(&r->raid_attrs.ac, dev);\
|
|
struct raid_data *rd; \
|
|
BUG_ON(!cdev); \
|
|
rd = class_get_devdata(cdev); \
|
|
return rd->attr; \
|
|
}
|
|
|
|
DEFINE_RAID_ATTRIBUTE(enum raid_level, level)
|
|
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 *);
|
|
|
|
void raid_component_add(struct raid_template *, struct device *,
|
|
struct device *);
|