Added create/activate/free all exported objects methods
Signed-off-by: Michal Rakowski <michal.rakowski@intel.com>
This commit is contained in:
parent
47a150644c
commit
ee6cba515a
@ -72,6 +72,7 @@ struct casdsk_functions_mapper {
|
|||||||
int (*casdsk_exp_obj_destroy)(struct casdsk_disk *dsk);
|
int (*casdsk_exp_obj_destroy)(struct casdsk_disk *dsk);
|
||||||
int (*casdsk_exp_obj_create)(struct casdsk_disk *dsk, const char *dev_name,
|
int (*casdsk_exp_obj_create)(struct casdsk_disk *dsk, const char *dev_name,
|
||||||
struct module *owner, struct casdsk_exp_obj_ops *ops);
|
struct module *owner, struct casdsk_exp_obj_ops *ops);
|
||||||
|
void(*casdsk_exp_obj_free)(struct casdsk_disk *dsk);
|
||||||
struct request_queue *(*casdsk_disk_get_queue)(struct casdsk_disk *dsk);
|
struct request_queue *(*casdsk_disk_get_queue)(struct casdsk_disk *dsk);
|
||||||
void (*casdsk_store_config)(size_t n_blobs, struct casdsk_props_conf *blobs);
|
void (*casdsk_store_config)(size_t n_blobs, struct casdsk_props_conf *blobs);
|
||||||
struct block_device *(*casdsk_disk_get_blkdev)(struct casdsk_disk *dsk);
|
struct block_device *(*casdsk_disk_get_blkdev)(struct casdsk_disk *dsk);
|
||||||
|
@ -79,6 +79,7 @@ int static cas_casdisk_lookup_funtions(void)
|
|||||||
cas_lookup_symbol(casdsk_disk_dettach);
|
cas_lookup_symbol(casdsk_disk_dettach);
|
||||||
cas_lookup_symbol(casdsk_exp_obj_destroy);
|
cas_lookup_symbol(casdsk_exp_obj_destroy);
|
||||||
cas_lookup_symbol(casdsk_exp_obj_create);
|
cas_lookup_symbol(casdsk_exp_obj_create);
|
||||||
|
cas_lookup_symbol(casdsk_exp_obj_free);
|
||||||
cas_lookup_symbol(casdsk_disk_get_queue);
|
cas_lookup_symbol(casdsk_disk_get_queue);
|
||||||
cas_lookup_symbol(casdsk_store_config);
|
cas_lookup_symbol(casdsk_store_config);
|
||||||
cas_lookup_symbol(casdsk_disk_get_blkdev);
|
cas_lookup_symbol(casdsk_disk_get_blkdev);
|
||||||
|
@ -884,6 +884,16 @@ int block_dev_activate_exported_object(ocf_core_t core)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int _block_dev_activate_exported_object(ocf_core_t core, void *cntx)
|
||||||
|
{
|
||||||
|
return block_dev_activate_exported_object(core);
|
||||||
|
}
|
||||||
|
|
||||||
|
int block_dev_activate_all_exported_objects(ocf_cache_t cache)
|
||||||
|
{
|
||||||
|
return ocf_core_visit(cache, _block_dev_activate_exported_object, NULL,
|
||||||
|
true);
|
||||||
|
}
|
||||||
int block_dev_create_exported_object(ocf_core_t core)
|
int block_dev_create_exported_object(ocf_core_t core)
|
||||||
{
|
{
|
||||||
ocf_volume_t obj = ocf_core_get_volume(core);
|
ocf_volume_t obj = ocf_core_get_volume(core);
|
||||||
@ -915,6 +925,15 @@ int block_dev_create_exported_object(ocf_core_t core)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int _block_dev_create_exported_object_visitor(ocf_core_t core, void *cntx){
|
||||||
|
return block_dev_create_exported_object(core);
|
||||||
|
}
|
||||||
|
|
||||||
|
int block_dev_create_all_exported_objects(ocf_cache_t cache)
|
||||||
|
{
|
||||||
|
return ocf_core_visit(cache, _block_dev_create_exported_object_visitor, NULL,
|
||||||
|
true);
|
||||||
|
}
|
||||||
int block_dev_destroy_exported_object(ocf_core_t core)
|
int block_dev_destroy_exported_object(ocf_core_t core)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -1016,3 +1035,17 @@ int block_dev_destroy_all_exported_objects(ocf_cache_t cache)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
static int _block_dev_free_exported_object(ocf_core_t core, void *cntx)
|
||||||
|
{
|
||||||
|
struct bd_object *bvol = bd_object(
|
||||||
|
ocf_core_get_volume(core));
|
||||||
|
|
||||||
|
casdisk_functions.casdsk_exp_obj_free(bvol->dsk);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int block_dev_free_all_exported_objects(ocf_cache_t cache)
|
||||||
|
{
|
||||||
|
return ocf_core_visit(cache, _block_dev_free_exported_object, NULL,
|
||||||
|
true);
|
||||||
|
}
|
||||||
|
@ -6,12 +6,15 @@
|
|||||||
#ifndef __VOL_BLOCK_DEV_TOP_H__
|
#ifndef __VOL_BLOCK_DEV_TOP_H__
|
||||||
#define __VOL_BLOCK_DEV_TOP_H__
|
#define __VOL_BLOCK_DEV_TOP_H__
|
||||||
|
|
||||||
|
int block_dev_activate_all_exported_objects(ocf_cache_t cache);
|
||||||
int block_dev_activate_exported_object(ocf_core_t core);
|
int block_dev_activate_exported_object(ocf_core_t core);
|
||||||
|
|
||||||
|
int block_dev_create_all_exported_objects(ocf_cache_t cache);
|
||||||
int block_dev_create_exported_object(ocf_core_t core);
|
int block_dev_create_exported_object(ocf_core_t core);
|
||||||
|
|
||||||
|
int block_dev_destroy_all_exported_objects(ocf_cache_t cache);
|
||||||
int block_dev_destroy_exported_object(ocf_core_t core);
|
int block_dev_destroy_exported_object(ocf_core_t core);
|
||||||
|
|
||||||
int block_dev_destroy_all_exported_objects(ocf_cache_t cache);
|
int block_dev_free_all_exported_objects(ocf_cache_t cache);
|
||||||
|
|
||||||
#endif /* __VOL_BLOCK_DEV_TOP_H__ */
|
#endif /* __VOL_BLOCK_DEV_TOP_H__ */
|
||||||
|
@ -421,6 +421,7 @@ void casdsk_exp_obj_free(struct casdsk_disk *dsk)
|
|||||||
kobject_put(&exp_obj->kobj);
|
kobject_put(&exp_obj->kobj);
|
||||||
dsk->exp_obj = NULL;
|
dsk->exp_obj = NULL;
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(casdsk_exp_obj_free);
|
||||||
|
|
||||||
static void __casdsk_exp_obj_release(struct casdsk_exp_obj *exp_obj)
|
static void __casdsk_exp_obj_release(struct casdsk_exp_obj *exp_obj)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user