On Mon, May 02, 2011 at 11:04:40PM +0800, wanlong.gao@xxxxxxxxx wrote: > From: Wanlong Gao <wanlong.gao@xxxxxxxxx> > > Add the comment the structure bus_type, device_driver, device, > class for generating the driver-model kerneldoc. > > Signed-off-by: Wanlong Gao <wanlong.gao@xxxxxxxxx> > --- > Documentation/DocBook/device-drivers.tmpl | 6 +- > include/linux/device.h | 104 ++++++++++++++++++++++++++++- > 2 files changed, 104 insertions(+), 6 deletions(-) > > diff --git a/Documentation/DocBook/device-drivers.tmpl b/Documentation/DocBook/device-drivers.tmpl > index 36f63d4..5e482e0 100644 > --- a/Documentation/DocBook/device-drivers.tmpl > +++ b/Documentation/DocBook/device-drivers.tmpl > @@ -96,10 +96,10 @@ X!Iinclude/linux/kobject.h > > <chapter id="devdrivers"> > <title>Device drivers infrastructure</title> > + <sect1><title>The Basic Device Driver-Model Structure </title> > +!Iinclude/linux/device.h > + </sect1> > <sect1><title>Device Drivers Base</title> > -<!-- > -X!Iinclude/linux/device.h > ---> > !Edrivers/base/driver.c > !Edrivers/base/core.c > !Edrivers/base/class.c > diff --git a/include/linux/device.h b/include/linux/device.h > index ab8dfc0..5258d5d 100644 > --- a/include/linux/device.h > +++ b/include/linux/device.h > @@ -47,6 +47,23 @@ extern int __must_check bus_create_file(struct bus_type *, > struct bus_attribute *); > extern void bus_remove_file(struct bus_type *, struct bus_attribute *); > > +/** > + * struct bus_type - The bus type of the device . > + * > + * @name: The name of the bus > + * @bus_attrs: The attributes of the bus Default attributes of the bus. > + * @dev_attrs: The default attributes of the devices on the bus > + * @drv_attrs: The default attributes of the device drivers on the bus > + * @match: Attaching drivers to devices No, this is called when the driver core wants to know if this driver can accept this device. It does not do an "attach" here. > + * @uevent: Add the environment variable for device plug "device plug"? No, not always, it is for when a device is added, removed, or a few other things that generate uevents. > + * @probe: Probe the device > + * @remove: Remove the device > + * @shutdown: Shutdown method > + * @suspend: Suspend method > + * @resume: Resume method All of these can get more descriptions, right? > + * @pm: Device power management operations > + * @p: The private data the subsystem p is private to the driver core, not to the subsystem. Only the driver core can touch this. > + */ > struct bus_type { > const char *name; > struct bus_attribute *bus_attrs; > @@ -119,6 +136,23 @@ extern int bus_unregister_notifier(struct bus_type *bus, > extern struct kset *bus_get_kset(struct bus_type *bus); > extern struct klist *bus_get_device_klist(struct bus_type *bus); > > +/** > + * struct device_driver - The basic device driver structure > + * @name: Name of the device driver > + * @bus: The bus the device driver belongs to > + * @owner: The driver's owner The module owner. > + * @mod_name: Used for built-in modules Huh? > + * @suppress_bind_attrs:Disables bind/unbind via sysfs > + * @of_match_table:Id table for matching the driver to device No, this is an open firmware table. > + * @probe: Called to bound a driver to the device To bind. > + * @remove: Called to unbind a driver from a device > + * @shutdown: Called when shutdown > + * @suspend: Called to put the device in a low power state Suspend is more than a "low power state" > + * @resume: Used to bring a device from a low power state Same here. > + * @groups: Driver's attribute groups Default attributes that get created by the driver core automatically. > + * @pm: Device's power management operations > + * @p: Driver's private data Again, the driver core's private data, not the driver's private data, very big difference. No one other than the driver core can touch this. Same goes for the other comments you added... I think this needs a whole lot more description than what you have provided in order for it to be acceptable. Care to work on it? thanks, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-doc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html