书籍详情
深入Linux设备驱动程序内核机制
作者:陈学松 著
出版社:电子工业出版社
出版时间:2012-01-08
ISBN:9787121150524
定价:¥98.00
购买这本书可以去
内容简介
内 容 简 介这是一本系统阐述Linux设备驱动程序技术内幕的专业书籍,它的侧重点不是讨论如何在Linux系统下编写设备驱动程序,而是要告诉读者隐藏在这些设备驱动程序背后的那些内核机制及原理。作者通过对Linux内核源码抽丝剥茧般的解读,再辅之以精心设计的大量图片,使读者在阅读完本书后对驱动程序前台所展现出来的那些行为特点变得豁然开朗。本书涵盖了编写设备驱动程序所需要的几乎所有的内核设施,比如内核模块、中断处理、互斥与同步、内存分配、延迟操作、时间管理,以及新设备驱动模型等内容。为了避免读者迷失在某一技术细节的讨论当中,本书在一个比较高的层面上进行展开,以一种先框架再细节的结构安排极大地简化了读者的阅读与学习。本书不仅适合那些在Linux系统下从事设备驱动程序开发的专业技术人员阅读,也同样适合有志于从事Linux设备驱动程序开发或对Linux设备驱动程序及Linux内核感兴趣的在校学生等阅读。对于没有任何Linux设备驱动程序开发经验的初学者,建议先阅读那些讨论“如何”在Linux系统下编写设备驱动程序的入门书籍,然后再阅读本书来理解“为什么”要以这样或者那样的方式来编写设备驱动程序。
作者简介
陈学松,曾任职于Intel,Marvell等半导体公司,9年以上Linux内核、设备驱动程序、嵌入式LinuxBSP等领域的开发经验。专注于Linux系统内核、BIOS、文件系统及软件虚拟化等技术,曾模仿Linux内核编写过微型操作系统。工作之余喜欢以文章的形式将自己的学习心得进行总结,善于运用图形等元素将复杂概念具体化,梳理脉络而不拘于细节。05年在IBMLinux开发者论坛所发表的《解析Linux中的VFS文件系统机制》则堪称作者这一写作特色的代表之作,该文发表后曾被多家技术网站、论坛及个人博客所转载。喜欢游泳,四肢发达,胸无城府。古文功底颇深,少时涉猎甚广,现在则主要阅读一些历史题材类的书籍,熟读《三国志》。目前任职于AMD上海研发中心,主要从事Linux显卡驱动等领域的研发工作。
目录
目 录第1章 内核模块 11.1 内核模块的文件格式 21.2 EXPORT_SYMBOL的内核实现 51.3 模块的加载过程 81.3.1 sys_init_module(第一部分) 91.3.2 structmodule 91.3.3 load_module 131.3.4 sys_init_module(第二部分) 491.3.5 模块的卸载 541.4 本章小结 55第2章 字符设备驱动程序 572.1 应用程序与设备驱动程序互动实例 582.2 structfile_operations 622.3 字符设备的内核抽象 632.4 设备号的构成与分配 652.4.1 设备号的构成 652.4.2 设备号的分配与管理 662.5 字符设备的注册 712.6 设备文件节点的生成 742.7 字符设备文件的打开操作 772.8 本章小结 85第3章 分配内存 873.1 物理内存的管理 873.1.1 内存节点node 873.1.2 内存区域zone 883.1.3 内存页 893.2 页面分配器(pageallocator) 903.2.1 gfp_mask 913.2.2 alloc_pages 953.2.3 __get_free_pages 963.2.4 get_zeroed_page 973.2.5 __get_dma_pages 973.3 slab分配器(slaballocator) 983.3.1 管理slab的数据结构 993.3.2 kmalloc与kzalloc 1053.3.3 kmem_cache_create与kmem_cache_alloc 1083.4 内存池(mempool) 1103.5 虚拟内存的管理 1113.5.1 内核虚拟地址空间构成 1113.5.2 vmalloc与vfree 1123.5.3 ioremap 1153.6 per-CPU变量 1153.6.1 静态per-CPU变量的声明与定义 1163.6.2 静态per-CPU变量的链接脚本 1173.6.3 setup_per_cpu_areas函数 1183.6.4 使用per-CPU变量 1213.7 本章小结 125第4章 互斥与同步 1274.1 并发的来源 1274.2 local_irq_enable与local_irq_disable 1284.3 自旋锁 1294.3.1 spin_lock 1304.3.2 spin_lock的变体 1334.3.3 单处理器上的spin_lock函数 1364.3.4 读取者与写入者自旋锁rwlock 1374.4 信号量(semaphore) 1414.4.1 信号量的定义与初始化 1414.4.2 DOWN操作 1424.4.3 UP操作 1454.4.4 读取者与写入者信号量rwsem 1464.5 互斥锁mutex 1484.5.1 互斥锁的定义与初始化 1484.5.2 互斥锁的DOWN操作 1494.5.3 互斥锁的UP操作 1504.6 顺序锁seqlock 1524.7 RCU 1554.7.1 读取者的RCU临界区 1564.7.2 写入者的RCU操作 1564.7.3 RCU使用的特点 1574.8 原子变量与位操作 1594.9 等待队列 1624.9.1 等待队列头wait_queue_head_t 1624.9.2 等待队列的节点 1634.9.3 等待队列的应用 1644.10 完成接口completion 1644.11 本章小结 168第5章 中断处理 1695.1 中断的硬件框架 1695.2 PIC与软件中断号 1705.3 通用的中断处理函数 1715.4 do_IRQ函数 1725.5 structirq_chip 1785.6 structirqaction 1795.7 irq_set_handler 1805.8 handle_irq_event 1845.9 request_irq 1865.10 中断处理的irq_thread机制 1905.11 free_irq 1915.12 SOFTIRQ 1925.13 irq的自动探测 1965.14 中断处理例程 2005.15 中断共享 2015.16 本章小结 202第6章 延迟操作 2036.1 tasklet 2036.1.1 tasklet机制初始化 2046.1.2 提交一个tasklet2056.1.3 tasklet_action 2096.1.4 tasklet的其他操作 2126.2 工作队列workqueue 2146.2.1 数据结构 2146.2.2 create_singlethread_workqueue和create_workqueue 2166.2.3 工人线程worker_thread 2196.2.4 destroy_workqueue 2216.2.5 提交工作节点queue_work 2246.2.6 内核创建的工作队列 2296.3 本章小结 230第7章 设备文件的高级操作 2317.1 ioctl文件操作 2317.1.1 ioctl的系统调用 2317.1.2 ioctl的命令编码 2357.1.3 copy_from_user和copy_to_user 2387.2 字符设备的I/O模型 2437.3 同步阻塞型I/O 2447.3.1 wait_event_interruptible 2447.3.2 wake_up_interruptible 2467.4 同步非阻塞型I/O2507.5 异步阻塞型I/O 2517.6 异步非阻塞型I/O2587.7 驱动程序的fsync例程2597.8 fasync例程 2607.9 llseek例程 2697.10 访问权能 2727.11 本章小结 273第8章 时间管理 2748.1 jiffies 2748.1.1 时间比较 2778.1.2 时间转换 2788.2 延时操作 2798.2.1 长延时 2808.2.2 短延时 2858.3 内核定时器 2868.3.1 init_timer 2898.3.2 add_timer 2898.3.3 del_timer和del_timer_sync 2938.4 本章小结 293第9章 Linux设备驱动模型 2959.1 sysfs文件系统 2959.2 kobject和kset 2989.2.1 kobject 2989.2.2 kobject的类型属性 3059.2.3 kset 3089.2.4 热插拔中的uevent和call_usermodehelper 3119.2.5 实例源码 3209.3 总线、设备与驱动 3289.3.1 总线及其注册 3289.3.2 总线的属性 3359.3.3 设备与驱动的绑定 3389.3.4 设备 3399.3.5 驱动 3489.4 class 3519.5 本章小结 355第10章 内存映射与DMA 35610.1 设备缓存与设备内存 35610.2 mmap 35610.2.1 structvm_area_struct 35710.2.2 用户空间虚拟地址布局 35810.2.3 mmap系统调用过程 36210.2.4 驱动程序中mmap方法的实现 36810.2.5 mmap使用范例 37310.2.6 munmap 38310.3 DMA 38410.3.1 内核中的DMA层 38410.3.2 物理地址与总线地址 38610.3.3 dma_set_mask 38710.3.4 DMA映射 38810.3.5 回弹缓冲区(bouncebuffer) 40110.3.6 DMA池 40110.4 本章小结 405第11章 块设备驱动程序 40711.1 块子系统初始化 40811.2 ramdisk源码实例 41011.2.1 make_request版本的RAMDISK源码 41111.2.2 request版本的RAMDISK源码 41611.2.3 ramdisk的使用 42011.3 块设备号的注册与管理 42211.4 block_device 42411.5 structgendisk 42511.6 structhd_struct 42811.7 用alloc_disk分配gendisk对象42811.8 向系统添加一个块设备add_disk 43011.9 block_device_operations 43911.10 块设备文件的打开 44011.11 blk_init_queue 44811.12 blk_queue_make_request 45911.13 向队列提交请求 46011.14 块设备的请求处理函数 46611.15 bio结构 46711.16 本章小结 472第12章 网络设备驱动程序 47312.1 net_device 47512.2 网络设备的注册 48812.3 设备方法 49212.3.1 设备初始化 49412.3.2 设备接口的打开与停止 49512.3.3 数据包的发送 49512.3.4 网络数据包发送过程中的流控机制 50012.3.5 传输超时(watchdogtimeout) 50312.3.6 数据包的接收 50612.4 套接字缓冲区 51012.5 中断处理 51812.6 NAPI 52012.7 本章小结 522
猜您喜欢