| ============================== |
| Decoding an IOCTL Magic Number |
| ============================== |
| |
| To decode a hex IOCTL code: |
| |
| Most architectures use this generic format, but check |
| include/ARCH/ioctl.h for specifics, e.g. powerpc |
| uses 3 bits to encode read/write and 13 bits for size. |
| |
| ====== ================================== |
| bits meaning |
| ====== ================================== |
| 31-30 00 - no parameters: uses _IO macro |
| 10 - read: _IOR |
| 01 - write: _IOW |
| 11 - read/write: _IOWR |
| |
| 29-16 size of arguments |
| |
| 15-8 ascii character supposedly |
| unique to each driver |
| |
| 7-0 function # |
| ====== ================================== |
| |
| |
| So for example 0x82187201 is a read with arg length of 0x218, |
| character 'r' function 1. Grepping the source reveals this is:: |
| |
| #define VFAT_IOCTL_READDIR_BOTH _IOR('r', 1, struct dirent [2]) |