linux debug工具集合

  • cat /proc/pid/fd/

    • 查看指定进程(PID)打开的所有文件描述符(fd)及其关联资源
  • strace -p pid

    • 是 Linux 下 跟踪指定进程(PID)系统调用和信号 的核心调试命令 ------ 简单说,它能 "实时监控" 目标进程正在执行哪些内核系统调用(比如 open、ioctl、mmap、close 等)、传递了什么参数、返回了什么结果,还能捕获进程收到的信号,是排查应用与内核(如 DRM 驱动)交互问题的 "利器"

    • strace -p 1234 -e trace=ioctl 跟踪 PID=1234 的 DRM 应用

      命令部分 作用 补充说明

      • strace 核心工具:跟踪进程的系统调用和信号 底层通过 ptrace 系统调用实现,依附到目标进程
      • -p pid 选项:指定要跟踪的进程 ID(pid 是目标进程的编号) 进程必须正在运行,否则会提示 "无此进程"
    • 扩展常用选项(调试 DRM 场景必备):

      c 复制代码
      -f:跟踪进程的子进程(比如 DRM 应用创建子进程处理渲染时,会一起跟踪);
      -t:在输出中添加时间戳(方便定位某个系统调用发生的时间);
      -T:显示每个系统调用的执行耗时(排查耗时过长的调用,如 ioctl 阻塞);
      -e trace=ioctl:只跟踪 ioctl 系统调用(DRM 应用主要通过 ioctl 与驱动交互,过滤后更简洁);
      -o log.txt:将跟踪日志输出到文件(避免终端刷屏,方便后续分析)。
    • 输出示例(跟踪 DRM 应用进程)

      用 strace -p 1234 -e trace=ioctl 跟踪 PID=1234 的 DRM 应用(只看 ioctl 调用),可能输出:

      c 复制代码
      ioctl(3, DRM_IOCTL_GEM_CREATE, {size=4194304, handle=0x7ffe9c3b2abc}) = 0
      ioctl(3, DRM_IOCTL_GEM_FLINK, {handle=1, name=0x7ffe9c3b2abd}) = 0
      ioctl(3, DRM_IOCTL_PRIME_HANDLE_TO_FD, {handle=1, flags=0, fd=5}) = 0
      ioctl(3, DRM_IOCTL_GEM_OPEN, {name=12345, handle=0x7ffe9c3b2abc, size=4194304}) = 0
      ioctl(3, DRM_IOCTL_MODE_SET_CRTC, {crtc_id=1, fb_id=2, x=0, y=0, mode=..., gamma_size=0}) = 0
  • cat /proc/pid/stack

    • 查询任意运行进程的内核栈
相关推荐
能喵烧香1 小时前
深度解析:Linux 与 Windows 超级权限账户的本质差异
linux·windows
Moshow郑锴3 小时前
Ubuntu 26.04 中文输入法 : fcitx5+Rime中州韵引擎
linux·运维·ubuntu
qq_163135754 小时前
Linux 【04-more命令超详细教程】
linux
sevencheng7985 小时前
【ADB】adb命令行常用按键模拟代码
linux·adb·模拟按键,返回键,音量键
暗影天帝5 小时前
BPI-R3 Mini 刷 Yuzhii DHCPD U-Boot 教程
linux
小赖同学啊5 小时前
智能连接器集群化高可用生产方案
linux·运维·人工智能
Cinema KI6 小时前
Linux第一个系统程序-进度条
linux·服务器
Moshow郑锴6 小时前
Ubuntu 26.04 更换阿里云源镜像
linux·运维·ubuntu
Jason_chen7 小时前
Linux 6.2 串口机制深度解析:AI驱动的自适应通信与零信任串口安全架构
linux
ShineWinsu7 小时前
对于Linux:线程概念与分页存储管理的解析
linux·运维·服务器·面试·线程·进程·虚拟空间地址