Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | #ifndef _LINUX_MISCDEVICE_H |
| 3 | #define _LINUX_MISCDEVICE_H |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 4 | #include <linux/major.h> |
Paul Gortmaker | 1986c93 | 2011-08-29 15:22:17 -0400 | [diff] [blame] | 5 | #include <linux/list.h> |
| 6 | #include <linux/types.h> |
PrasannaKumar Muralidharan | ca75d60 | 2016-08-25 22:30:49 +0530 | [diff] [blame] | 7 | #include <linux/device.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 8 | |
Alan Cox | 79907d8 | 2010-06-09 09:39:49 +0100 | [diff] [blame] | 9 | /* |
Sebastian Fricke | 31b4b3b | 2020-08-03 07:43:45 +0200 | [diff] [blame] | 10 | * These allocations are managed by device@lanana.org. If you need |
| 11 | * an entry that is not assigned here, it can be moved and |
| 12 | * reassigned or dynamically set if a fixed value is not justified. |
Alan Cox | 79907d8 | 2010-06-09 09:39:49 +0100 | [diff] [blame] | 13 | */ |
| 14 | |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 15 | #define PSMOUSE_MINOR 1 |
Lucas De Marchi | 3503958 | 2014-02-18 02:27:24 -0300 | [diff] [blame] | 16 | #define MS_BUSMOUSE_MINOR 2 /* unused */ |
| 17 | #define ATIXL_BUSMOUSE_MINOR 3 /* unused */ |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 18 | /*#define AMIGAMOUSE_MINOR 4 FIXME OBSOLETE */ |
Lucas De Marchi | 3503958 | 2014-02-18 02:27:24 -0300 | [diff] [blame] | 19 | #define ATARIMOUSE_MINOR 5 /* unused */ |
| 20 | #define SUN_MOUSE_MINOR 6 /* unused */ |
| 21 | #define APOLLO_MOUSE_MINOR 7 /* unused */ |
| 22 | #define PC110PAD_MINOR 9 /* unused */ |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 23 | /*#define ADB_MOUSE_MINOR 10 FIXME OBSOLETE */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 24 | #define WATCHDOG_MINOR 130 /* Watchdog timer */ |
| 25 | #define TEMP_MINOR 131 /* Temperature Sensor */ |
Corentin Labbe | 874bcd0 | 2016-12-15 20:36:33 +0100 | [diff] [blame] | 26 | #define APM_MINOR_DEV 134 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 27 | #define RTC_MINOR 135 |
Arnd Bergmann | 8067c0b | 2020-02-26 23:43:21 +0100 | [diff] [blame] | 28 | /*#define EFI_RTC_MINOR 136 was EFI Time services */ |
Lucas De Marchi | b075dd4 | 2014-02-18 02:19:26 -0300 | [diff] [blame] | 29 | #define VHCI_MINOR 137 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 30 | #define SUN_OPENPROM_MINOR 139 |
Lucas De Marchi | 3503958 | 2014-02-18 02:27:24 -0300 | [diff] [blame] | 31 | #define DMAPI_MINOR 140 /* unused */ |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 32 | #define NVRAM_MINOR 144 |
Zhenzhong Duan | 2668dba | 2020-03-11 15:16:54 +0800 | [diff] [blame] | 33 | #define SBUS_FLASH_MINOR 152 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 34 | #define SGI_MMTIMER 153 |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 35 | #define PMU_MINOR 154 |
Lucas De Marchi | 3503958 | 2014-02-18 02:27:24 -0300 | [diff] [blame] | 36 | #define STORE_QUEUE_MINOR 155 /* unused */ |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 37 | #define LCD_MINOR 156 |
| 38 | #define AC_MINOR 157 |
| 39 | #define BUTTON_MINOR 158 /* Major 10, Minor 158, /dev/nwbutton */ |
Zhenzhong Duan | 2668dba | 2020-03-11 15:16:54 +0800 | [diff] [blame] | 40 | #define NWFLASH_MINOR 160 /* MAJOR is 10 - miscdevice */ |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 41 | #define ENVCTRL_MINOR 162 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 42 | #define I2O_MINOR 166 |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 43 | #define UCTRL_MINOR 174 |
Corentin Labbe | 0f109f0 | 2019-11-21 08:14:42 +0000 | [diff] [blame] | 44 | #define AGPGART_MINOR 175 |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 45 | #define TOSH_MINOR_DEV 181 |
Corentin LABBE | fd50d71 | 2016-12-13 15:51:13 +0100 | [diff] [blame] | 46 | #define HWRNG_MINOR 183 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 47 | #define MICROCODE_MINOR 184 |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 48 | #define KEYPAD_MINOR 185 |
LABBE Corentin | 24c946c | 2016-12-15 11:42:48 +0100 | [diff] [blame] | 49 | #define IRNET_MINOR 187 |
Corentin Labbe | da61e73 | 2017-09-18 20:10:36 +0200 | [diff] [blame] | 50 | #define D7S_MINOR 193 |
Alex Williamson | 8dcf94b | 2013-12-19 10:17:11 -0700 | [diff] [blame] | 51 | #define VFIO_MINOR 196 |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 52 | #define PXA3XX_GCU_MINOR 197 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 53 | #define TUN_MINOR 200 |
Tom Gundersen | cb2ffb2 | 2013-09-09 20:18:27 +0200 | [diff] [blame] | 54 | #define CUSE_MINOR 203 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 55 | #define MWAVE_MINOR 219 /* ACP/Mwave Modem */ |
| 56 | #define MPT_MINOR 220 |
Eric Moore | dec3f95 | 2009-03-09 01:27:49 -0600 | [diff] [blame] | 57 | #define MPT2SAS_MINOR 221 |
Sreekanth Reddy | 78ad724 | 2012-11-30 07:58:10 +0530 | [diff] [blame] | 58 | #define MPT3SAS_MINOR 222 |
Kay Sievers | 8905aaa | 2010-08-19 09:52:28 -0700 | [diff] [blame] | 59 | #define UINPUT_MINOR 223 |
Liu, Jinsong | cef12ee | 2012-06-07 19:56:51 +0800 | [diff] [blame] | 60 | #define MISC_MCELOG_MINOR 227 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 61 | #define HPET_MINOR 228 |
| 62 | #define FUSE_MINOR 229 |
Zhenzhong Duan | 6ce6ae7 | 2020-03-11 15:16:53 +0800 | [diff] [blame] | 63 | #define SNAPSHOT_MINOR 231 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 64 | #define KVM_MINOR 232 |
Kay Sievers | 578454f | 2010-05-20 18:07:20 +0200 | [diff] [blame] | 65 | #define BTRFS_MINOR 234 |
| 66 | #define AUTOFS_MINOR 235 |
Peter Rajnoha | 7e507eb | 2010-08-12 04:14:05 +0100 | [diff] [blame] | 67 | #define MAPPER_CTRL_MINOR 236 |
Kay Sievers | 770fe30 | 2011-07-31 22:08:04 +0200 | [diff] [blame] | 68 | #define LOOP_CTRL_MINOR 237 |
stephen hemminger | 7c7c7f0 | 2012-01-11 19:30:38 +0000 | [diff] [blame] | 69 | #define VHOST_NET_MINOR 238 |
David Herrmann | 19872d2 | 2013-09-09 18:33:54 +0200 | [diff] [blame] | 70 | #define UHID_MINOR 239 |
Stephen Chandler Paul | 5523662e | 2015-10-24 13:10:29 -0700 | [diff] [blame] | 71 | #define USERIO_MINOR 240 |
Stefan Hajnoczi | f4660cc | 2017-05-10 10:19:18 -0400 | [diff] [blame] | 72 | #define VHOST_VSOCK_MINOR 241 |
Marcel Holtmann | 8670b2b | 2019-10-24 19:40:42 +0200 | [diff] [blame] | 73 | #define RFKILL_MINOR 242 |
Tejun Heo | 193da60 | 2008-11-26 12:03:54 +0100 | [diff] [blame] | 74 | #define MISC_DYNAMIC_MINOR 255 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 75 | |
| 76 | struct device; |
Takashi Iwai | bd73599 | 2015-02-02 15:44:54 +0100 | [diff] [blame] | 77 | struct attribute_group; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 78 | |
| 79 | struct miscdevice { |
| 80 | int minor; |
| 81 | const char *name; |
Arjan van de Ven | 99ac48f | 2006-03-28 01:56:41 -0800 | [diff] [blame] | 82 | const struct file_operations *fops; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 83 | struct list_head list; |
Greg Kroah-Hartman | 94fbcde | 2006-07-27 16:16:04 -0700 | [diff] [blame] | 84 | struct device *parent; |
| 85 | struct device *this_device; |
Takashi Iwai | bd73599 | 2015-02-02 15:44:54 +0100 | [diff] [blame] | 86 | const struct attribute_group **groups; |
Kay Sievers | e454cea | 2009-09-18 23:01:12 +0200 | [diff] [blame] | 87 | const char *nodename; |
Al Viro | a85cfda | 2011-07-26 04:47:38 -0400 | [diff] [blame] | 88 | umode_t mode; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 89 | }; |
| 90 | |
Robert P. J. Day | f82dd4b | 2014-05-16 04:36:13 -0400 | [diff] [blame] | 91 | extern int misc_register(struct miscdevice *misc); |
Greg Kroah-Hartman | f368ed6 | 2015-07-30 15:59:57 -0700 | [diff] [blame] | 92 | extern void misc_deregister(struct miscdevice *misc); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 93 | |
PrasannaKumar Muralidharan | ca75d60 | 2016-08-25 22:30:49 +0530 | [diff] [blame] | 94 | /* |
Paul Gortmaker | f71082f | 2016-10-22 18:36:05 -0400 | [diff] [blame] | 95 | * Helper macro for drivers that don't do anything special in the initcall. |
Sebastian Fricke | 31b4b3b | 2020-08-03 07:43:45 +0200 | [diff] [blame] | 96 | * This helps to eliminate boilerplate code. |
Paul Gortmaker | f71082f | 2016-10-22 18:36:05 -0400 | [diff] [blame] | 97 | */ |
| 98 | #define builtin_misc_device(__misc_device) \ |
| 99 | builtin_driver(__misc_device, misc_register) |
| 100 | |
| 101 | /* |
PrasannaKumar Muralidharan | ca75d60 | 2016-08-25 22:30:49 +0530 | [diff] [blame] | 102 | * Helper macro for drivers that don't do anything special in module init / exit |
Sebastian Fricke | 31b4b3b | 2020-08-03 07:43:45 +0200 | [diff] [blame] | 103 | * call. This helps to eliminate boilerplate code. |
PrasannaKumar Muralidharan | ca75d60 | 2016-08-25 22:30:49 +0530 | [diff] [blame] | 104 | */ |
| 105 | #define module_misc_device(__misc_device) \ |
| 106 | module_driver(__misc_device, misc_register, misc_deregister) |
| 107 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 108 | #define MODULE_ALIAS_MISCDEV(minor) \ |
| 109 | MODULE_ALIAS("char-major-" __stringify(MISC_MAJOR) \ |
| 110 | "-" __stringify(minor)) |
| 111 | #endif |