mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-26 14:56:16 +00:00 
			
		
		
		
	 ed542bed12
			
		
	
	
		ed542bed12
		
	
	
	
	
		
			
			Signed-off-by: Jeff Garzik <jeff@garzik.org> Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			83 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 *);
 | |
| 
 | |
| int __must_check raid_component_add(struct raid_template *, struct device *,
 | |
| 				    struct device *);
 | |
| 
 |