| Chuck Ebbert | cf1b939 | 2006-12-10 02:18:57 -0800 | [diff] [blame] | 1 | To decode a hex IOCTL code: | 
|  | 2 |  | 
| Matt LaPlante | d919588 | 2008-07-25 19:45:33 -0700 | [diff] [blame] | 3 | Most architectures use this generic format, but check | 
| Chuck Ebbert | cf1b939 | 2006-12-10 02:18:57 -0800 | [diff] [blame] | 4 | include/ARCH/ioctl.h for specifics, e.g. powerpc | 
|  | 5 | uses 3 bits to encode read/write and 13 bits for size. | 
|  | 6 |  | 
|  | 7 | bits    meaning | 
|  | 8 | 31-30	00 - no parameters: uses _IO macro | 
|  | 9 | 10 - read: _IOR | 
|  | 10 | 01 - write: _IOW | 
|  | 11 | 11 - read/write: _IOWR | 
|  | 12 |  | 
|  | 13 | 29-16	size of arguments | 
|  | 14 |  | 
|  | 15 | 15-8	ascii character supposedly | 
|  | 16 | unique to each driver | 
|  | 17 |  | 
|  | 18 | 7-0	function # | 
|  | 19 |  | 
|  | 20 |  | 
| Matt LaPlante | d919588 | 2008-07-25 19:45:33 -0700 | [diff] [blame] | 21 | So for example 0x82187201 is a read with arg length of 0x218, | 
| Chuck Ebbert | cf1b939 | 2006-12-10 02:18:57 -0800 | [diff] [blame] | 22 | character 'r' function 1. Grepping the source reveals this is: | 
|  | 23 |  | 
|  | 24 | #define VFAT_IOCTL_READDIR_BOTH         _IOR('r', 1, struct dirent [2]) |