quedou 2019-06-14
需求:
在物联网设备中,TCP/IP网络协议栈是一个非常重要的软件组成部分,没有TCP/IP网络协议栈,物联网设备就无法连接到互联网中。TCP/IP网络协议协议本身比较复杂。物联网出现之前的TCP/IP实现代码量都非常的庞大。但对于物联网设备来说,内存非常有限,处理器的性能也非常有限,这就需要一个轻量级的TCP/IP网络协议栈来运行,使用非常小的内存,把一些不必要的功能舍弃掉,保留主要的功能。由于这些需求,产生了几种嵌入式的TCP/IP的协议栈,常见的有以下几种:μC/ TCP-IP,LwIP,UIP。
常见的嵌入式TCP/IP协议栈
1. μC/ TCP-IP:
μC/ TCP-IP是Micrium公司自己的操作系统UC/OS的一个组件,同时支持IPv4和IPv6,支持BSD套接字API,具有最流行的套接字选项。这个协议栈是紧凑,可靠,高性能的TCP / IP协议栈,针对嵌入式系统进行了优化。μC/ TCP-IP完全自主编码,具有高质量,可扩展性和可靠性,可快速配置所需的网络选项,从而最大限度地缩短产品上市时间,MicriumμC/ TCP-IP嵌入式协议栈允许根据设计要求调整内存占用。μC/ TCP-IP可以配置为仅包括系统所需的那些网络组件。未使用组件时,它可以不包含在协议栈中,从而节省宝贵的内存空间。
2. LwIp网络协议栈:
LwIP是由瑞典科学研究院的Adam Dunkels开发的一套小型的TCP / IP协议组件,实现的主要目标是减少资源使用,同时仍然具有全面的TCP功能。这使得lwIP适用于具有10Kb字节空闲RAM的嵌入式系统,并且可以容纳大约40Kb的代码ROM。从开始发展到现在LwIP被移植到多个嵌入式操作系统,包括流行的FreeRTOS,还有阿里云的物联网操作系统AliOS Things,华为的物联网操作系统LiteOS等等。
3. uIP网络协议栈:
uIP主要用于8位和16位微控制器的小型嵌入式网络协议栈。最初,uIP 网络协议栈由瑞典计算机科学院的Adam Dunkels 开发,其源代码由C 语言编写,并完全开源。uIP协议栈最大的优势就是短小精悍,Flash和RAM需求小,去掉了完整的TCP/IP 中不常用的功能,简化了通讯流程,但保留了网络通信必须使用的协议,重点放在了IP/TCP/ICMP/UDP/ARP 这些网络层和传输层协议上,保证了其代码的通用性和结构的稳定性。
LwIP协议栈功能
从这部分看,LwIP支持的功能是非常多的,除了传统的TCPIP,还支持了很多最新的协议(如mDNS,UDP-lite,6LoWPAN等)
整体架构
LwIP架构
从上图看到,IwIP按照TCP/IP的分层分为4层,分别是链路层,网络层,传输层和应用层。
协议栈的数据处理流程主要有以下三种:
数据包的收发需要基于邮箱和信号量的支持,如果基于操作系统,这些机制操作系统都可以提供,移植起来只需要把基于邮箱和信号的函数加以封装即可,如果是没有操作系统的裸机移植则需要使用中断或者轮询方式实现收发数据,工作量相对要比没有操作系统要大。
源码架构
LwIP协议栈主目录
我们用最新的2.1 版本为例,LwIP的文件夹主要有三个,doc,src和test三个目录。
Doc是存储的帮助文档,和之前的1.4版本的帮助文档的文本文件不同,它使用了doxygen工具根据源代码的注释生成HTML格式的帮助文档。src是LwIP的主要源代码目录,test目录是测试脚本和一些测试协议栈的程序。