摘要:
网络
普及,安全问题正
威胁着每一个网络用户。
黑客攻击和信息泄漏等安全问题并不像病毒那样直截了当
对系统进行破坏,
故意隐藏自己
行动,
往往不能引起人们
重视。
,一旦网络安全问题发生,通常会带来严重
后果。目前最常见
网络安全防范工具是软件防火墙,这种防火墙
缺点就是占用有限系统资源,
防火墙
等级提高,该防火墙将严重阻碍通信
质量。本文对网络防火墙
具体分析,来讨论
嵌入式系统来实现网络硬件防火墙
过程。
关键词:网络硬件防火墙,嵌入式系统,UCOSII,TCP/IP,USB2.0
1 引言
网络防火墙是一种控制用户计算机网络访问
软件或硬件。
对它
各种规则设置,使
合法
链路
以建立;而非法
连接将被禁止,同时
各种手段屏蔽掉用户
隐私信息,以保障用户
对网络访问
安全。目前一般个人电脑是用
软件防火墙,
微电子
快速发展,我们可以完全利用嵌入式系统来实现硬件防火墙,
提高系统
网络访问性能。
2 网络防火墙
硬件实现
2.1 网络防火墙
硬件结构
本系统中,主芯片
采用菲利普
LPC2210,它是一款采用ARM7TDMI
核,工作频率可高达60M。网络芯片采用
Realtek公司
RTL8019AS,它是一款10M
网络芯片。PC机
通信芯片采用Cypress
USB2.0
接口芯片CY7C68013,它可以完成PC机和硬件防火墙
高速通信。
本系统中还提供2M字节
FLASH和512K字节
RAM,它们分别由芯片SST39VF160和IS61LV25616AL来实现。系统
硬件结构如图1:

2.2 主芯片LPC2210
LPC2210是基于一个支持实时仿真和嵌入式跟踪
16/32位ARM7TDMI-S
微控制器对代码规模有严格控制
应用可使用16位Thumb模式将代码规模降低超过30%而性能
损失却很小。
LPC2210
144脚封装极低
功耗多个32位定时器8路10位ADCPWM输出以及多达9个外部中断使它们特别适用于工业控制医疗系统访问控制和POS机 。
配置总线LPC2210最多可提供76个GPIO
内置了宽范围
串行通信接口它们也非常适合于通信网关协议转换器嵌入式软modern以及其它各种类型
应用。
2.3 网络通信芯片RTL8019
RTL8019AS网络芯片是REALTEK公司生产
,基于ISA接口
10M以太网通信芯片。 它采用全双工方式来进行接收以太网数据,非常容易和微处理器接口。该芯片集成了以太网
物理层以及以太网
收发器,数据封包形式完全符合IEEE802.3标准。
2.4 USB2.0接口芯片CY7C68013
CY7C68013是Cypress公司生产
一款USB2.0
接口芯片。它内部集成了8051
核,可以单独对该芯片编程。由该芯片完成USB2.0接口,跟PC机
通信速率可以高达10Mbyte/s。我们利用该款芯片来实现一个数据FIFO,即对微处理器来讲,它
将数据写入该FIFO,然后该芯片就会将数据
USB2.0
协议发送给PC机。
3 网络防火墙
软件实现
本系统中,软件一共分为两个部分:即嵌入式系统实现部分和PC机用户界面实现部分。嵌入式系统实现部分主要完成对网络封包
过滤以及完成与PC
人机界面
接口。用户可以
USB2.0接口对网络硬件防火墙进行设置,然后嵌入式系统
用户设置
安全规则来完成对网络封包进行过滤。
3.1 底层软件
实现
这部分软件是网络硬件防火墙实现
关键,它主要完成四个方面
工作,即对网络封包
过滤,日志
记录并发送,对用户
报警以及跟PC机
接口。
本系统中我们采用实时操作系统UCOS,配合自己编写
TCP/IP协议栈来实现对各个网络层次封包
过滤。
3.1.1 UC/OSII
ARM7下
移植
UCOSII是一个完整、可移植、可固化及可剪裁
占先式实时多任务内核。它用ANSI C编写,包含一小部分汇编代码,使之可以供不同架构
微处理器使用。移植该实时操作系统是实现底层软件
第一步。移植操作系统其实是一件不简单
事情,它必须要求开发人员对目标硬件平台有很深
了解;对UCOS
原理有相当
了解;对所使用
编译器有较深入
了解。
具备以上三点,才能成功移植该实时操作系统。要移植UCOS,
编写三个文件即可,它们分别是:OS_CPU.H,OS_CPU_C.C,OS_CPU_A.ASM。下面就简单介绍该移植
实现过程。

第一个是编写OS_CPU.H。
该文件中主要完成以下几个方面
工作。首先是几个数据类型
定义,如INT8U、INT16U、INT16S等,之
这样做是
ANSI C中并没有明确定义short、int等数据类型
实际长度,它与处理器
类型有关,隐含着不可移植性。代之以移植性强
INT8U、INT16U等数据类型,即直观又可移植。其次就是完成两个中断处理宏
定义,一个是关中断宏OS_ENTER_CRITICAL( ),另一个就是开中断宏OS_EXIT_CRITICAL( )。考虑到
所有版本
C语言都支持C语言级
开关中断,
编写此宏来实现C语言级
开关中断。最后就是定义栈生长方向和栈
宽度,它们分别用变量OS_STK_GROWTH和OS_STK。
第二个是编写OS_CPU_C.C。
该文件中主要完成函数OSTaskStkInit( )
编写,该函数主要完成任务堆栈
初始化工作,如初始化各个寄存器
状态,以及用户添加
一些任务变量等。
第三个是编写OS_CPU_A.ASM。该文件
是移植
关键所
,
本文件中必须完成四个函数
编写工作,它们分别为OSIntCtxSw( ),OSCtxSw(
), OSStartHighRdy( )和OSTickISR( )。其中前两个函数是重中之重,它们必须用汇编语言编写,主要完成任务环境
切换工作。
ARM7硬件平台下移植UCOSII要注意几个问题,首先是
移植系统函数
系统宏时要尽量
调用软件中断,这样有助于简化移植工作;其次
初始化任务堆栈时,可以添加任务变量OSEnterSum这个变量来监视中断开关次数,这是
移植
一个技巧;最后要注意
方便编写中断服务程序,
移植时还要提供相应
汇编宏来简化用户层代码
编写。
3.1.2 TCP/IP协议栈
UCOSII下
实现
TCP/IP协议分为四层,分别为应用层、传输层、网络层,物理层。本系统中物理层主要包括8019
驱动程序,网络层包括IP协议和ARP协议,传输层主要包括TCP协议和UDP协议,应用层主要包括FTP、HTTP、SNMP和一些用户应用程序。
该协议实现很复杂,这也是本系统实现
难点,下面给出该协议栈实现
函数框图:

图 3
箭头表示函数
调用关系,该协议栈是一个较完整
TCP/IP协议栈,它提供标准
SOCKET API函数,非常方便用户来实现INTERNET通信。并集成了简单
路由协议,可以跨越网关收发数据。TCP/TP协议栈
实现都是
调用图2框图来实现
。
3.1.3 各协议层下网络封包过滤
实现
实现了TCP/IP协议,
该基础上实现网络封包
过滤
个原理
实现问题。
实现网络封包过滤时,一般不会直接
协议里面进行数据包
过滤,
TCP/IP协议栈
各个层次下嵌入用户过滤层,
实现对改层数据包
过滤。比如要将PING程序
回显屏蔽掉,
传输层之上嵌入用户过滤层,该用户层作用是,当传输层向用户层提交接收到
以太网数据时,该用户层必须对所有
IP数据包进行检查。若检查到某个IP数据包含有PING请求时,该用户层就会将该数据包屏蔽掉,即它不会将该数据包提交到网络层
。若IP数据包正常时,它就会将数据包直接提交到网络层。这样,添加了该层协议之后,就可以对传输层
协议包进行过滤。同样
道理,可以
各个协议层下添加用户过滤层来实现各种协议数据包
过滤。具体
实现过程见图4:

3.1.4 USB2.0接口模块
实现
该模块采用CY7C68013,该芯片本身提供高速FIFO通道来实现通信数据到USB协议
转换,
程序初始化时,将该芯片置成SLAVE FIFO模式,那该芯片就会扮演一个协议转换器
角色。它
工作原理见图4。
由上图可以看出,LPC2210
周期
查询标志位,来判断FIFO是满
空,
接收FIFO有数据就立刻将数据读进来进行处理;若发送FIFO满,这时就不能将数据发送到FIFO中。CY7C68013
初始化程序片段如下:
IFCONFIG = 0xCB; //设置68013工作
SLAVE FIFO模式
PINFLAGSAB = 0x98; //将FLAGA,FLAGB分别设置成FIFO满和空标志
FIFORESET = 0x02; //复位各个FIFO缓冲
FIFORESET = 0x04;
FIFORESET = 0x06;
FIFORESET = 0x08;
EP2FIFOCFG = 0x00; //将FIFO设置成自动输出,并是传输数据宽度为16位
CY7C68013中添加以上初始化程序,就可以将该芯片变成一个USB协议转换器,其传输速率可达10Mbyte/S。
3.2 PC机人机界面
实现
该部分软件可以称为上位机软件,主
WINDOWS环境下实现
用户界面。该用户界面一共分为四个部分:封包监视、日志查询、控管规则以及系统设置。这四个部分都是
USB2.0接口与硬件防火墙进行通信,用户
它们就可以很方便
实现对具体网络封包
过滤,对日志进行查询以及对网络控管规则
设置。
封包
监视:该模块就是指硬件防火墙
用户设置
控制规则对网络封包进行过滤,当有网络封包被拦截之后,硬件防火墙会
USB接口模块将拦截信息传给该模块。该模块接收到拦截信息后,就会
PC机上以一定
形式显示出来。
日志管理:该模块是用来设置查询条件并显示查询结果。该模块是非常实用
,用户可以从某个日志文件中查找符合条件
记录并显示,这极大
方便了用户对网络封包数据
分析。
控管规则:该模块是人机界面
最重要部分,它用来设置和显示应用程序以及网络数据
控管规则,这个模块需要提供对控管规则进行增加、修改和删除
功能按钮。比如,用户希望对某个IP
址
IP范围进行屏蔽,就可以
添加控制规则来实现该目
。
系统设置:该模块其实是一个辅助模块,由它来设置系统
配置参数。这些参数分为公共设置和报警设置,其中公共设置包括日志设置,是否自动启动以及是否显示欢迎界面。报警设置包括拦截时是否用声音报警和是否闪烁图标报警等。
4 结语
我们设计
针对个人PC用户
硬件防火墙,具有成本低,性能优越
优点,它可以极大
节约系统资源,为个人用户提供高效可靠
网络环境。
网络
普及,个人网络硬件防火墙将会有很大
发展空间,它
出现将极大
保障用户
对网络访问
安全。