摘要

LwIP是一种TCP/IP协议栈的实现。LwIP协议栈专注于减少内存的使用和代码的大小,使LwIP适用于嵌入式系统中在有限的资源下能够使用小型的客户机。为了减少处理和内存的需求,LwIP使用裁剪过的API,并不需要任何数据都拷贝。
这个报告描述LwIP的设计与实现。算法和数据结构都用于协议的实现且描述了像内存和缓冲区管理系统的子系统。这个包括了LwIP参考API和使用LwIP的一些例子代码。

目录

1.  简介

2.  协议层
3.  概述
4.  流程模型
5.  操作系统模拟层
6.  缓冲区和内存管理
   6.1  包缓冲——pbufs
    6.2  内存管理
7.  网络接口
8.  IP处理
    8.1  包的接受
    8.2  包的发送
    8.3  包的交付
    8.4 ICMP处理
9.  UDP处理
10. TCP处理
    10.1 概述
    10.2 数据结构
    10.3 序列号的计算
    10.4 数据对列和传输
        10.4.1 避免愚蠢的窗口
    10.5 段接收
        10.5.1 多路调解
        10.5.2 数据接收
    10.6 新会话的接收
    10.7 快速重发
    10.8 定时器
    10.9 来回的时间评估
    10.10拥塞控制
11. 协议栈接口
12. 应用程序接口(API)
   12.1  基本概念
   12.2  API的实现
13. 统计代码分析
   13.1  代码的行数
   13.2  工程代码的大小
14. 执行分析
15. API参考
   15.1数据类型
      15.1.1 Netbufs
   15.2缓冲函数
      15.2.1 netbuf_new()
      15.2.2 netbuf_delete()
      15.2.3 netbuf_alloc()
      15.2.4 netbuf_free()
      15.2.5 netbuf_ref()
      15.2.6 netbuf_len()
      15.2.7 netbuf_data()
      15.2.8 netbuf_next()
      15.2.9 netbuf_first()
      15.2.10netbuf_copy()
      15.2.11netbuf_chain()
      15.2.12netbuf_fromaddr()
      15.2.13netbuf_fromport()
16. 网络连接函数
      16.0.14netconn_new()
      16.0.15netconn_delete()
      16.0.16netconn_type()
      16.0.17netconn_peer()
      16.0.18netconn_addr()
      16.0.19netconn_bind()
      16.0.20netconn_connect()
      16.0.21netconn_listen()
      16.0.22netconn_accept()
      16.0.23netvonn_recv()
      16.0.24netconn_write()
      16.0.25netconn_send()
      16.0.26netconn_close()
17. BSD套接字库
   17.1 套接字的描述
   17.2 申请套接字
       17.2.1 sokect()的调用
   17.3 建立链接
       17.3.1 bind()的调用
       17.3.2 connect()的调用
       17.3.3 listen()的调用
       17.3.4 accept()的调用
   17.4 数据的发送和接收
       17.4.1 send()的调用
       17.4.2 sendto()的调用
       17.4.3 write()的调用
       17.4.4 recv()的调用
       17.4.5 recvfrom()和recvmsg()的调用
 18. 例子代码
    18.1 API的使用
    18.2 直接地连接栈

LwIP协议栈规范翻译——摘要目录的更多相关文章

  1. 1、 LwIP协议栈规范翻译——简介

    1.简介 在过去几年中,计算机和计算机支持设备接之间的互联到无线网络日趋增加.计算机已经越来越无缝的集成在了日常的设备且价格也在下降.同时,无线网络技术例如蓝牙[HNI+98]和IEEE802.11b ...

  2. 3、LwIP协议栈规范翻译——概述

    3.概述 像许多其他TCP/IP实现一样,分层协议设计已经成为设计lwIP实现的指南.每个协议实现为自己的模块,其中几个功能充当每个协议的入口点.尽管协议层是单独实现的,一些层却不全是,正如前面所叙述 ...

  3. 4、 LwIP协议栈规范翻译——流程模型

    4.流程模型 协议实现的流程模型描述了系统被划分为不同的流程的方式.用于实现通信协议的一个流程模型是让每个协议作为一个独立的进程运行.有了这个模型,严格的协议分层被强制执行,并且协议之间的通信点必须严 ...

  4. 5、 LwIP协议栈规范翻译——操作系统仿真层

    为了使lwIP可移植,操作系统特定的函数调用和数据结构不直接在协议的代码中使用.相反,当需要这样的函数调用和数据结构时,直接使用操作系统仿真层. 操作系统仿真层为操作系统服务提供统一的接口,如定时器, ...

  5. 2、LwIP协议栈规范翻译——协议层

    2.协议层 TCP/IP套件中的协议是以层次的方式设计的,其中每个协议层解决了通信问题的单独部分.这种分层可以用作设计协议实现的指南,因为每个协议可以与另一个分开实现.然而,以严格分层的方式实现协议可 ...

  6. Go语言安全编码规范-翻译(分享转发)

    Go语言安全编码规范-翻译 本文翻译原文由:blood_zer0.Lingfighting完成 如果翻译的有问题:联系我(Lzero2012).匆忙翻译肯定会有很多错误,欢迎大家一起讨论Go语言安全能 ...

  7. LwIP协议栈开发嵌入式网络的三种方法分析

    LwIP协议栈开发嵌入式网络的三种方法分析   摘要  轻量级的TCP/IP协议栈LwIP,提供了三种应用程序设计方法,且很容易被移植到多任务的操作系统中.本文结合μC/OS-II这一实时操作系统,以 ...

  8. lwip协议栈学习---udp

    书籍:<嵌入式网络那些事-lwip协议> udp协议的优点: 1)基于IP协议,无连接的用户数据报协议,适用于传送大批量数据, 2)实时性比较高,适用于嵌入式网络 发送函数:udp_sen ...

  9. [转]MBTiles 1.2 规范翻译

    MBTiles 1.2 可以参考超图的文档MBTiles扩展具体实现可以参考浅谈利用SQLite存储离散瓦片的思路和实现方法 mapbox提供了一个简单实现测试代码,github地址在这里https: ...

随机推荐

  1. python itertools 模块讲解

    1.介绍itertools 是python的迭代器模块,itertools提供的工具相当高效且节省内存. 使用这些工具,你将能够创建自己定制的迭代器用于高效率的循环. - 无限迭代器 itertool ...

  2. underscore.js学习笔记

    一.理清概念 1.Underscore封装了常用的JavaScript对象操作方法,用于提高开发效率,Underscore还可以被使用在Node.js运行环境.从API中,你已经可以看出,Unders ...

  3. C# Task中的Func, Action, Async与Await的使用

    在说Asnc和Await之前,先说明一下Func和Action委托, Task任务的基础的用法 1. Func Func是一种委托,这是在3.5里面新增的,2.0里面我们使用委托是用Delegate, ...

  4. linux的挂载的问题,重启后就挂载就没有了

    我用fdisk命令,分一个/dev/sda6出来,然后用mkfs格式化为ext3,然后挂载到根目录下的PPP文件夹中,挂载是成功了,但是用reboot和shutdown重启或关机后挂载就没有了 要修改 ...

  5. Centos7.0下Nexus私服搭建

    1.下载nexus wget https://sonatype-download.global.ssl.fastly.net/nexus/oss/nexus-2.11.2-03-bundle.tar. ...

  6. 【XGBOOST】

    https://www.cnblogs.com/wxquare/p/5541414.html

  7. 高并发分布式系统中生成全局唯一(订单号)Id

    1.GUID数据因毫无规律可言造成索引效率低下,影响了系统的性能,那么通过组合的方式,保留GUID的10个字节,用另6个字节表示GUID生成的时间(DateTime),这样我们将时间信息与GUID组合 ...

  8. ZIP解压缩工具类

    import java.io.File; import org.apache.tools.ant.Project; import org.apache.tools.ant.taskdefs.Expan ...

  9. 关于Kafka broker IO的讨论

    Apache Kafka是大量使用磁盘和页缓存(page cache)的,特别是对page cache的应用被视为是Kafka实现高吞吐量的重要因素之一.实际场景中用户调整page cache的手段并 ...

  10. mysql按位的索引判断值是否为1

    DELIMITER $$ DROP FUNCTION IF EXISTS `value_of_bit_index_is_true`$$/*计算某个数字的某些索引的位的值是否都为1,索引类似1,2,3, ...