本文主要是介绍linux 设备驱动之tty_driver数据结构介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
tty_driver 结构用来注册一个 tty 驱动到 tty 核心. 这是结构中所有不同的成员的列
表和如何被 tty 核心使用:
struct module *owner;
这个驱动的模块拥有者.
int magic;
给这个结构的"魔术"值. 应当一直设为 TTY_DRIVER_MAGIC. 在 alloc_tty_driver
函数中被初始化.
const char *driver_name;
驱动的名子, 用在 /proc/tty 和 sysfs.
const char *name;
驱动的节点名.
int name_base;
使用的起始数字, 当创建设备名子时. 当内核创建分配给这个 tty 驱动的一个特
定 tty 设备的字符串表示是使用.
short major;
驱动的主编号
short minor_start;
驱动的开始次编号. 这常常设为 name_base 的相同值. 典型地, 这个值设为 0.
short num;
分配给这个驱动的次编号个数. 如果整个主编号范围被驱动使用了, 这个值应当设
为 255. 这个变量在 alloc_tty_driver 函数中初始化.
short type;
short subtype;
描述什么类型的 tty 驱动在注册到 tty 核心. subtype 的值依赖于 type. type
成员可能是:
TTY_DRIVER_TYPE_SYSTEM
由 tty 子系统内部使用来记住它在处理一个内部 tty 驱动. subtype 应当设为
SYSTEM_TYPE_TTY, SYSTEM_TYEP_CONSOLE, SYSTEM_TYPE_SYSCONS, 或者
SYSTEM_TYPE_SYSPTMX. 这个类型不应当被任何"正常" tty 驱动使用.
TTY_DRIVER_TYPE_CONSOLE
仅被控制台驱动使用.
TTY_DRIVER_TYPE_SERIAL
被任何串行类型驱动使用. subtype 应当设为 SERIAL_TYPE_NORMAL 或者
SERIAL_TYPE_CALLOUT, 根据你的驱动是什么类型. 这是 type 成员的其中一个最
普遍的设置.
TTY_DRIVER_TYPE_PTY
被伪控制台接口(pty)使用. subtype 需要被设置为 PTY_TYPE_MASTER 或者
PTY_TYPE_SLAVE.
struct termios init_termios;
当创建设备时的初始化 struct termios 值.
int flags;
驱动标志, 如同本章前面描述的.
struct proc_dir_entry *proc_entry;
这个驱动的 /proc 入口结构. 它由 tty 核心创建如果驱动实现了 write_proc 或
者 read_proc 函数. 这个成员不应当由 tty 驱动自己设置.
struct tty_driver *other;
指向一个 tty 从驱动. 这只被 pty 驱动使用, 并且不应当被其他的 tty 驱动使
用.
void *driver_state;
tty 驱动的内部状态. 应当只被 pty 驱动使用.
struct tty_driver *next;
struct tty_driver *prev;
连接变量. 这些变量被 tty 核心使用来连接所有的不同 tty 驱动, 并且不应当被
任何 tty 驱动碰.
这篇关于linux 设备驱动之tty_driver数据结构介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!