/** * struct dfl_device - represent an dfl device on dfl bus * * @dev: generic device interface. * @id: id of the dfl device. * @type: type of DFL FIU of the device. See enum dfl_id_type. * @feature_id: feature identifier local to its DFL FIU type. * @revision: revision of this dfl device feature. * @mmio_res: mmio resource of this dfl device. * @irqs: list of Linux IRQ numbers of this dfl device. * @num_irqs: number of IRQs supported by this dfl device. * @cdev: pointer to DFL FPGA container device this dfl device belongs to. * @id_entry: matched id entry in dfl driver's id table. * @dfh_version: version of DFH for the device * @param_size: size of the block parameters in bytes * @params: pointer to block of parameters copied memory
*/ struct dfl_device { struct device dev; int id;
u16 type;
u16 feature_id;
u8 revision; struct resource mmio_res; int *irqs; unsignedint num_irqs; struct dfl_fpga_cdev *cdev; conststruct dfl_device_id *id_entry;
u8 dfh_version; unsignedint param_size; void *params;
};
/** * struct dfl_driver - represent an dfl device driver * * @drv: driver model structure. * @id_table: pointer to table of device IDs the driver is interested in. * { } member terminated. * @probe: mandatory callback for device binding. * @remove: callback for device unbinding.
*/ struct dfl_driver { struct device_driver drv; conststruct dfl_device_id *id_table;
int (*probe)(struct dfl_device *dfl_dev); void (*remove)(struct dfl_device *dfl_dev);
};
/* * use a macro to avoid include chaining to get THIS_MODULE.
*/ #define dfl_driver_register(drv) \
__dfl_driver_register(drv, THIS_MODULE) int __dfl_driver_register(struct dfl_driver *dfl_drv, struct module *owner); void dfl_driver_unregister(struct dfl_driver *dfl_drv);
/* * module_dfl_driver() - Helper macro for drivers that don't do * anything special in module init/exit. This eliminates a lot of * boilerplate. Each module may only use this macro once, and * calling it replaces module_init() and module_exit().
*/ #define module_dfl_driver(__dfl_driver) \
module_driver(__dfl_driver, dfl_driver_register, \
dfl_driver_unregister)
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.