~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/linux/auxiliary_bus.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/linux/auxiliary_bus.h (Version linux-6.12-rc7) and /include/linux/auxiliary_bus.h (Version linux-6.2.16)


  1 /* SPDX-License-Identifier: GPL-2.0-only */         1 /* SPDX-License-Identifier: GPL-2.0-only */
  2 /*                                                  2 /*
  3  * Copyright (c) 2019-2020 Intel Corporation        3  * Copyright (c) 2019-2020 Intel Corporation
  4  *                                                  4  *
  5  * Please see Documentation/driver-api/auxilia      5  * Please see Documentation/driver-api/auxiliary_bus.rst for more information.
  6  */                                                 6  */
  7                                                     7 
  8 #ifndef _AUXILIARY_BUS_H_                           8 #ifndef _AUXILIARY_BUS_H_
  9 #define _AUXILIARY_BUS_H_                           9 #define _AUXILIARY_BUS_H_
 10                                                    10 
 11 #include <linux/device.h>                          11 #include <linux/device.h>
 12 #include <linux/mod_devicetable.h>                 12 #include <linux/mod_devicetable.h>
 13                                                    13 
 14 /**                                                14 /**
 15  * DOC: DEVICE_LIFESPAN                            15  * DOC: DEVICE_LIFESPAN
 16  *                                                 16  *
 17  * The registering driver is the entity that a     17  * The registering driver is the entity that allocates memory for the
 18  * auxiliary_device and registers it on the au     18  * auxiliary_device and registers it on the auxiliary bus.  It is important to
 19  * note that, as opposed to the platform bus,      19  * note that, as opposed to the platform bus, the registering driver is wholly
 20  * responsible for the management of the memor     20  * responsible for the management of the memory used for the device object.
 21  *                                                 21  *
 22  * To be clear the memory for the auxiliary_de     22  * To be clear the memory for the auxiliary_device is freed in the release()
 23  * callback defined by the registering driver.     23  * callback defined by the registering driver.  The registering driver should
 24  * only call auxiliary_device_delete() and the     24  * only call auxiliary_device_delete() and then auxiliary_device_uninit() when
 25  * it is done with the device.  The release()      25  * it is done with the device.  The release() function is then automatically
 26  * called if and when other code releases thei     26  * called if and when other code releases their reference to the devices.
 27  *                                                 27  *
 28  * A parent object, defined in the shared head     28  * A parent object, defined in the shared header file, contains the
 29  * auxiliary_device.  It also contains a point     29  * auxiliary_device.  It also contains a pointer to the shared object(s), which
 30  * also is defined in the shared header.  Both     30  * also is defined in the shared header.  Both the parent object and the shared
 31  * object(s) are allocated by the registering      31  * object(s) are allocated by the registering driver.  This layout allows the
 32  * auxiliary_driver's registering module to pe     32  * auxiliary_driver's registering module to perform a container_of() call to go
 33  * from the pointer to the auxiliary_device, t     33  * from the pointer to the auxiliary_device, that is passed during the call to
 34  * the auxiliary_driver's probe function, up t     34  * the auxiliary_driver's probe function, up to the parent object, and then
 35  * have access to the shared object(s).            35  * have access to the shared object(s).
 36  *                                                 36  *
 37  * The memory for the shared object(s) must ha     37  * The memory for the shared object(s) must have a lifespan equal to, or
 38  * greater than, the lifespan of the memory fo     38  * greater than, the lifespan of the memory for the auxiliary_device.  The
 39  * auxiliary_driver should only consider that      39  * auxiliary_driver should only consider that the shared object is valid as
 40  * long as the auxiliary_device is still regis     40  * long as the auxiliary_device is still registered on the auxiliary bus.  It
 41  * is up to the registering driver to manage (     41  * is up to the registering driver to manage (e.g. free or keep available) the
 42  * memory for the shared object beyond the lif     42  * memory for the shared object beyond the life of the auxiliary_device.
 43  *                                                 43  *
 44  * The registering driver must unregister all      44  * The registering driver must unregister all auxiliary devices before its own
 45  * driver.remove() is completed.  An easy way      45  * driver.remove() is completed.  An easy way to ensure this is to use the
 46  * devm_add_action_or_reset() call to register     46  * devm_add_action_or_reset() call to register a function against the parent
 47  * device which unregisters the auxiliary devi     47  * device which unregisters the auxiliary device object(s).
 48  *                                                 48  *
 49  * Finally, any operations which operate on th     49  * Finally, any operations which operate on the auxiliary devices must continue
 50  * to function (if only to return an error) af     50  * to function (if only to return an error) after the registering driver
 51  * unregisters the auxiliary device.               51  * unregisters the auxiliary device.
 52  */                                                52  */
 53                                                    53 
 54 /**                                                54 /**
 55  * struct auxiliary_device - auxiliary device      55  * struct auxiliary_device - auxiliary device object.
 56  * @dev: Device,                                   56  * @dev: Device,
 57  *       The release and parent fields of the      57  *       The release and parent fields of the device structure must be filled
 58  *       in                                        58  *       in
 59  * @name: Match name found by the auxiliary de     59  * @name: Match name found by the auxiliary device driver,
 60  * @id: unique identitier if multiple devices      60  * @id: unique identitier if multiple devices of the same name are exported,
 61  * @sysfs: embedded struct which hold all sysf << 
 62  * @sysfs.irqs: irqs xarray contains irq indic << 
 63  * @sysfs.lock: Synchronize irq sysfs creation << 
 64  * @sysfs.irq_dir_exists: whether "irqs" direc << 
 65  *                                                 61  *
 66  * An auxiliary_device represents a part of it     62  * An auxiliary_device represents a part of its parent device's functionality.
 67  * It is given a name that, combined with the      63  * It is given a name that, combined with the registering drivers
 68  * KBUILD_MODNAME, creates a match_name that i     64  * KBUILD_MODNAME, creates a match_name that is used for driver binding, and an
 69  * id that combined with the match_name provid     65  * id that combined with the match_name provide a unique name to register with
 70  * the bus subsystem.  For example, a driver r     66  * the bus subsystem.  For example, a driver registering an auxiliary device is
 71  * named 'foo_mod.ko' and the subdevice is nam     67  * named 'foo_mod.ko' and the subdevice is named 'foo_dev'.  The match name is
 72  * therefore 'foo_mod.foo_dev'.                    68  * therefore 'foo_mod.foo_dev'.
 73  *                                                 69  *
 74  * Registering an auxiliary_device is a three-     70  * Registering an auxiliary_device is a three-step process.
 75  *                                                 71  *
 76  * First, a 'struct auxiliary_device' needs to     72  * First, a 'struct auxiliary_device' needs to be defined or allocated for each
 77  * sub-device desired.  The name, id, dev.rele     73  * sub-device desired.  The name, id, dev.release, and dev.parent fields of
 78  * this structure must be filled in as follows     74  * this structure must be filled in as follows.
 79  *                                                 75  *
 80  * The 'name' field is to be given a name that     76  * The 'name' field is to be given a name that is recognized by the auxiliary
 81  * driver.  If two auxiliary_devices with the      77  * driver.  If two auxiliary_devices with the same match_name, eg
 82  * "foo_mod.foo_dev", are registered onto the      78  * "foo_mod.foo_dev", are registered onto the bus, they must have unique id
 83  * values (e.g. "x" and "y") so that the regis     79  * values (e.g. "x" and "y") so that the registered devices names are
 84  * "foo_mod.foo_dev.x" and "foo_mod.foo_dev.y"     80  * "foo_mod.foo_dev.x" and "foo_mod.foo_dev.y".  If match_name + id are not
 85  * unique, then the device_add fails and gener     81  * unique, then the device_add fails and generates an error message.
 86  *                                                 82  *
 87  * The auxiliary_device.dev.type.release or au     83  * The auxiliary_device.dev.type.release or auxiliary_device.dev.release must
 88  * be populated with a non-NULL pointer to suc     84  * be populated with a non-NULL pointer to successfully register the
 89  * auxiliary_device.  This release call is whe     85  * auxiliary_device.  This release call is where resources associated with the
 90  * auxiliary device must be free'ed.  Because      86  * auxiliary device must be free'ed.  Because once the device is placed on the
 91  * bus the parent driver can not tell what oth     87  * bus the parent driver can not tell what other code may have a reference to
 92  * this data.                                      88  * this data.
 93  *                                                 89  *
 94  * The auxiliary_device.dev.parent should be s     90  * The auxiliary_device.dev.parent should be set.  Typically to the registering
 95  * drivers device.                                 91  * drivers device.
 96  *                                                 92  *
 97  * Second, call auxiliary_device_init(), which     93  * Second, call auxiliary_device_init(), which checks several aspects of the
 98  * auxiliary_device struct and performs a devi     94  * auxiliary_device struct and performs a device_initialize().  After this step
 99  * completes, any error state must have a call     95  * completes, any error state must have a call to auxiliary_device_uninit() in
100  * its resolution path.                            96  * its resolution path.
101  *                                                 97  *
102  * The third and final step in registering an      98  * The third and final step in registering an auxiliary_device is to perform a
103  * call to auxiliary_device_add(), which sets      99  * call to auxiliary_device_add(), which sets the name of the device and adds
104  * the device to the bus.                         100  * the device to the bus.
105  *                                                101  *
106  * .. code-block:: c                              102  * .. code-block:: c
107  *                                                103  *
108  *      #define MY_DEVICE_NAME "foo_dev"          104  *      #define MY_DEVICE_NAME "foo_dev"
109  *                                                105  *
110  *      ...                                       106  *      ...
111  *                                                107  *
112  *      struct auxiliary_device *my_aux_dev =     108  *      struct auxiliary_device *my_aux_dev = my_aux_dev_alloc(xxx);
113  *                                                109  *
114  *      // Step 1:                                110  *      // Step 1:
115  *      my_aux_dev->name = MY_DEVICE_NAME;        111  *      my_aux_dev->name = MY_DEVICE_NAME;
116  *      my_aux_dev->id = my_unique_id_alloc(xx    112  *      my_aux_dev->id = my_unique_id_alloc(xxx);
117  *      my_aux_dev->dev.release = my_aux_dev_r    113  *      my_aux_dev->dev.release = my_aux_dev_release;
118  *      my_aux_dev->dev.parent = my_dev;          114  *      my_aux_dev->dev.parent = my_dev;
119  *                                                115  *
120  *      // Step 2:                                116  *      // Step 2:
121  *      if (auxiliary_device_init(my_aux_dev))    117  *      if (auxiliary_device_init(my_aux_dev))
122  *              goto fail;                        118  *              goto fail;
123  *                                                119  *
124  *      // Step 3:                                120  *      // Step 3:
125  *      if (auxiliary_device_add(my_aux_dev))     121  *      if (auxiliary_device_add(my_aux_dev)) {
126  *              auxiliary_device_uninit(my_aux    122  *              auxiliary_device_uninit(my_aux_dev);
127  *              goto fail;                        123  *              goto fail;
128  *      }                                         124  *      }
129  *                                                125  *
130  *      ...                                       126  *      ...
131  *                                                127  *
132  *                                                128  *
133  * Unregistering an auxiliary_device is a two-    129  * Unregistering an auxiliary_device is a two-step process to mirror the
134  * register process.  First call auxiliary_dev    130  * register process.  First call auxiliary_device_delete(), then call
135  * auxiliary_device_uninit().                     131  * auxiliary_device_uninit().
136  *                                                132  *
137  * .. code-block:: c                              133  * .. code-block:: c
138  *                                                134  *
139  *         auxiliary_device_delete(my_dev->my_    135  *         auxiliary_device_delete(my_dev->my_aux_dev);
140  *         auxiliary_device_uninit(my_dev->my_    136  *         auxiliary_device_uninit(my_dev->my_aux_dev);
141  */                                               137  */
142 struct auxiliary_device {                         138 struct auxiliary_device {
143         struct device dev;                        139         struct device dev;
144         const char *name;                         140         const char *name;
145         u32 id;                                   141         u32 id;
146         struct {                               << 
147                 struct xarray irqs;            << 
148                 struct mutex lock; /* Synchron << 
149                 bool irq_dir_exists;           << 
150         } sysfs;                               << 
151 };                                                142 };
152                                                   143 
153 /**                                               144 /**
154  * struct auxiliary_driver - Definition of an     145  * struct auxiliary_driver - Definition of an auxiliary bus driver
155  * @probe: Called when a matching device is ad    146  * @probe: Called when a matching device is added to the bus.
156  * @remove: Called when device is removed from    147  * @remove: Called when device is removed from the bus.
157  * @shutdown: Called at shut-down time to quie    148  * @shutdown: Called at shut-down time to quiesce the device.
158  * @suspend: Called to put the device to sleep    149  * @suspend: Called to put the device to sleep mode. Usually to a power state.
159  * @resume: Called to bring a device from slee    150  * @resume: Called to bring a device from sleep mode.
160  * @name: Driver name.                            151  * @name: Driver name.
161  * @driver: Core driver structure.                152  * @driver: Core driver structure.
162  * @id_table: Table of devices this driver sho    153  * @id_table: Table of devices this driver should match on the bus.
163  *                                                154  *
164  * Auxiliary drivers follow the standard drive    155  * Auxiliary drivers follow the standard driver model convention, where
165  * discovery/enumeration is handled by the cor    156  * discovery/enumeration is handled by the core, and drivers provide probe()
166  * and remove() methods. They support power ma    157  * and remove() methods. They support power management and shutdown
167  * notifications using the standard convention    158  * notifications using the standard conventions.
168  *                                                159  *
169  * Auxiliary drivers register themselves with     160  * Auxiliary drivers register themselves with the bus by calling
170  * auxiliary_driver_register(). The id_table c    161  * auxiliary_driver_register(). The id_table contains the match_names of
171  * auxiliary devices that a driver can bind wi    162  * auxiliary devices that a driver can bind with.
172  *                                                163  *
173  * .. code-block:: c                              164  * .. code-block:: c
174  *                                                165  *
175  *         static const struct auxiliary_devic    166  *         static const struct auxiliary_device_id my_auxiliary_id_table[] = {
176  *                 { .name = "foo_mod.foo_dev"    167  *                 { .name = "foo_mod.foo_dev" },
177  *                 {},                            168  *                 {},
178  *         };                                     169  *         };
179  *                                                170  *
180  *         MODULE_DEVICE_TABLE(auxiliary, my_a    171  *         MODULE_DEVICE_TABLE(auxiliary, my_auxiliary_id_table);
181  *                                                172  *
182  *         struct auxiliary_driver my_drv = {     173  *         struct auxiliary_driver my_drv = {
183  *                 .name = "myauxiliarydrv",      174  *                 .name = "myauxiliarydrv",
184  *                 .id_table = my_auxiliary_id    175  *                 .id_table = my_auxiliary_id_table,
185  *                 .probe = my_drv_probe,         176  *                 .probe = my_drv_probe,
186  *                 .remove = my_drv_remove        177  *                 .remove = my_drv_remove
187  *         };                                     178  *         };
188  */                                               179  */
189 struct auxiliary_driver {                         180 struct auxiliary_driver {
190         int (*probe)(struct auxiliary_device *    181         int (*probe)(struct auxiliary_device *auxdev, const struct auxiliary_device_id *id);
191         void (*remove)(struct auxiliary_device    182         void (*remove)(struct auxiliary_device *auxdev);
192         void (*shutdown)(struct auxiliary_devi    183         void (*shutdown)(struct auxiliary_device *auxdev);
193         int (*suspend)(struct auxiliary_device    184         int (*suspend)(struct auxiliary_device *auxdev, pm_message_t state);
194         int (*resume)(struct auxiliary_device     185         int (*resume)(struct auxiliary_device *auxdev);
195         const char *name;                         186         const char *name;
196         struct device_driver driver;              187         struct device_driver driver;
197         const struct auxiliary_device_id *id_t    188         const struct auxiliary_device_id *id_table;
198 };                                                189 };
199                                                   190 
200 static inline void *auxiliary_get_drvdata(stru    191 static inline void *auxiliary_get_drvdata(struct auxiliary_device *auxdev)
201 {                                                 192 {
202         return dev_get_drvdata(&auxdev->dev);     193         return dev_get_drvdata(&auxdev->dev);
203 }                                                 194 }
204                                                   195 
205 static inline void auxiliary_set_drvdata(struc    196 static inline void auxiliary_set_drvdata(struct auxiliary_device *auxdev, void *data)
206 {                                                 197 {
207         dev_set_drvdata(&auxdev->dev, data);      198         dev_set_drvdata(&auxdev->dev, data);
208 }                                                 199 }
209                                                   200 
210 static inline struct auxiliary_device *to_auxi    201 static inline struct auxiliary_device *to_auxiliary_dev(struct device *dev)
211 {                                                 202 {
212         return container_of(dev, struct auxili    203         return container_of(dev, struct auxiliary_device, dev);
213 }                                                 204 }
214                                                   205 
215 static inline const struct auxiliary_driver *t !! 206 static inline struct auxiliary_driver *to_auxiliary_drv(struct device_driver *drv)
216 {                                                 207 {
217         return container_of(drv, struct auxili    208         return container_of(drv, struct auxiliary_driver, driver);
218 }                                                 209 }
219                                                   210 
220 int auxiliary_device_init(struct auxiliary_dev    211 int auxiliary_device_init(struct auxiliary_device *auxdev);
221 int __auxiliary_device_add(struct auxiliary_de    212 int __auxiliary_device_add(struct auxiliary_device *auxdev, const char *modname);
222 #define auxiliary_device_add(auxdev) __auxilia    213 #define auxiliary_device_add(auxdev) __auxiliary_device_add(auxdev, KBUILD_MODNAME)
223                                                   214 
224 #ifdef CONFIG_SYSFS                            << 
225 int auxiliary_device_sysfs_irq_add(struct auxi << 
226 void auxiliary_device_sysfs_irq_remove(struct  << 
227                                        int irq << 
228 #else /* CONFIG_SYSFS */                       << 
229 static inline int                              << 
230 auxiliary_device_sysfs_irq_add(struct auxiliar << 
231 {                                              << 
232         return 0;                              << 
233 }                                              << 
234                                                << 
235 static inline void                             << 
236 auxiliary_device_sysfs_irq_remove(struct auxil << 
237 #endif                                         << 
238                                                << 
239 static inline void auxiliary_device_uninit(str    215 static inline void auxiliary_device_uninit(struct auxiliary_device *auxdev)
240 {                                                 216 {
241         mutex_destroy(&auxdev->sysfs.lock);    << 
242         put_device(&auxdev->dev);                 217         put_device(&auxdev->dev);
243 }                                                 218 }
244                                                   219 
245 static inline void auxiliary_device_delete(str    220 static inline void auxiliary_device_delete(struct auxiliary_device *auxdev)
246 {                                                 221 {
247         device_del(&auxdev->dev);                 222         device_del(&auxdev->dev);
248 }                                                 223 }
249                                                   224 
250 int __auxiliary_driver_register(struct auxilia    225 int __auxiliary_driver_register(struct auxiliary_driver *auxdrv, struct module *owner,
251                                 const char *mo    226                                 const char *modname);
252 #define auxiliary_driver_register(auxdrv) \       227 #define auxiliary_driver_register(auxdrv) \
253         __auxiliary_driver_register(auxdrv, TH    228         __auxiliary_driver_register(auxdrv, THIS_MODULE, KBUILD_MODNAME)
254                                                   229 
255 void auxiliary_driver_unregister(struct auxili    230 void auxiliary_driver_unregister(struct auxiliary_driver *auxdrv);
256                                                   231 
257 /**                                               232 /**
258  * module_auxiliary_driver() - Helper macro fo    233  * module_auxiliary_driver() - Helper macro for registering an auxiliary driver
259  * @__auxiliary_driver: auxiliary driver struc    234  * @__auxiliary_driver: auxiliary driver struct
260  *                                                235  *
261  * Helper macro for auxiliary drivers which do    236  * Helper macro for auxiliary drivers which do not do anything special in
262  * module init/exit. This eliminates a lot of     237  * module init/exit. This eliminates a lot of boilerplate. Each module may only
263  * use this macro once, and calling it replace    238  * use this macro once, and calling it replaces module_init() and module_exit()
264  *                                                239  *
265  * .. code-block:: c                              240  * .. code-block:: c
266  *                                                241  *
267  *      module_auxiliary_driver(my_drv);          242  *      module_auxiliary_driver(my_drv);
268  */                                               243  */
269 #define module_auxiliary_driver(__auxiliary_dr    244 #define module_auxiliary_driver(__auxiliary_driver) \
270         module_driver(__auxiliary_driver, auxi    245         module_driver(__auxiliary_driver, auxiliary_driver_register, auxiliary_driver_unregister)
271                                                   246 
272 struct auxiliary_device *auxiliary_find_device    247 struct auxiliary_device *auxiliary_find_device(struct device *start,
273                                                   248                                                const void *data,
274                                                !! 249                                                int (*match)(struct device *dev, const void *data));
275                                                   250 
276 #endif /* _AUXILIARY_BUS_H_ */                    251 #endif /* _AUXILIARY_BUS_H_ */
277                                                   252 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php