2013-09-26 14:38:17 +02:00
# ifndef USB_F_MASS_STORAGE_H
# define USB_F_MASS_STORAGE_H
2013-10-09 10:06:01 +02:00
# include <linux/usb/composite.h>
2013-09-26 14:38:17 +02:00
# include "storage_common.h"
struct fsg_module_parameters {
char * file [ FSG_MAX_LUNS ] ;
bool ro [ FSG_MAX_LUNS ] ;
bool removable [ FSG_MAX_LUNS ] ;
bool cdrom [ FSG_MAX_LUNS ] ;
bool nofua [ FSG_MAX_LUNS ] ;
unsigned int file_count , ro_count , removable_count , cdrom_count ;
unsigned int nofua_count ;
unsigned int luns ; /* nluns */
bool stall ; /* can_stall */
} ;
# define _FSG_MODULE_PARAM_ARRAY(prefix, params, name, type, desc) \
module_param_array_named ( prefix # # name , params . name , type , \
& prefix # # params . name # # _count , \
S_IRUGO ) ; \
MODULE_PARM_DESC ( prefix # # name , desc )
# define _FSG_MODULE_PARAM(prefix, params, name, type, desc) \
module_param_named ( prefix # # name , params . name , type , \
S_IRUGO ) ; \
MODULE_PARM_DESC ( prefix # # name , desc )
# define __FSG_MODULE_PARAMETERS(prefix, params) \
_FSG_MODULE_PARAM_ARRAY ( prefix , params , file , charp , \
" names of backing files or devices " ) ; \
_FSG_MODULE_PARAM_ARRAY ( prefix , params , ro , bool , \
" true to force read-only " ) ; \
_FSG_MODULE_PARAM_ARRAY ( prefix , params , removable , bool , \
" true to simulate removable media " ) ; \
_FSG_MODULE_PARAM_ARRAY ( prefix , params , cdrom , bool , \
" true to simulate CD-ROM instead of disk " ) ; \
_FSG_MODULE_PARAM_ARRAY ( prefix , params , nofua , bool , \
" true to ignore SCSI WRITE(10,12) FUA bit " ) ; \
_FSG_MODULE_PARAM ( prefix , params , luns , uint , \
" number of LUNs " ) ; \
_FSG_MODULE_PARAM ( prefix , params , stall , bool , \
" false to prevent bulk stalls " )
# ifdef CONFIG_USB_GADGET_DEBUG_FILES
# define FSG_MODULE_PARAMETERS(prefix, params) \
__FSG_MODULE_PARAMETERS ( prefix , params ) ; \
module_param_named ( num_buffers , fsg_num_buffers , uint , S_IRUGO ) ; \
MODULE_PARM_DESC ( num_buffers , " Number of pipeline buffers " )
# else
# define FSG_MODULE_PARAMETERS(prefix, params) \
__FSG_MODULE_PARAMETERS ( prefix , params )
# endif
struct fsg_common ;
/* FSF callback functions */
struct fsg_operations {
/*
* Callback function to call when thread exits . If no
* callback is set or it returns value lower then zero MSF
* will force eject all LUNs it operates on ( including those
* marked as non - removable or with prevent_medium_removal flag
* set ) .
*/
int ( * thread_exits ) ( struct fsg_common * common ) ;
} ;
2013-10-09 10:06:05 +02:00
struct fsg_lun_opts {
struct config_group group ;
struct fsg_lun * lun ;
int lun_id ;
} ;
2013-10-09 10:06:01 +02:00
struct fsg_opts {
struct fsg_common * common ;
struct usb_function_instance func_inst ;
2013-10-09 10:06:05 +02:00
struct fsg_lun_opts lun0 ;
struct config_group * default_groups [ 2 ] ;
2013-10-09 10:06:01 +02:00
bool no_configfs ; /* for legacy gadgets */
2013-10-09 10:06:05 +02:00
/*
* Read / write access to configfs attributes is handled by configfs .
*
* This is to protect the data from concurrent access by read / write
* and create symlink / remove symlink .
*/
struct mutex lock ;
int refcnt ;
2013-10-09 10:06:01 +02:00
} ;
2013-09-26 14:38:17 +02:00
struct fsg_lun_config {
const char * filename ;
char ro ;
char removable ;
char cdrom ;
char nofua ;
} ;
struct fsg_config {
unsigned nluns ;
struct fsg_lun_config luns [ FSG_MAX_LUNS ] ;
/* Callback functions. */
const struct fsg_operations * ops ;
/* Gadget's private data. */
void * private_data ;
const char * vendor_name ; /* 8 characters or less */
const char * product_name ; /* 16 characters or less */
char can_stall ;
unsigned int fsg_num_buffers ;
} ;
2013-10-09 10:06:01 +02:00
static inline struct fsg_opts *
fsg_opts_from_func_inst ( const struct usb_function_instance * fi )
{
return container_of ( fi , struct fsg_opts , func_inst ) ;
}
2013-09-26 14:38:17 +02:00
void fsg_common_get ( struct fsg_common * common ) ;
void fsg_common_put ( struct fsg_common * common ) ;
2013-10-09 10:05:53 +02:00
void fsg_common_set_sysfs ( struct fsg_common * common , bool sysfs ) ;
2013-10-09 10:05:55 +02:00
int fsg_common_set_num_buffers ( struct fsg_common * common , unsigned int n ) ;
2013-10-09 10:06:01 +02:00
void fsg_common_free_buffers ( struct fsg_common * common ) ;
2013-10-09 10:05:57 +02:00
int fsg_common_set_cdev ( struct fsg_common * common ,
struct usb_composite_dev * cdev , bool can_stall ) ;
2013-10-09 10:05:56 +02:00
void fsg_common_remove_lun ( struct fsg_lun * lun , bool sysfs ) ;
void fsg_common_remove_luns ( struct fsg_common * common ) ;
void fsg_common_free_luns ( struct fsg_common * common ) ;
int fsg_common_set_nluns ( struct fsg_common * common , int nluns ) ;
2013-10-09 10:06:02 +02:00
void fsg_common_set_ops ( struct fsg_common * common ,
const struct fsg_operations * ops ) ;
2013-10-09 10:05:58 +02:00
int fsg_common_create_lun ( struct fsg_common * common , struct fsg_lun_config * cfg ,
unsigned int id , const char * name ,
const char * * name_pfx ) ;
int fsg_common_create_luns ( struct fsg_common * common , struct fsg_config * cfg ) ;
2013-10-09 10:05:59 +02:00
void fsg_common_set_inquiry_string ( struct fsg_common * common , const char * vn ,
const char * pn ) ;
2013-10-09 10:06:00 +02:00
int fsg_common_run_thread ( struct fsg_common * common ) ;
2013-09-26 14:38:17 +02:00
void fsg_config_from_params ( struct fsg_config * cfg ,
const struct fsg_module_parameters * params ,
unsigned int fsg_num_buffers ) ;
# endif /* USB_F_MASS_STORAGE_H */