当我用几道题考了一遍做Linux驱动的同事......

简介: 当我用几道题考了一遍做Linux驱动的同事......

出了几道题,考了一下做Linux驱动的同事!

说下新增驱动的一些基本操作

同事:先在设备树里新建一个节点,填写compatible和reg属性,然后在驱动里映射寄存器基址,后续就可以操作寄存器。

:寄存器基址怎么映射?

同事:先用platform_get_resource获取IORESOURCE_MEM资源,然后用devm_ioremap_resource将基址映射为虚拟地址。

:probe里还有哪些常规操作?

同事:通常一个驱动都会有时钟,所以probe里映射完基址后,通常要进行时钟和复位的操作。调用devm_clk_get获取时钟源,然后调用devm_clk_prepare_enbale使能时钟,复位的话先调用devm_reset_control_get获取复位源,然后用reset_control_reset复位。

:驱动中通常会定义一个私有结构体,里面包含一些内核结构体,但注册的时候只注册了某个成员,怎么找到这个私有结构体。

同事:可以通过container_of宏找到这个私有结构体的指针。

你会怎么给应用层提供接口

同事:驱动给应用层提供接口,一般都是通过ioctl接口,应用层传入一个结构体,驱动解析

:用户想在shell下调用驱动怎么办?

同事:可以提供procfs、sysfs或者debugfs这三个虚拟文件系统接口,根据具体用途提供

:这几个有什么区别?

同事:procfs接口一般是系统性的信息,主要是用来查看的,例如内存信息。sysfs接口更多用于与驱动交互,可以传参给驱动,修改驱动中一些变量。debugfs一般是用来调试用的,需要挂载debugfs。

内核启动时卡住或者崩了,怎么办

同事:卡住或者崩了,需要分析卡在哪里,从而找到原因。

:怎么知道卡在哪里?

同事:在内核的initcall初始化函数中加打印,把initcall的level和函数指针打印出来,看内核跑到了哪个等级的初始化。

:level等级是知道了,但这个等级执行的函数太多,而且打印出来的是地址,怎么知道具体跑到哪个函数?

同事:把内核编译出来的vmlinux文件反汇编,反汇编文件包含函数名和对应地址,根据地址查找。

说一下你知道的内核调试方法

同事:printk、BUG_ON、devmem、dump_statck......

:printk怎么用?

同事:printk有打印等级,用法和printf一样,可以用pr_info、pr_err这些不同等级的函数加打印。在shell中可以通过echo的方式控制printk等级

:为什么把printk等级调到最高,还是不能直接看到打印,而要通过dmesg?

同事:因为printk输出等级是针对串口控制台,要用串口连接才行,你可能使用ssh远程登录的。

:devmem怎么用?

同事:devmem是一个命令,它可以在shell下直接读写寄存器

:为什么devmem可以直接读写寄存器,而不需要映射?

同事:并非不需要映射,devmem应用程序会打开/dev/mem节点,这个设备实现了mmap接口,devmem应用程序打开/dev/mem后,会调用mmap函数将寄存器物理地址映射到用户空间,所以可以直接读写寄存器

:dump_stack有什么用?

同事:dump_stack函数可以打印函数调用栈,可以分析函数调用关系

:dump_stack出来的结果只有地址,没有函数名,怎么办?

同事:可以用工具链的add2line,查找地址对应的符号,就能看到函数名

:能让dump_stack显示出函数名吗?

同事:可以,只有地址的原因是因为内核配置没有打开CONFIG_KALLSYMS,这个配置是编入符号表,选上后,dump_stack就可以清楚看到调用关系和符合偏移。

简述MMU的工作原理

同事:以三级页表为例,MMU通过访问页表基址寄存器,得到一级页表PGD的基地址,再结合虚拟地址中的PGD index找到了下一级页表PTE的基地址;得到了PTE的基址,再结合虚拟地址中的PTE index找到PFN,然后再和VA相加得到物理地址。

:页表基址寄存器有什么用?

同事:存储第一级页表的基地址

:页表是谁创建的?MMU吗?

同事:页表是软件创建的,并非MMU硬件创建。MMU只是通过页表,将虚拟地址转换为了物理地址。

:页表在哪里?

同事:页表在物理内存中。

:CPU访问内存的过程是怎样的?

同事:CPU先访问TLB,如果TLB中存在这个地址,则直接从TLB中取地址。如果没有,再访问内存,读取页表,将虚拟地址转为物理地址,从而访问到内存。

:TLB又在哪里?TLB的本质是什么?

同事:TLB在MMU中,本质是一块cache。


总结,同事还是很强的!

end

猜你喜欢

入职Linux驱动工程师后,我才知道的真相......

一个Linux驱动工程师必知的内核模块知识

Linux内核中常用的数据结构和算法

Linux内核中常用的C语言技巧

Linux内核基础篇——常用调试技巧汇总

Linux内核基础篇——动态输出调试

Linux内核基础篇——printk调试

Linux内核基础篇——initcall

相关文章
|
4月前
|
Java Linux API
Linux设备驱动开发详解2
Linux设备驱动开发详解
58 6
|
4月前
|
消息中间件 算法 Unix
Linux设备驱动开发详解1
Linux设备驱动开发详解
61 5
|
4月前
|
Ubuntu NoSQL Linux
Linux内核和驱动
Linux内核和驱动
40 2
|
4月前
|
数据采集 Linux
Linux源码阅读笔记20-PCI设备驱动详解
Linux源码阅读笔记20-PCI设备驱动详解
|
5月前
|
存储 JSON Linux
|
5月前
|
Oracle 关系型数据库 Linux
讲解linux下的Qt如何编译oracle的驱动库libqsqloci.so
通过这一连串的步骤,可以专业且有效地在Linux下为Qt编译Oracle驱动库 `libqsqloci.so`,使得Qt应用能够通过OCI与Oracle数据库进行交互。这些步骤适用于具备一定Linux和Qt经验的开发者,并且能够为需要使用Qt开发数据库应用的专业人士提供指导。
180 1
讲解linux下的Qt如何编译oracle的驱动库libqsqloci.so
|
3月前
|
Linux API
Linux里的高精度时间计时器(HPET)驱动 【ChatGPT】
Linux里的高精度时间计时器(HPET)驱动 【ChatGPT】
|
4月前
|
Linux
【linux】【驱动】<specifier>-map-pass-thru讲解
【linux】【驱动】<specifier>-map-pass-thru讲解
24 0
|
4月前
|
Linux
【linux】【驱动】phy接口类型
【linux】【驱动】phy接口类型
28 0
|
5月前
|
缓存 网络协议 算法
【Linux系统编程】深入剖析:四大IO模型机制与应用(阻塞、非阻塞、多路复用、信号驱动IO 全解读)
在Linux环境下,主要存在四种IO模型,它们分别是阻塞IO(Blocking IO)、非阻塞IO(Non-blocking IO)、IO多路复用(I/O Multiplexing)和异步IO(Asynchronous IO)。下面我将逐一介绍这些模型的定义:
276 2

热门文章

最新文章