<linux/kdev.h>内容如下:
#ifndef _LINUX_KDEV_T_H
#define _LINUX_KDEV_T_H
#ifdef __KERNEL__
#define MINORBITS 20
#define MINORMASK ((1U << MINORBITS) - 1)
#define MAJOR(dev) ((unsigned int) ((dev) >> MINORBITS))
#define MINOR(dev) ((unsigned int) ((dev) & MINORMASK))
#define MKDEV(ma,mi) (((ma) << MINORBITS) | (mi))
在内核中,用32位的dev_t类型来保存设备编号,高12位为主设备号,低20位为次设备号。
要获取dev_t的主次设备,应使用:
MAJOR(dev_t dev); //主设备号
MINOR(dev_t dev); //次设备号
如果要将主次设备号转为dev_t类型,应使用:
MKDEV(int major, int minor);
这里需要注意的是次设备的code:
#define MINORMASK ((1U << MINORBITS) - 1)
#define MINOR(dev) ((unsigned int) ((dev) & MINORMASK))
这里我们讲一下1u<<(bit)的含义
1u<<(bit)可以理解为取一个无符号数(unsigned)其大小为1,并且将其左移bit位。
假设 bit等于5, 则其等同于:
(1<<5)-1; 即100000-1 =011111
因此,
(1U << MINORBITS) = 0000 0000 0001 0000 0000 0000 0000 0000
((1U << MINORBITS) - 1) = 0000 0000 0000 1111 1111 1111 1111 1111
MAJOR(dev)得到的是dev的高12位,MINOR(dev)得到的是dev的低20位
MKDEV(ma,mi) 就是先将主设备号左移20位,然后与此设备号相加得到设备号