深入理解嵌入式Linux设备驱动程序
2020-04-17 11:03:41 0 举报
AI智能生成
深入理解嵌入式Linux设备驱动程序
作者其他创作
大纲/内容
深入理解嵌入式Linux设备驱动程序
9 嵌入式Linux LCD屏驱动程序设计
9.1 LCD屏的工作原理概述
9.2 LCD屏硬件原理及驱动程序设计
9.2.1 TFT LCD屏的显示原理
9.2.2 S3C2440 LCD控制器TFT LCD的控制时序分析
9.2.3 S3C2440 LCD控制器显示的数据格式
9.2.4 S3C2440 LCD控制器的显示数据流程
9.2.5 VBPD、VFPD、VSPW和HBPD、HFPD、HSPW的设置
9.3 嵌入式Linux LCD屏驱动程序框架
9.4 嵌入式Linux LCD屏驱动源码分析
9.4.1 S3c2410fb.c源码分析
9.4.2 LCD屏Linux驱动主要数据结构
9.4.3 Probe函数处理流程及源码分析
9.4.4 Fbmem.c源码分析
9.5 嵌入式Linux LCD屏驱动的移植
10 嵌入式Linux触摸屏驱动程序设计
10.1 触摸屏工作原理概述
10.2 S3C2440触摸屏接口及硬件驱动程序设计
10.2.1 S3C2440触摸屏控制器接口
10.2.2 S3C2440裸机下触摸屏控制器的接口编程
10.3 嵌入式Linux触摸屏驱动程序框架
10.4 嵌入式Linux触摸屏驱动的源码分析
10.4.1 Linux触摸设备驱动的处理流程
10.4.2 触摸屏驱动模块的初始化函数s3c2410ts_init
10.4.3 笔针按下中断服务处理程序stylus_updown
10.5 嵌入式Linux输入子系统的工作原理及实现机制
10.5.1 Linux输入子系统的主要数据结构与全局变量
10.5.2 输入设备的注册流程
10.5.3 事件处理器的注册流程
10.5.4 输入事件的报告流程
10.5.5 应用程序访问输入设备的流程
11 嵌入式Linux MTD子系统与FLASH驱动程序设计
11.1 MTD子系统概述
11.2 Linux中Nor FLASH驱动的源码分析
11.3 MTD子系统的源码分析
11.3.1 MTD子系统源码组织
11.3.2 MTD子系统主要数据的结构分析
11.4 Nor FLASH芯片手册解读
12 嵌入式Linux Nand FLASH驱动程序设计
12.1 Nand FLASH芯片硬件及接口介绍
12.1.1 Nand FLASH存储空间的组织
12.1.2 Nand FLASH的硬件接口及读写操作时序
12.1.3 S3C2440对Nand FLASH芯片的访问
12.2 嵌入式Linux下Nand FLASH驱动分析
12.2.1 Nand FLASH驱动源码组织
12.2.2 Nand FLASH驱动架构
12.2.3 Nand FLASH相关操作流程
12.2.4 s3c24xx_nand_probe函数分析
12.3 应用程序对Nand FLASH设备的读/写操作
12.3.1 MTD字符设备写Nand FLASH的操作分析
12.3.2 s3c2440_nand_hwcontrol函数
12.3.3 nand_command函数
13 嵌入式Linux I^2C总线驱动程序设计
13.1 I^2C总线概述
13.2 S3C2440 I^2C总线控制器的硬件工作原理
13.3 S3C2440 I^2C控制器的硬件编程
13.3.1 初始化S3C2440 I^2C主控制器
13.3.2 I^2C总线写AT24C02操作
13.3.3 I^2C总线读AT24C02操作
13.4 嵌入式Linux I^2C总线驱动架构
13.4.1 I^2C体系架构的硬件实体
13.4.2 I^2C驱动的软件实体
13.5 嵌入式Linux I^2C总线驱动源码的组织
13.6 嵌入式Linux I^2C总线控制器驱动的程序设计及源码分析
13.6.1 I^2C总线控制器驱动的主要数据结构
13.6.2 写AT24C02一个字节操作
13.6.3 I^2C总线驱动框架
13.6.4 I^2C总线控制器设备驱动探测函数probe的工作流程
13.6.5 i2c_add_adapter处理流程分析
13.6.6 定义和实现I^2C适配器的底层操作接口Algorithm
13.7 嵌入式Linux I^2C设备驱动程序的设计及源码分析
13.7.1 I^2C设备驱动程序框架
13.7.2 i2c_add_driver函数
13.7.3 at24c02b_probe函数
13.8 应用程序通过I^2C设备驱动写AT24C02一个字节的流程
14 嵌入式Linux网卡驱动程序设计
14.1 概述
14.2 DM9000网络芯片与S3C2440的硬件原理图
14.3 DM9000A网卡芯片内部寄存器的访问
14.4 DM9000数据发送/接收的流程
14.5 嵌入式Linux DM9000网卡驱动的框架及源码分析
14.5.1 DM9000设备
14.5.2 DM9000设备驱动
14.5.3 DM9000平台设备驱动的工作流程
14.5.4 应用层网络应用程序的操作
15 嵌入式Linux USB设备驱动程序设计
15.1 USB通信系统概述
15.2 USB通信系统的拓扑结构图
15.3 USB通信的分时复用技术
15.4 USB通信系统的基本概念
15.5 USB通信的数据格式
15.5.1 域
15.5.2 包
15.5.3 事务
15.5.4 传输
15.5.5 USB标识域(PID)
15.6 USB设备的枚举过程
15.7 USB设备端USB通信固件的程序设计
15.7.1 USB芯片CY7C68013概述
15.7.2 EZ-USB固件程序的启动模式
15.7.3 EZ-USB芯片的中断系统
15.7.4 USB固件程序的功能
15.7.5 USB固件程序的框架及源码分析
15.8 嵌入式Linux USB驱动程序框架
15.9 嵌入式Linux USB主控制器驱动的源码分析
15.9.1 S3C2440 USB主控制器平台设备驱动的源码分析
15.9.2 USB主机驱动枚举USB设备的过程
15.10 嵌入式Linux USB设备驱动的程序设计方法
1 嵌入式ARM系统开发基础
1.1 嵌入式ARM系统开发概述
1.1.1 ARM系统可执行映像文件格式
1.1.2 ARM开发调试工具
1.1.3 加载地址和运行地址
1.2 嵌入式ARM系统的启动代码分析
1.2.1 ARM上电启动概述
1.2.2 ARM上电初始化启动代码分析
1.3 嵌入式ARM系统的中断系统
1.3.1 ARM中断机制代码分析
1.3.2 ARM中断服务处理程序的响应过程
1.4 按键中断实验
2 嵌入式Linux设备驱动程序开发环境的构建
2.1 安装虚拟机软件VMware 6.0.2
2.2 新建虚拟机
2.3 安装Linux操作系统ubuntu
2.4 安装VMware tools工具软件
2.5 网络配置
2.6 设置软件源服务器
2.7 安装libncurses5-dev软件包
2.8 安装交叉编译器arm-linux-gcc
3 嵌入式Linux内核的裁剪与编译
3.1 嵌入式Linux内核的本质
3.2 嵌入式Linux内核源码的组织
3.3 嵌入式Linux内核的移植与裁剪
3.4 嵌入式Linux内核配置、编译的基本原理
3.5 构建嵌入式Linux根文件系统
4 嵌入式系统BootLoader代码分析与移植
4.1 嵌入式系统BootLoader功能概述
4.1.1 嵌入式Linux系统的软件组成及分布
4.1.2 嵌入式Linux中为什么要有BootLoader
4.1.3 BootLoader的功能和选择
4.2 u-boot源码分析
4.2.1 u-boot源码文件的组成及配置编译
4.2.2 u-boot的执行过程及Linux内核加载流程
4.2.3 start.s源码文件分析
4.2.4 board.c源码文件分析
4.3 u-boot中的环境变量
4.4 Linux系统的加载过程
4.4.1 u-boot命令执行过程
4.4.2 bootm的执行流程
4.5 u-boot向Linux传递参数的过程
4.6 u-boot的移植
5 嵌入式Linux内核模块与字符设备驱动
5.1 嵌入式Linux内核模块
5.1.1 嵌入式Linux内核模块的概念
5.1.2 嵌入式Linux内核模块编程
5.1.3 嵌入式Linux内核模块的编译
5.1.4 嵌入式Linux内核模块的安装与卸载
5.1.5 直接编译嵌入式Linux内核模块到内核
5.2 嵌入式Linux字符设备驱动
5.2.1 嵌入式Linux设备驱动程序的概念
5.2.2 嵌入式Linux设备管理机制
5.2.3 嵌入式Linux字符设备驱动程序的主要数据结构分析
5.2.4 嵌入式Linux字符设备驱动的工作原理
5.2.5 嵌入式Linux字符设备驱动程序设计实例
6 嵌入式Linux系统的内存管理
6.1 虚拟地址和物理地址概述
6.2 虚拟地址到物理地址转换的基本原理
6.3 基于ARM S3C2440的GPIO端口地址映射实验
6.3.1 问题描述
6.3.2 分析与思路
6.4 Linux内核中内存分配和释放函数的用法
7 嵌入式Linux设备驱动开发的核心技术
7.1 嵌入式Linux中断处理和定时器
7.1.1 嵌入式Linux系统中断服务程序的编写
7.1.2 嵌入式Linux系统硬件定时器的使用
7.1.3 中断的下半部分
7.1.4 嵌入式Linux软件定时器的使用
7.2 嵌入式Linux设备驱动程序中的并发及并发控制
7.2.1 并发的概念
7.2.2 嵌入式Linux设备驱动程序中的并发控制方式
7.2.3 信号量与自旋锁的使用场景
7.3 嵌入式Linux设备驱动中的阻塞与非阻塞
7.3.1 概述
7.3.2 Linux设备驱动程序中阻塞的工作原理
7.3.3 进程阻塞访问设备的基本原理
7.3.4 Linux设备驱动程序中的阻塞编程
7.4 嵌入式Linux设备驱动中的异步通知编程
7.4.1 概述
7.4.2 Linux异步通知工作原理
7.4.3 Linux异步通知应用的编程方法
7.4.4 Linux异步通知驱动的编程方法
7.5 嵌入式Linux设备驱动中的轮询操作
7.5.1 概述
7.5.2 Linux设备驱动轮询操作的工作原理及源码分析
7.5.3 Linux轮询操作的应用层编程
7.5.4 Linux轮询操作的驱动层编程
8 嵌入式Linux平台设备驱动程序开发
8.1 Linux设备和设备驱动模型
8.1.1 Linux内核中的BUS(总线)
8.1.2 Linux内核中的设备
8.1.3 Linux内核中的设备驱动
8.2 Linux平台设备驱动程序开发过程
8.3 嵌入式Linux系统中利用mdev自动创建设备文件节点
0 条评论
回复 删除
下一页