UART read过程分析

参考代码

串口核心层:
drivers/tty/serial/serial_core.c

TTY层:
drivers/tty/tty_io.c

行规程:
drivers/tty/tty_ldisc.c
drivers/tty/n_tty.c

read 过程

  1. APP 读:
    使用行规程来读
    无数据时休眠

  2. UART 接收到数据,产生硬件中断
    在中断处理函数中,从硬件上读入数据

  3. 发给行规程
    行规程处理后存入buffer
    唤醒APP
    
  4. APP 在行规程中得到数据

源码解析

drivers/tty/tty_io.c
在这里插入图片描述
这里的ld ->ops 是 n_tty.c 文件中的tty_ldisc_N_TTY 结构体,详情见: Uart驱动 open流程

drivers/tty/n_tty.c
在这里插入图片描述
当UART 硬件上,有数据产生时,触发中断, 读入 数据并且 发送给行规程,行规程得到数据后,唤醒APP

uart_insert_char(port, lsr, UART_LSR_OE, ch, flag); //将数据插入tty_port 的tty_buffer中
tty_flip_buffer_push(&port->state->port); //通知行规程
	
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Linux系统中,要抓包可以使用一些工具,例如tcpdump或Wireshark。不过针对UART串口数据的抓包,并不像网络数据那样简单方便。 在Linux中,UART串口设备会被当作字符设备文件,一般位于/dev目录下,如/dev/ttyUSB0或/dev/ttyS0。因为UART数据是原始的二进制数据,不能直接使用类似于tcpdump或Wireshark这样的工具进行解析和显示,我们需要自己编写一些代码来实现UART数据的抓包。 首先,我们需要使用C或Python等编程语言来打开UART设备文件,并设置设备参数,如波特率、数据位数、停止位等。然后,我们可以使用读取函数,如read()或recv(),从UART设备文件中读取数据。读取到的数据是原始的二进制数据,我们可以根据协议进行解析和显示。 在解析和显示UART数据时,我们需要了解所使用的协议格式。一般来说,UART数据会按照一定的格式进行传输,如帧头、帧尾、校验位等。我们可以编写相应的代码来解析这些数据格式,并将它们以易于理解的方式进行显示,如打印到终端或写入文件。 当然,如果想要更方便地进行UART数据的抓包,可以考虑使用一些专门设计用于串口调试和抓包的工具,如Serial Port Monitor或Bus Pirate等。这些工具可以通过连接到UART设备,实时显示和记录串口数据,方便用户分析和调试。 总之,Linux环境下的UART数据抓包需要编写一些代码来打开设备文件、读取数据和解析显示。同时,也可以考虑使用一些专门的工具来简化这个过程
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值