《嵌入式Linux网络体系结构设计与TCP/IP协议栈》PDF下载

  • 购买积分:15 如何计算积分?
  • 作  者:单立平编著
  • 出 版 社:北京:电子工业出版社
  • 出版年份:2011
  • ISBN:9787121129766
  • 页数:462 页
图书介绍:本书共分12章,第1章概述Linux内核组件与内核技术特点。第2~5章在介绍了实现网络体系结构、协议栈、设备驱动程序的两个最重要的数据结构sk_buff和net_device。第6章讨论了网络协议栈中数据链路层收发数据的设计和实现。第7章讲解了网络层IP协议的实现。第8~9章介绍传输层数据收发过程。第10章讨论了Linux内核套接字层的实现。第11章介绍网络应用软件的开发技术。第12章讲解在嵌入式系统开发中如何将硬件驱动程序、内核代码、应用程序集成在一起下载至芯片中。

第1章 概述 1

1.1 Linux内核组件 1

1.2 Linux内核中的活动 3

1.2.1 进程和系统调用 3

1.2.2 硬件中断 4

1.2.3 tasklet 6

1.2.4 workqueue 6

1.2.5 软件中断 7

1.3 互斥机制 7

1.3.1 spin lock 8

1.3.2 读—写spin lock 10

1.3.3 读—复制—更新(Read-Copy-Update,RCU) 10

1.4 内核模块(module) 11

1.4.1 管理内核模块 11

1.4.2 自动装载模块 12

1.4.3 模块功能的注册和取消 13

1.4.4 在模块装载时给模块传递参数 14

1.4.5 内核和模块的符号表 14

1.5 内存资源 15

1.5.1 高速缓冲区(memory cache) 15

1.5.2 高速缓存和哈希链表 16

1.6 时间管理 16

1.7 嵌入式的挑战 17

1.8 本章总结 18

第2章 Linux网络包传输的关键数据结构——Socket Buffer 19

2.1 Socket Buffer设计概述 19

2.1.1 Socket Buffer与TCP/IP协议栈 19

2.1.2 Socket Buffer的对外接口 20

2.1.3 Socket Buffer的特点 20

2.2 Socket Buffer的构成 20

2.2.1 Socket Buffer的基本组成 21

2.2.2 Socket Buffer穿越TCP/IP协议栈 22

2.3 sk_buff数据域的设计和含义 24

2.3.1 sk_buff中的结构管理域 24

2.3.2 常规数据域 27

2.3.3 sk_buff的网络功能配置域 32

2.4 操作sk_buff的函数 34

2.4.1 创建和释放Socket Buffer 35

2.4.2 数据空间的预留和对齐 40

2.4.3 复制和克隆 41

2.4.4 操作队列的函数 43

2.4.5 引用计数的操作 44

2.4.6 协议头指针操作 44

2.5 数据分片和分段 45

2.5.1 为什么要分割数据包 45

2.5.2 设计skb_shared_info数据结构的目的 46

2.5.3 操作skb_shared_info的函数 46

2.6 本章总结 47

第3章 网络设备在内核中的抽象——struct net_device数据结构 48

3.1 协议栈与网络设备 49

3.1.1 协议栈软件与网络设备硬件之间的接口 49

3.1.2 设备独立接口文件dev.c 50

3.1.3 设备驱动程序 51

3.1.4 struct net_device数据结构 51

3.2 struct net_device数据结构 52

3.2.1 struct net_device数据结构的数据域 52

3.2.2 struct net_device数据结构的其他数据域 56

3.3 struct net_device数据结构中数据域的功能分类 63

3.3.1 设备管理域 64

3.3.2 设备配置管理域 64

3.3.3 设备状态 65

3.3.4 统计 65

3.3.5 设备链表 66

3.3.6 链路层组传送 66

3.3.7 流量管理 66

3.3.8 常规域 69

3.3.9 操作函数结构 69

3.4 函数指针 69

3.4.1 设备初始化 70

3.4.2 传送 71

3.4.3 硬件协议头 71

3.4.4 网络统计状态 73

3.4.5 修改配置 73

3.5 本章总结 74

第4章 网络设备在Linux内核中识别 75

4.1 内核初始化的特点 76

4.1.1 命令行参数 76

4.1.2 网络子系统的命令行参数 78

4.2 内核启动过程 80

4.2.1 用do_initcall函数完成的初始化 83

4.2.2 标记初始化函数的宏 84

4.2.3 网络子系统初始化 85

4.2.4 网络设备的初始化 86

4.3 网络设备的注册和struct net_device数据结构实例的初始化 88

4.3.1 初始化函数的任务 88

4.3.2 网络设备的注册和注销 92

4.3.3 网络设备的引用计数(reference count) 97

4.3.4 允许和禁止网络设备 98

4.4 网络设备的管理 99

4.4.1 管理网络设备的链表 99

4.4.2 网络设备的搜索函数 101

4.5 事件通知链 102

4.5.1 事件通知链构成 103

4.5.2 注册回调函数到事件通知链 104

4.5.3 通知子系统有事件发生 106

4.5.4 网络子系统中的事件通知链 107

4.5.5 网络子系统传送的事件 108

4.6 本章总结 108

第5章 网络设备驱动程序 109

5.1 网络设备驱动程序概述 109

5.1.1 网络设备驱动程序的任务 110

5.1.2 网络设备驱动程序的构成 110

5.2 网络设备与内核的交互 113

5.2.1 设备与内核的交互方式 113

5.2.2 硬件中断 115

5.2.3 中断在内核的实现 117

5.2.4 软件中断 120

5.3 网络设备驱动程序的实现 127

5.3.1 网络适配器的初始化 127

5.3.2 网络设备活动功能函数 132

5.3.3 网络设备管理函数 143

5.3.4 在适配器中支持组发送 145

5.4 CS8900A网络适配器驱动程序的实现 149

5.4.1 CS8900A网络控制芯片的功能概述 149

5.4.2 CS8900A的PacketPage结构 151

5.4.3 CS8900A的操作 153

5.4.4 CS8900A设备驱动程序分析 157

5.5 本章总结 167

第6章 数据链路层数据帧的收发 168

6.1 关键数据结构 170

6.1.1 struct napi_struct数据结构 170

6.1.2 struct softnet_data数据结构 171

6.2 数据帧的接收处理 173

6.2.1 NAPI的实现 174

6.2.2 netif_rx函数分析 178

6.3 网络接收软件中断 182

6.3.1 net_rx_action的工作流程 182

6.3.2 net_rx_action函数的实现细节 183

6.3.3 从输入队列中读取数据帧 185

6.3.4 处理输入数据帧 186

6.4 数据链路层与网络层的接口 190

6.4.1 输入数据帧协议解析 190

6.4.2 实现数据链路层与网络层接口的关键数据结构 192

6.4.3 接口的组织 194

6.5 数据链路层对数据帧发送的处理 196

6.5.1 启动/停止设备发送数据 197

6.5.2 调度设备发送数据帧 198

6.5.3 队列策略接口 200

6.5.4 dev_queue_xmit函数 203

6.5.5 发送软件中断 206

6.5.6 Watchdog时钟 209

6.6 本章总结 211

第7章 网络层传送 212

7.1 Internet协议的基本概念 213

7.1.1 Internet协议的任务 213

7.1.2 Internet协议头 214

7.1.3 Linux内核中描述IP协议头的数据结构 217

7.2 IP协议实现前的准备工作 217

7.2.1 协议初始化 217

7.2.2 与网络过滤子系统的交互 219

7.2.3 与路由子系统的交互 220

7.3 输入数据包在IP层的处理 220

7.3.1 ip_rcv函数分析 221

7.3.2 ip_rcv_finish函数分析 224

7.3.3 接收操作中IP选项的处理 226

7.4 IP选项 228

7.4.1 IP选项的格式 228

7.4.2 描述IP选项的数据结构 234

7.4.3 Linux内核对IP选项的处理 235

7.4.4 Linux内核对IP选项处理的具体实现 237

7.5 IPv4数据包的前送和本地发送 245

7.5.1 数据包的前送 245

7.5.2 dst_output函数的实现 249

7.5.3 本地发送的处理 250

7.6 在IP层的发送 254

7.6.1 执行发送的关键函数 255

7.6.2 发送数据包相关信息的数据结构 256

7.6.3 ip_queue_xmit函数 260

7.6.4 ip_append_data函数预备 264

7.6.5 ip_append_data函数分析 274

7.6.6 ip_append_page函数 279

7.6.7 ip_push_pending_frames函数 280

7.6.8 发送数据包的整体过程 282

7.7 与相邻子系统的接口 284

7.8 数据包的分片与重组 286

7.8.1 数据分片需要考虑的问题 287

7.8.2 在上层分片的效率 287

7.8.3 数据包分片/重组使用的IP协议头数据域 287

7.9 本章总结 288

第8章 传输层UDP协议的实现 289

8.1 UDP协议基础 289

8.2 UDP协议实现的关键数据结构 290

8.2.1 UDP协议头的数据结构 290

8.2.2 UDP的控制缓冲区 290

8.2.3 UDP套接字的数据结构 291

8.2.4 应用程序发送给UDP负载数据的数据结构 291

8.3 UDP、套接字层、IP层之间的接口 292

8.3.1 UDP协议实例与套接字层间的接口 292

8.3.2 UDP协议与IP层之间的接口 293

8.4 发送UDP数据报的实现 294

8.4.1 初始化一个连接 294

8.4.2 在UDP套接字上发送数据包 297

8.4.3 向IP层发送数据包 301

8.4.4 从用户地址空间复制数据到数据报 304

8.5 UDP协议接收的实现 305

8.5.1 UDP协议接收的处理函数 305

8.5.2 将数据包放入套接字接收队列的处理函数 307

8.5.3 UDP协议接收广播与组发送数据包 308

8.5.4 UDP的哈希链表 309

8.5.5 将数据包放到套接字接收队列 312

8.6 UDP协议在套接字层的接收处理 313

8.6.1 函数输入参数 313

8.6.2 函数处理流程 313

8.7 本章总结 315

第9章 传输层TCP协议的实现 316

9.1 CP协议简介 316

9.1.1 CP是可靠协议 316

9.1.2 TCP是面向连接的协议 318

9.1.3 TCP是按字节流交换的协议 319

9.1.4 TCP协议实现的功能 320

9.2 描述TCP协议实现的关键数据结构 320

9.2.1 TCP协议头数据结构 320

9.2.2 TCP的控制缓冲区 321

9.2.3 TCP套接字的数据结构 322

9.2.4 TCP协议选项Options 323

9.2.5 应用层传送给传输层信息的数据结构 325

9.3 在TCP协议、套接字、IP层之间的接口 326

9.3.1 管理套接字与TCP接口的数据结构 326

9.3.2 初始化套接字与传输层之间的接口 327

9.3.3 TCP与IP层之间的接收接口 328

9.3.4 TCP与IP层之间的发送接口 329

9.3.5 初始化TCP套接字 331

9.4 TCP协议实例接收过程的实现 332

9.4.1 tcp_v4_rcv函数的实现 333

9.4.2 Fast Path和prequeue队列的处理 338

9.4.3 处理TCP的Blocklog队列 340

9.4.4 套接字层的接收函数 342

9.5 Linux内核中TCP发送功能的实现 348

9.5.1 将数据从用户地址空间复制到内核SocketBuffer 349

9.5.2 TCP数据段输出 354

9.5.3 发送过程的状态机 358

9.6 TCP套接字的连接管理 358

9.6.1 TCP连接初始化 361

9.6.2 TCP状态从CLOSED切换到SYN_SENT 362

9.6.3 TCP连接的状态管理 365

9.6.4 TCP连接为ESTABLISHED状态时的接收处理 370

9.6.5 TCP的TIME_WAIT状态处理 374

9.7 本章总结 379

第10章 套接字层实现 380

10.1 套接字概述 380

10.1.1 什么是套接字 381

10.1.2 套接字与管理套接字的数据结构 383

10.1.3 套接字与文件 390

10.2 套接字层的初始化 391

10.3 地址族的值和协议交换表 392

10.3.1 协议交换表的数据结构 392

10.3.2 套接字支持多协议栈的实现 393

10.4 IPv4中协议成员注册和初始化 396

10.5 套接字API系统调用的实现 397

10.5.1 系统调用简述 397

10.5.2 套接字API系统调用的实现 398

10.6 创建套接字 403

10.6.1 sock_create函数创建套接字 404

10.6.2 协议族套接字创建函数的管理 406

10.6.3 AF_INET套接字的创建 407

10.7 I/O系统调用和套接字 408

10.8 本章总结 409

第11章 应用层——网络应用套接字编程 411

11.1 套接字描述符 413

11.1.1 family参数 413

11.1.2 type参数 413

11.1.3 protocol参数 414

11.1.4 AF_XXX与PF_XXX形式的常数 414

11.2 地址格式 416

11.2.1 字节顺序 416

11.2.2 地址结构 417

11.2.3 支持地址格式转换的函数 419

11.2.4 获取网络配置信息 419

11.2.5 编程示例 423

11.2.6 将地址与套接字绑定 426

11.3 套接字连接 427

11.3.1 connect函数分析 427

11.3.2 服务器套接字建立侦听队列 428

11.3.3 建立套接字连接 429

11.4 数据的传送 430

11.4.1 send函数 430

11.4.2 传送数据的函数 431

11.4.3 接收数据的函数 432

11.4.4 recvfrom、recvmsg函数 432

11.4.5 编程示例 433

11.5 套接字选项 441

11.5.1 设置套接字选项 441

11.5.2 读取套接字选项 442

11.6 out-of-band数据 443

11.7 非阻塞和异步I/O操作 444

11.8 本章总结 444

第12章 嵌入式系统网络应用技术 445

12.1 嵌入式系统的设计要素 445

12.2 嵌入式系统开发环境的构成 445

12.2.1 硬件构成 446

12.2.2 典型的硬件开发环境 447

12.2.3 软件交叉平台开发环境 448

12.2.4 嵌入式软件的开发步骤 448

12.3 将网络设备驱动程序加入内核 450

12.3.1 配置新网络设备 450

12.3.2 编译新驱动程序 451

12.4 内核配置 452

12.4.1 目标硬件及内核、库配置 452

12.4.2 内核组件配置 454

12.4.3 应用配置 459

12.5 集成应用程序并下载至目标板 460

12.5.1 集成应用程序 460

12.5.2 将执行文件下载至目标板 461

12.6 本章总结 462