电子工程师的网站
首 页 |  新闻资讯 | 最新产品 | 解决方案 | 技术参数
设计应用
电路图 | 技术资料 | 芯片资料 | 技术论坛
  现在位置: 首页 > 设计应用 > 嵌入式系统/ARM技术 > 详细信息
嵌入式系统/ARM技术:基于S3C44B0X+μcLinux的嵌入式以太网设计
来源: http://www.ic37.com   时间: 2007-11-14 2:35:13    
  来源:电子设计信息网 作者:寇向晖 陈利学 田家林随着半导体技术的飞速发展,嵌入式产品已经广泛应用于军事、消费电子、网络通信、工业控制等各个领域,网络化是嵌入式系统发展的必然趋势。嵌入式Linux 作为具有开放的源代码、优秀的网络性能、可裁减等诸多优点的操作系统,非常适合用于具有网络功能的嵌入式系统。本文介绍了以S3C44B0X 的ARM处理器和RTL8019AS 以太网控制器为基础的网络接口设计,并阐述了怎样在嵌入式操作系统μcLinux 下实现对网卡的驱动。 
    
  S3C44B0X 处理器介绍
    
  ARM是业界著名的芯片设计IP 供应商,其32 位RISC 微处理器占据了全球80%以上的市场份额。ARM7 系列处理器也是目前市场上最成熟、应用最广的处理器。SAMSUNG 公司推出的S3C44B0X 就是以ARM7TDMI 为内核的一款16/32 位RISC 处理器。它采用0.25μm CMOS 工艺制造,为手持设备和一般应用提供了高性价比和高性能的微处理器解决方案。S3C44B0X 通过提供全面的、通用的片上外设,大大减少了外围的元器件配置,从而使系统成本大为降低。S3C44B0X 芯片的内部结构如图1 所示。
     
    
  网络接口的电路设计
    
  在介绍电路设计之前,先简要介绍一下网络控制器RTL8019AS 的情况。RTL8019AS 是台湾REALTEK公司生产的一款性价比很高的、带有即插即用功能的全双工以太网控制器。它内部集成了两块RAM,一块16KB,地址为0x4000~0x7FFF;一块32 字节,地址为0x0000~0x001F。16K 的RAM用作收发数据的缓冲区,一般将0x4000~0x46FF 作为发送缓冲区,0x4700~0x7FFF 作为接收缓冲区。图2 是针对S3C44B0X,用RTL8019AS、74LV138(3- 8 译码器)、FB2022(网卡变压器)设计的以太网接口电路。
     
    
  该电路数据宽度为16 位,使用外部中断EXINT3。处理器的片选信号nGCS1 和A16、A17、A18 通过74LV138 输出为网卡的使能控制端。nOE 和nWE控制网卡的读写,nRESET 控制网卡的复位,FB2022起变压滤波的作用。
     
     
     
     
    
  μcLinux 操作系统和网络驱动开发介绍
    
  本系统为什么要选择μcLinux
    
  Linux以其开放的源代码、强大的网络功能等诸多优点而成为当今流行的操作系统之一。μcLinux 从Linux 内核派生而来,沿袭了Linux 的大部分特性,专门针对没有MMU(存储器管理单元)的CPU,并且为嵌入式系统做了很多小型化工作,它内核小,但功能强大,系统健壮,并且具有广泛的硬件支持特性,是一个优秀的嵌入式操作系统。S3C44B0X 正是一款没有MMU 的处理器,所以在该系统中,操作系统选择μcLinux 是非常合适的。
    
  μcLinux 下网络驱动开发简介
    
  μcLinux 和Linux 下驱动的实现过程基本相同。linux 将所有的设备看作具体的文件,通过文件系统层对设备进行访问。所以在linux/uclinux 的框架结构中,和设备相关的处理可以分为两个层次— —文件系统层和设备驱动层。设备驱动层屏蔽具体设备的细节,文件系统层则向用户提供一组统一的规范的用户接口。这种设备管理方法可以很好的做到“设备无关性”,使linux/uclinux 可以根据硬件外设的发展进行方便的扩展,比如要实现一个设备驱动程序,只要根据具体的硬件特性向文件系统提供一组访问接口即可。整个设备管理子系统的结构如图3 所示。
     
    
  在Linux/μclinux 中,整个网络接口驱动程序的框架可分为四层,从上到下分别为协议接口层、网络设备接口层、提供实际功能的设备驱动功能层、以及网络设备和网络媒介层。这个框架在内核网络模块中已经搭建好了,我们在设计网络驱动程序时,要做的主要工作就是根据上层网络设备接口层定义的net_device结构和底层具体的硬件特性,完成设备驱动的功能。在网络驱动程序部分主要有两个数据结构,一个是sk_buff,TCP/IP 中不同协议层间以及和网络驱动程序之间数据包的传递都是通过这个结构体来完成的,这个结构体主要包括传输层、网络层、连接层需要的变量,决定数据区位置和大小的指针,以及发送接收数据包所用到的具体设备信息等。它的详细定义可参阅内核源代码。
    
  另一个就是net_device 结构,它的定义在中。这个结构是网络驱动程序的核心,它定义了很多供系统访问和协议层调用的设备标准的方法,包括供设备初始化和往系统注册用的init 函数,打开和关闭网络设备的open 和stop 函数,处理数据包发送的函数hard_start_xmit,以及中断处理函数等,接口状态统计函数等。
  RTL8019AS 驱动程序的实现
    
  嵌入式系统开发中,设备驱动的编写会占用很大的工作量。下面详细介绍在本系统中网卡驱动程序设计的步骤。
    
    * 初始化函数
    
    static int RTL8019_init(struct net_device *dev)
    
    {
    
    调用ether_setup (dev) 函数设置通用的以太网接口;
    
    填充net_device 数据结构的属性字段;
    
    调用kmalloc 申请需要的内存空间;
    
    手动设置MAC 地址;
    
    }
    
    * 设备打开与关闭函数
    
    static int RTL8019_open(struct net_device *dev)
    
    {
    
    关闭中断;
    
    注册中断号和I/O 地址;
    
    初始化设备的寄存器;
    
    使能中断;
    
    }
    
    设备关闭函数与打开函数的动作相反。
    
    * 数据包发送函数
    
    static int RTL8019_sendpacket(struct sk_buff *skb,
    
    struct net_device *dev)
    
    {
    
    将标志位tbusy 打开;
    
    将数据包写入RTL8019 的发送缓冲区,启动DMA 发送功能;
    
    释放缓冲区;
    
    }
    
    * 数据包接收函数
    
    static int RTL8019_rx( int irq, void *dev_id, structpt_regs *regs)
    
    {
    
    申请skb 缓存区存储新的数据包;
    
    从硬件中读取新到达的数据;
    
    调用函数netif_rx(),将新的数据包向网络协议的上一层传送;
    
    }
               
    最后,将驱动程序编译进内核,由于μcLinux 不支持模块动态加载,因此必须使用静态编译的方法。如果一切正常的话,使用ifconfig、route add 命令设置IP地址和子网掩码,网卡就能正常工作了。
    
    结束语
    
    RTL8019AS 以太网控制器以其优良的性能在嵌入式系统中得到了广泛的应用,而μcLinux行通信和交换数据。试验表明,用HPI 接口在C5416和S3C4510B 间通信满足嵌入式系统的实时性要求。
相关信息
发表评论
打印本页 关闭本页
基于S3C44B0X μcLinux的嵌入式以太网设计
    随着半导体技术的飞速发展,嵌入式产品已经广泛应用于军事、消费电子、网络通信、工业控制等各个领域,网络化是嵌入式系统发展的必然趋势。嵌入式Linux 作为具有开放的源代码、优秀的网络性能、可裁减等诸多优点的操作系统,非常适合用于具有网络功能的嵌入式系统。本文介绍了以S3C44B0X 的ARM处理器和RTL8019AS 以太网控制器为基础的网络接口设计,并阐述了怎样在嵌入式操作系统μcL...
>>详细内容
关于三星S3C44B0X目标板的uClinux Bootloader
  uClinux是为控制领域设计的嵌入式Linux操作系统,它沿袭了主流Linux的大部分特性,并进行了一定幅度的裁减。其设计主要针对没有内存管理单元(MMU)的微处理器,例如基于ARM7TDMI内核的S3C44B0X。 嵌入式Linux系统通常由三部份组成:Bootloader、Kernel和File System。其中Bootloader是在系统启动之后、Kernel运行之前所执行的第一段代码,其任务是为调用Kernel准备必要的软硬件环境。由此...
>>详细内容
ARM CPU S3C44B0X在水表智能抄表系统中应用
  摘 要: 介绍水表智能抄表系统的核心部分--抄表手机,以及如何用32位机S3C44B0X来实现抄表手机的功能。关键词: 智能抄表系统 抄表手机 S3C44B0X CPU ARM7TDMI核 USB总线 1 水表智能抄表系统简介目前,自来水表都是机械式的,而且多数自来水表都装在户内,这给水表抄表员带来了很大的麻烦。当抄表员抄表时,必须挨家挨户用肉眼读取水表的读数,然后登记在随身携带的小本子上...
>>详细内容
基于S3C4510B型微处理器的最小系统设计
  基于S3C4510B型微处理器的最小系统设计 陈斌 (西安工程科技学院 电子信息学院 陕西 西安 710048) 1 引言 ARM(Advanced RISC Machines),既可以认为它是一个公司的名字,也可以认为它是一类微处理器的统称,还可以认为它是一种技术名称,习惯上称之为&qu...
>>详细内容
基于S3C44B0X的Microwindows在远程红外抄表器中的应用
  随着嵌入式系统的广泛应用,面向人机交互的嵌入式产品的需求量越来越大,GUI的设计也变得越来越重要。在Linux之上进行实时嵌入式系统开发的厂商,一般会选择如下几种GUI系统:高度裁减的X Windows 系统、MiniGUI、Microwindows、QT/Embedded等。Microwindows作为一种开放式源码的嵌入式GUI软件,目的是把图形视窗环境引入到运行Linux的小型设备和平台上,其体系结构如图1所示。Microwindo...
>>详细内容
基于S3C4510B的存储系统原理与设计
    1. 引言  对于嵌入式系统的开发人员来说,深刻地理解其存储系统的寻址原理和有效的管理存储系统对正确高效地设计嵌入式系统的硬件和底层软件编程具有重要的意义。目前嵌入式系统中最常用的存储器包括有EEPROM、FLASH、Normal DRAM和Sync.DRAM等。本文所采用的存储器包括有SDRAM和FLASH。S3C4510B(以下简称4510)微处理器是构建在ARM核ARM7TDMI之上的,ARM7TDMI的地址总线为32位的,...
>>详细内容
已有(
)位对此新闻感兴趣的网发发表了看法 >>更多评论
内 容:
     
 
热点新闻
一周排行
关于我们 | 服务项目 | 付款方式 | 广告服务 | 联系我们 | 友情链接 | 投诉 建议 合作 | 网站地图 | 加入收藏
Copyright © 2007-2008 WEEQOO.COM Corp.All Rights Reserved. 版权所有 经营许可证编号:浙B2-20050339 法律声明
维库电子旗下网站:维库电子市场网 | ChinaICMart | 维库电子开发网 | 维库电子人才网
总部:杭州市下城区朝晖路182号国都发展大厦1号楼80A
电话:0571-85889139-8007 QQ:303939539 | MSN:zh1226@hotmail.com |  邮箱:laz8258@163.com dzsc51@163.com