linux 设备驱动之tty_driver数据结构介绍

2024-01-18 16:52

本文主要是介绍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数据结构介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/619652

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)