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