• Linux设备驱动开发
图书条目标准图
21年品牌 40万+商家 超1.5亿件商品

Linux设备驱动开发

89.4 6.0折 149 全新

库存28件

河北保定
认证卖家担保交易快速发货售后保障

作者[美]约翰·马德奥 著;李强 译

出版社清华大学出版社

出版时间2022-12

版次1

装帧其他

货号x4

上书时间2024-04-29

尚贤文化江苏分店

已实名 已认证 进店 收藏店铺

   商品详情   

品相描述:全新
图书标准信息
  • 作者 [美]约翰·马德奥 著;李强 译
  • 出版社 清华大学出版社
  • 出版时间 2022-12
  • 版次 1
  • ISBN 9787302619024
  • 定价 149.00元
  • 装帧 其他
  • 开本 16开
  • 纸张 胶版纸
【内容简介】
《Linux设备驱动开发》本书详细阐述了与Linux设备驱动开发相关的基本解决方案,主要包括Linux内核概念、regmap API应用、MFD子系统和syscon API、通用时钟框架、ALSA SoC框架、V4L2和视频采集、集成V4L2异步和媒体控制器框架、V4L2 API、Linux内核电源管理、PCI设备驱动、NVMEM框架、看门狗设备驱动、Linux内核调试技巧和**实践等内容。此外,本书还提供了相应的示例、代码,以帮助读者进一步理解相关方案的实现过程。 本书适合作为高等院校计算机及相关专业的教材和教学参考书,也可作为相关开发人员的自学用书和参考手册。 本书详细阐述了与Linux设备驱动开发相关的基本解决方案,主要包括Linux内核概念、regmap API应用、MFD子系统和syscon API、通用时钟框架、ALSA SoC框架、V4L2和视频采集、集成V4L2异步和媒体控制器框架、V4L2 API、Linux内核电源管理、PCI设备驱动、NVMEM框架、看门狗设备驱动、Linux内核调试技巧和**实践等内容。此外,本书还提供了相应的示例、代码,以帮助读者进一步理解相关方案的实现过程。 本书适合作为高等院校计算机及相关专业的教材和教学参考书,也可作为相关开发人员的自学用书和参考手册。
【作者简介】
约翰·马德奥现居住在法国巴黎,他是一位嵌入式Linux和内核工程师。他的主要工作包括为物联网、自动化、运输、医疗保健、能源和军事等领域的公司开发设备驱动程序和板级支持包(Board Support Package,BSP)。John是LABCSMART公司的创始人兼首席顾问,该公司可为嵌入式Linux和Linux内核工程提供培训和服务。他是一位开源和嵌入式系统爱好者,始终坚信只有分享知识,我们才能学到更多。
【目录】
第1篇  用于嵌入式设备驱动程序开发的内核核心框架

第1章  嵌入式开发人员需要掌握的Linux内核概念 3

1.1  技术要求 3

1.2  内核锁API和共享对象 3

1.2.1  自旋锁 4

1.2.2  禁用中断与仅禁用抢占 8

1.2.3  互斥锁 8

1.2.4  try-lock方法 11

1.3  Linux内核中的等待、感知和阻塞 13

1.3.1  等待活动完成或状态改变 13

1.3.2  Linux内核等待队列 15

1.4  工作延迟机制 19

1.4.1  softIRQ 20

1.4.2  关于ksoftirqd 24

1.4.3  tasklet 25

1.4.4  工作队列 28

1.4.5  内核共享队列 31

1.4.6  新的工作队列 32

1.4.7  并发管理的工作队列 33

1.5  Linux内核中断管理 37

1.5.1  中断的状态 37

1.5.2  中断处理流程 38

1.5.3  设计中断处理程序 40

1.5.4  中断的标志 42

1.5.5  中断的返回值 44

1.5.6  关于中断的一些注意事项 45

1.5.7  上半部和下半部的概念 46

1.5.8  线程中断处理程序 48

1.5.9  请求一个上下文中断 53

1.5.10  使用工作队列延迟下半部 55

1.5.11  从中断处理程序中锁定 58

1.6  小结 61

第2章  regmap API应用 63

2.1  技术要求 63

2.2  regmap及其数据结构 64

2.2.1  struct regmap_config结构体中的字段 65

2.2.2  访问设备寄存器 69

2.2.3  一次读/写多个寄存器 71

2.2.4  更新寄存器中的位 72

2.3  regmap和IRQ管理 73

2.3.1  Linux内核IRQ管理的结构 73

2.3.2  创建映射 74

2.3.3  struct irq_domain_ops 76

2.3.4  irq_domain_ops.map() 77

2.3.5  irq_domain_ops.xlate() 77

2.4  链接IRQ 78

2.4.1  链式中断 78

2.4.2  嵌套中断 83

2.4.3  irqchip和gpiolib API—新一代 85

2.4.4  基于gpiochip的链式IRQ芯片 87

2.4.5  基于gpiochip的嵌套IRQ芯片 89

2.5  regmap IRQ API和数据结构 91

2.5.1  regmap IRQ数据结构 91

2.5.2  regmap IRQ API 95

2.5.3  regmap IRQ API示例 98

2.6  小结 102

第3章  深入研究MFD子系统和syscon API 103

3.1  技术要求 103

3.2  MFD子系统和syscon API 104

3.2.1  da9055设备驱动程序示例 104

3.2.2  max8925设备驱动程序示例 113

3.3  MFD设备的设备树绑定 116

3.4  了解syscon和simple-mfd 119

3.4.1  syscon API 119

3.4.2  simple-mfd 123

3.5  小结 125

第4章  通用时钟框架 127

4.1  技术要求 128

4.2  CCF数据结构和接口 128

4.2.1  了解struct clk_hw及其依赖项 129

4.2.2  注册/取消注册时钟提供者 131

4.2.3  将时钟公开给使用者 135

4.2.4  时钟提供者设备树节点及其相关机制 136

4.2.5  了解of_parse_phandle_with_args() API 138

4.2.6  了解__of_clk_get_from_provider() API 140

4.2.7  时钟解码回调 141

4.3  编写时钟提供者驱动程序 145

4.3.1  有关时钟提供者驱动程序的基础知识 145

4.3.2  提供时钟操作 149

4.3.3  clk_hw.init.flags中的时钟标志 152

4.3.4  固定频率时钟案例研究及其操作 154

4.3.5  通用简化注意事项 156

4.3.6  固定频率时钟设备绑定 158

4.3.7  PWM时钟 159

4.3.8  固定倍频时钟驱动程序及其操作 160

4.3.9  固定倍频时钟的设备树绑定 162

4.3.10  门控时钟及其操作 162

4.3.11  基于I2C/SPI的门控时钟 164

4.3.12  GPIO门控时钟 165

4.3.13  多选一时钟及其操作 165

4.3.14  基于I2C/SPI的多选一时钟 170

4.3.15  GPIO多选一时钟 170

4.3.16  分频器时钟及其操作 172

4.3.17  复合时钟及其操作 176

4.3.18  综合概述 177

4.4  时钟使用者API 179

4.4.1  获取和释放时钟 180

4.4.2  准备/取消准备时钟 180

4.4.3  启用/禁用 181

4.4.4  频率函数 181

4.4.5  父函数 182

4.4.6  综合概述 182

4.5  小结 182

第2篇  嵌入式Linux系统中的多媒体和节能

第5章  ALSA SoC框架—利用编解码器和平台类驱动程序 185

5.1  技术要求 186

5.2  ASoC简介 186

5.2.1  ASoC数字音频接口 187

5.2.2  ASoC子元素 187

5.3  编写编解码器类驱动程序 189

5.3.1  编解码器驱动程序的实例结构 190

5.3.2  编解码器DAI和PCM配置 192

5.3.3  DAI操作 193

5.3.4  采集和回放硬件配置 196

5.3.5  控件的概念 197

5.3.6  控件命名约定 199

5.3.7  控制元数据 200

5.3.8  定义kcontrol 200

5.3.9  设置一个简单开关 202

5.3.10  设置带有音量级别的开关 203

5.3.11  立体声控件 203

5.3.12 带音量级别的立体声控件 203

5.3.13  混音器控件 204

5.3.14  定义有多个输入的控件 204

5.4  DAPM概念 205

5.4.1  关于widget 205

5.4.2  定义widget 207

5.4.3  编解码域定义 207

5.4.4  定义平台域widget 208

5.4.5  定义音频路径域widget 209

5.4.6  定义音频流域 211

5.4.7  路径的概念—widget之间的连接器 213

5.4.8  路由的概念—widget互连 214

5.4.9  定义DAPM kcontrol 215

5.4.10  创建widget和路由 217

5.5  编解码器组件注册 222

5.6  编写平台类驱动程序 224

5.6.1  CPU DAI驱动程序 225

5.6.2  平台DMA驱动程序 226

5.6.3  音频DMA接口 227

5.6.4  PCM硬件配置 230

5.7  小结 233

第6章  ALSA SoC框架—深入了解机器类驱动程序 235

6.1  技术要求 235

6.2  机器类驱动程序介绍 236

6.2.1  机器类驱动程序的开发流程 236

6.2.2  DAI链接 237

6.2.3  获取CPU和编解码器节点 239

6.3  机器路由 241

6.3.1  编解码器引脚 241

6.3.2  板卡接口 242

6.3.3  机器路由 243

6.3.4  设备树路由 243

6.3.5  静态路由 244

6.4  时钟和格式注意事项 245

6.4.1  时钟和格式设置辅助函数 245

6.4.2  格式 246

6.4.3  时钟源 247

6.4.4  时钟分频器 247

6.4.5  时钟和格式设置的典型实现 247

6.5  声卡注册 249

6.6  利用simple-card机器驱动程序 252

6.6.1  simple-audio机器驱动程序 252

6.6.2  无编解码器声卡 253

6.7  小结 254

第7章  V4L2和视频采集设备驱动程序揭秘 255

7.1  技术要求 255

7.2  框架架构和主要数据结构 255

7.2.1  V4L2架构简介 256

7.2.2  初始化和注册V4L2设备 257

7.3  桥接视频设备驱动程序 258

7.3.1  struct video_device结构体 259

7.3.2  初始化和注册视频设备 262

7.3.3  视频设备文件操作 264

7.3.4  V4L2 ioctl处理 267

7.3.5  videobuf2接口和API 269

7.3.6  缓冲区的概念 269

7.3.7  平面的概念 271

7.3.8  队列的概念 272

7.3.9  与特定驱动程序相关的流传输回调函数 274

7.3.10  初始化和释放vb2队列 277

7.4  关于子设备 278

7.4.1  子设备数据结构体 279

7.4.2  子设备初始化 282

7.4.3  子设备操作 284

7.4.4  核心操作结构 285

7.4.5  视频操作结构 286

7.4.6  传感器操作结构 287

7.4.7  调用子设备操作 288

7.4.8  子设备的注册和注销方式 289

7.5  V4L2控件基础结构 290

7.5.1  标准控件对象 290

7.5.2  控件处理程序 292

7.5.3  摄像头传感器驱动程序示例 294

7.5.4  关于控件继承 297

7.6  小结 297

第8章  集成V4L2异步和媒体控制器框架 299

8.1  技术要求 299

8.2  V4L2异步接口和图绑定的概念 299

8.2.1  图绑定 300

8.2.2  端口和端点表示 300

8.2.3  端点链接 301

8.2.4  V4L2异步和面向图的API 302

8.2.5  从设备树API到通用fwnode图API 302

8.2.6  V4L2固件节点API 309

8.2.7  V4L2 fwnode或媒体总线类型 311

8.2.8  BT656和并行总线 312

8.2.9  MIPI CSI-2总线 313

8.2.10  CPP2和MIPI CSI-1总线 314

8.2.11  总线猜测 315

8.2.12  V4L2异步模式 315

8.2.13  异步模式工作原理 318

8.2.14  异步桥接和子设备探测示例 321

8.3  Linux媒体控制器框架 325

8.3.1  媒体控制器抽象模型 325

8.3.2  V4L2设备抽象 327

8.3.3  媒体控制器数据结构 328

8.3.4  在驱动程序中集成媒体控制器支持 333

8.3.5  初始化并注册接口和实体 334

8.3.6  媒体实体操作 335

8.3.7  媒体总线的概念 335

8.3.8  注册媒体设备 340

8.3.9  来自用户空间的媒体控制器 341

8.3.10  使用media-ctl 341

8.3.11  带有OV2680的WaRP7示例 344

8.4  小结 351

第9章  从用户空间利用V4L2 API 353

9.1  技术要求 353

9.2  从用户空间看V4L2 353

9.2.1  V4L2用户空间API 353

9.2.2  常用ioctl命令 354

9.2.3  在用户空间中使用V4L2 API的示例 356

9.3  视频设备打开和属性管理 357

9.3.1  打开和关闭设备 357

9.3.2  查询设备功能 357

9.4  缓冲区管理 359

9.4.1  图像(缓冲区)格式 360

9.4.2  请求缓冲区 364

9.4.3  请求用户指针缓冲区 364

9.4.4  请求内存可映射缓冲区 366

9.4.5  请求DMABUF缓冲区 367

9.4.6  请求读/写I/O内存 369

9.4.7  将缓冲区加入队列并启用流传输 369

9.4.8  主缓冲区的概念 370

9.4.9  将用户指针缓冲区加入队列 370

9.4.10  将内存可映射缓冲区加入队列 371

9.4.11  将DMABUF缓冲区加入队列 371

9.4.12  启用流传输 372

9.4.13  将缓冲区移出队列 373

9.4.14  将内存映射缓冲区移出队列 373

9.4.15  将用户指针缓冲区移出队列 375

9.4.16  读/写I/O 376

9.5  V4L2用户空间工具 376

9.5.1  关于v4l2-ctl 376

9.5.2  列出视频设备及其功能 377

9.5.3  更改设备属性 377

9.5.4  设置像素格式、分辨率和帧速率 379

9.5.5  采集帧和流传输 380

9.6  在用户空间中调试V4L2 382

9.6.1  启用框架调试 382

9.6.2  V4L2合规性驱动程序测试 384

9.7  小结 385

第10章  Linux内核电源管理 387

10.1  技术要求 387

10.2  基于Linux系统的电源管理概念 388

10.2.1  运行时电源管理 389

10.2.2  动态电源管理接口 389

10.3  主要电源管理框架详解 389

10.3.1  CPU Idle框架 389

10.3.2  CPUFreq框架 392

10.3.3  Thermal框架 394

10.4  系统电源管理休眠状态 395

10.4.1  挂起到空闲 395

10.4.2  通电待机 396

10.4.3  挂起到内存 396

10.4.4  挂起到磁盘 397

10.5  为设备驱动程序添加电源管理功能 399

10.5.1  设备和电源管理操作数据结构 399

10.5.2  实现运行时电源管理功能 401

10.5.3  驱动程序中的运行时电源管理 402

10.5.4  运行时电源管理的同步和异步操作 404

10.5.5  自动挂起 404

10.6  综合应用 405

10.6.1  probe函数中的电源管理机制 405

10.6.2  读取函数中的电源管理调用 407

10.6.3  卸载模块时的电源管理方法 409

10.6.4  运行时电源管理回调函数执行的一般规则 410

10.6.5  电源域的概念 410

10.7  系统挂起和恢复顺序 411

10.7.1  挂起阶段 411

10.7.2  恢复阶段 412

10.7.3  实现系统休眠功能 412

10.8  系统唤醒源 415

10.8.1  唤醒源的数据结构 415

10.8.2  使设备成为唤醒源 417

10.8.3  唤醒功能激活实例 418

10.8.4  IRQ处理程序 419

10.8.5  唤醒源和sysfs 421

10.8.6  关于IRQF_NO_SUSPEND标志 422

10.9  小结 422

第3篇  与其他Linux内核子系统保持同步

第11章  编写PCI设备驱动程序 425

11.1  技术要求 425

11.2  PCI总线和接口介绍 426

11.2.1  术语 427

11.2.2  PCI总线枚举、设备配置和寻址 428

11.2.3  设备识别 428

11.2.4  总线枚举 428

11.3  PCI地址空间 432

11.3.1  PCI配置空间 432

11.3.2  PCI I/O地址空间 433

11.3.3  PCI内存地址空间 433

11.4  BAR的概念 433

11.5  中断分配 434

11.5.1  PCI传统INT-X中断 434

11.5.2  基于消息的中断类型 435

11.5.3  MSI机制 436

11.5.4  MSI-X机制 437

11.5.5  传统INTx模拟 437

11.6  Linux Kernel PCI子系统 438

11.7  PCI数据结构 439

11.7.1  实例化PCI设备的结构体 439

11.7.2  用于识别PCI设备的结构体 441

11.7.3  实例化PCI设备驱动程序的结构体 443

11.7.4  注册PCI驱动程序 444

11.8  PCI驱动程序结构体概述 445

11.8.1  启用设备 445

11.8.2  总线控制能力 446

11.8.3  访问配置寄存器 447

11.8.4  访问内存映射I/O资源 448

11.8.5  访问I/O端口资源 451

11.8.6  处理中断 453

11.8.7  传统INTx IRQ分配 455

11.8.8  模拟INTx IRQ调和 457

11.8.9  关于锁定的注意事项 457

11.8.10  关于传统API的简要说明 457

11.9  PCI和直接内存访问 458

11.9.1  关于DMA缓冲区 459

11.9.2  PCI一致DMA映射 460

11.9.3  流式DMA映射 462

11.9.4  单缓冲区映射 462

11.9.5  分散/聚集映射 464

11.10  小结 466

第12章  利用NVMEM框架 467

12.1  技术要求 467

12.2  NVMEM数据结构和API 468

12.2.1  NVMEM硬件抽象数据结构 468

12.2.2  NVMEM设备的运行时配置数据结构 468

12.2.3  NVMEM数据单元的数据结构 470

12.3  编写NVMEM提供者驱动程序 472

12.3.1  NVMEM设备的注册和注销 472

12.3.2  实时时钟设备中的NVMEM存储器 473

12.3.3  DS1307实时时钟驱动程序示例 474

12.3.4  实现NVMEM读/写回调函数 475

12.3.5  NVMEM提供者的设备树绑定 476

12.4  NVMEM使用者驱动程序API 477

12.4.1  NVMEM使用者API 477

12.4.2  用户空间中的NVMEM 478

12.5  小结 480

第13章  看门狗设备驱动程序 481

13.1  技术要求 481

13.2  看门狗数据结构和API 481

13.2.1  表示看门狗设备的结构体 482

13.2.2  表示看门狗信息的结构体 483

13.2.3  表示看门狗操作的结构体 485

13.2.4  注册/注销看门狗设备 486

13.2.5  处理预超时和调控器 488

13.2.6  基于GPIO的看门狗 489

13.3  看门狗用户空间接口 491

13.3.1  启动和停止看门狗 491

13.3.2  发送保持活动的ping 492

13.3.3  获取看门狗的功能和ID 493

13.3.4  设置和获取超时和预超时 493

13.3.5  获取剩余的时间 494

13.3.6  获取(启动/重启)状态 494

13.3.7  看门狗sysfs接口 496

13.3.8  处理预超时事件 497

13.4  小结 497

第14章  Linux内核调试技巧和最佳实践 499

14.1  技术要求 499

14.2  了解Linux内核发布流程 499

14.3  Linux内核开发技巧 501

14.3.1  消息打印 502

14.3.2  内核日志级别 502

14.3.3  内核日志缓冲区 504

14.3.4  添加计时信息 505

14.4  Linux内核跟踪和性能分析 506

14.4.1  使用Ftrace检测代码 506

14.4.2  可用的tracer 508

14.4.3  function tracer 509

14.4.4  function_graph tracer 510

14.4.5  函数过滤器 512

14.4.6  跟踪事件 513

14.4.7  使用Ftrace接口跟踪特定进程 515

14.5  Linux内核调试技巧 516

14.5.1  oops和恐慌分析 516

14.5.2  转储oops跟踪消息 519

14.5.3  使用objdump识别内核模块中的错误代码行 520

14.6  小结 521

 
点击展开 点击收起

—  没有更多了  —

以下为对购买帮助不大的评价

此功能需要访问孔网APP才能使用
暂时不用
打开孔网APP