基于多媒体处理器VG2的智能家居控制器设计

发布者:风暴使者最新更新时间:2012-10-29 来源: 21ic 关键字:多媒体处理器  VG2  智能家居控制器 手机看文章 扫描二维码
随时随地手机看文章

1 硬件设计

核心CPU采用三星公司的S3C44B0。S3C44B0采用ARM7TDMI内核,它通过提供全面的、通用的片上外设,大大减少了系统电路除处理器以外的元器件配置,降低了系统成本。 网络接口芯片采用Realtek公司生产的RTL8019AS。它是一款高度集成的以太网控制器,不仅集成了MAC(介质访问控制)子层和物理层的性能,而且与NE2000兼容,具有软件可移植性强以及价格低廉等优点。

S3C4480与RTL8019AS的硬件接口原理如图1所示。从图1中可以看出,RTL8019AS的使能端连到S3C44B0的nGCS3,因此它的地址映射在系统的Bank3上,基地址为0x06000000。RTL8019AS支持8位/16位数据总线,在本电路中采用16位方式。

RTL8019AS共有32个输入/输出地址,对应地址偏移量为0x00~0x1f。现分别说明如下:

①0x00~0x0f的16个地址,为寄存器地址。

②0x10~0xl7的8个地址,为数据读写端口地址。它们都是一样的,每个都可以用来做数据读写端口,只要用其中一个就可以了。

③0x18~0x1f的8个地址,为复位端口。它们的功能都是一样的。但需要注意,实际上只有0x18、0x1a、0x1c、0xle这几个复位端口是有效的,其他不要使用;因为有些兼容卡不支持0xl9、0xlb、Oxld等奇数地址的复位。

在软件设计时,尤其要注意以下两点:

①RTL8019AS的地址线从SA0~SA4依次连到S3C4480的ADDR1~ADDR5上,因此,RTL8019的寄存器地址要左移1位。

②RTL8019AS使用EXINT1中断,且上升沿触发。

2 软件实现

2.1 VxWorks的网络协议栈和MUX接口

VxWorks中的网络协议栈叫作"SENS(Scalable En-hanced Network STack)",即可裁减增强网络协议栈。SENS是基于4.4BSDTCP/IP协议栈发展而来的。它包含了许多4.4BSDTCP/IP协议栈没有的协议;而且SENS在实现一些协议功能时增加了许多新特性。如在IP协议实现时增加了多播功能。SENS协议栈层次如图2所示。

SENS的基本特征与传统的TCP/IP网络协议栈相似,但从图2中可以看出,SENS最大的特点是在数据链路层和网络协议层之间多了MUX层。在SENS中网络接口的驱动程序叫作"END(Enhanced Network Driver)",即增强型网络驱动程序,它处于数据链路层。IP层和TCP/UDP层合称为"网络协议层"。在数据链路层和网络协议层之间有应用程序接口(API),这个接口在SENS中叫作"MUX(Multiplexer)接口"。MUX接口如图3所示。MUX接口起到隔离网络驱动程序与网络协议的作用。在老式的BSD4.3的驱动模式下,网络驱动程序和协议是紧密联结的,无论协议还是驱动程序都需要了解对方的数据结构。而在新的基于MUX的模式下,驱动程序和协议并不需要了解对方。它们通过MUX接口来通信。例如,在收到一个包后,网络驱动程序并不直接访问协议的数据结构;相反,当准备将数据传给协议层时,它调用一个MUX提供的函数,该函数处理把数据传给协议层的细节。这使得添加一个新的驱动程序或协议十分容易。MUX实现了下面的一套函数集:muxBind()、muxUn-bind()、muxDevLoad()、muxDevUnload()、muxReceive()、muxError()、muxSend()、muxTxRestartRtn()、muxM castAddrDel()、muxMcastAddrGet()、mux-PollSend()、muxMcastAddrAdd()、muxPollReceive()、muxIoctrl()。网络驱动程序和协议都要调用上面的函数,不需要为它们添加任何附加代码。 [page]

2.2 END设备驱动程序装载过程

在VxWorks中,END设备驱动程序装载过程可以分为3个步骤,即指定END设备,装载END设备和启动END设备。END设备的指定是通过数组endDevTbl[ ]来完成的,该数组描述了系统中的所有网络设备的装载人口点及其相关参数。系统调用MUX设备装载函数mux-DevLoad()来装载END设备,调用MUX设备启动函数muxDevStart()来启动END设备。网络设备驱动程序的装载过程如图4所示。系统通过usrRoot()函数来调用usrNetInit()函数完成MUX的初始化,装载网络设备表endDevTbl[ ]中描述的所有设备,并将IP协议绑定到网络引导设备上等。

当网络设备产生中断时,VxWorks调用驱动程序先前注册的中断服务程序。中断服务程序应做尽可能少的工作,以完成将数据包从本地网络设备送出/取出的操作。

2.3 文件配置

由于RTL8019兼容NE2000网卡芯片,只需要在其基础上完成必要的修改。首先将Tornado2.2\target\src\drv\end目录下的ne2000End.c和Tornado2.2\target\h\dry\end目录下的ne2000End.h拷贝到bsp目录下,然后修改以下文件。

(1) 修改ne2000End.C

①修改头文件包含目录;
②sysIntConnect修改为intConnect;
③sysLanIntEnable修改为intEnable,并修改返回类型void为STATUS。

(2) 修改ne2000End.h

将寄存器地址左移1位,如:

#define ENE_RSTART(0x01<<1)

(3) 修改config.h

添加网络宏定义:

①#define INCLUDE_NETWORK
②#define INCLUDE_END
③#ifdef INCLUDE_END
#undef INCLUDE_SNGKS32C_END
#define INCLUDE_NE2000_END
#endif/*INCLUDE_END*/

(4) 修改configNet.h

在endDevTbl[ ]表中添加新的装载函数(其函数命名格式为xxLoad( ))入口点及相关参数。


(5) 修改Makefile

添加MACH_EXTRA=ne2000End.o

(6) 修改sysLib.c

①添加MAC地址定义:

unsigned char ne2000EnetAddr[]=ETHERNET_MAC_ADRS;

②添加 sysInByte、sysOutByte、syslnWordString和sysOutWordString函数。

③在sysHwInit()中添加CPU端口初始化:


④在sysHwInit()中添加RTL8019芯片的复位和初始化函数。相关代码如下(有关寄存器的宏定义请参照RTL8019数据手册):[page]



结 语

本文在VxWorks嵌入式实时操作系统下,提出了网络接口的解决方案,即以ARM7(S3C44B0)为核心CPU,控制网络控制器TRL8019实现网络通信。本文首先简单介绍了几款主要芯片,给出了硬件原理图;然后简要分析了VxWorks下的网络协议和驱动装载过程;最后,针对此网络接口,详细列出了VxWorks下文件配置过程,提供了部分软件源程序,对开发人员有一定的参考价值。

关键字:多媒体处理器  VG2  智能家居控制器 引用地址:基于多媒体处理器VG2的智能家居控制器设计

上一篇:S3C44B0X在水表智能抄表系统中应用
下一篇:基于IAR集成开发平台的ARM程序设计方法

推荐阅读最新更新时间:2024-03-16 13:11

高性能多媒体应用的SH7786系列双核处理器
− 利用双核SH-4A高性能32位CPU内核实现1920 MIPS的卓越性能 − 东京,2008年1月31日 —瑞萨科技公司(Renesas Technology Corp.)今天宣布,开发出了采用双内核SH-4A CPU构建的双核处理器的SH7786系列。SH7786适用于高性能多媒体应用,尤其是像汽车导航系统这样的汽车信息系统(CIS)。它集成了两个瑞萨科技的SH-4A高性能CPU内核,可实现高达1920 MIPS(每秒百万指令)* 1 的卓越处理能力(CPU工作频率为533 MHz时)。 该系列中的第一个产品采用90 nm工艺制造,目前已交付样品给特定的汽车电子厂商。下一个产品将采用
[焦点新闻]
盘点飞思卡尔i.MX多媒体处理器前世今生
现如今,移动处理器领域,大家关注最多的是德州仪器、高通、展讯、MTK,甚至包括Intel,但是请别忘记飞思卡尔,他的i.MX处理器已经发展到第六代。 那么我们今天就来盘点下i.MX的前世今生吧。 i.MX前世:DragonBall 现在提到DragonBall,也许大部分人会以为是七龙珠怀旧。不过确实,七龙珠出现的时间要早于摩托罗拉的DragonBall(即MC68328)。七龙珠1984年开始创作,而DragonBall则出现于1995年,设计者为当时在摩托罗拉公司实习的香港城市理工学院的电子工程系学生。 从名字我们就可以看出,MC68328基于摩托罗拉68000内核,但这款产品功耗与同类产品比较,功耗极低,因此非常适合
[手机便携]
基于μC/OS-II的VG2以太网和USB接口设计
1 引言 近几年来,随着计算机网络技术的快速发展,TCP/IP协议已成为应用最广泛的网络互联协议。USB(通用串行总线)以灵活、方便、通信稳定、成本低廉、即插即用等优点已经成为数据存储与交换的通用接口。 ADChips公司的32位多媒体微处理器VirgineG2(简称VG2)具有强大的数据、图像和音频处理功能,而且能够直接输出NTSC/PAL制式模拟信号。VG2只提供了一路32位的I/O接口和两路串行通讯接口,因此需要对VG2扩展TCP/IP接口和USB接口,以实现远/近程数据的交互和大容量数据存储。 本文采用Realtek公司的RTL8019AS芯片对VG2进行以太网接口扩展,通过TCP/IP协议规范及LwIP实现VG2的
[单片机]
基于μC/OS-II的<font color='red'>VG2</font>以太网和USB接口设计
LSI Logic第一款基于ZEVIO架构标准芯片问世
近日,LSI Logic发布基于ZEVIO架构的第一款标准芯片——ZEVIOTM 1020多媒体应用处理器。该产品可提供一流的成本、功耗和性能比。 据了解,新的ZEVIO 1020应用处理器和完整的开发支持工具能够帮助生产商快速设计出成本敏感型的消费电子产品,同时具备低功耗、更高级图像和数字音/视频处理功能。同时,该产品还特别针对电子玩具、导航系统和其他创新型消费电子产品进行高度优化。例如在功耗方面,多数情况下其消耗功率都低于150毫瓦。 “LSI的ZEVIO 1020处理器,是特别针对大量低于100美元的便携式多媒体应用而设计的。” LSI Logic消费电子部门ZEVIO产品市场总监Melvin Hirata介绍说,“通过提
[焦点新闻]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
  • 学习ARM开发(16)
    ARM有很多东西要学习,那么中断,就肯定是需要学习的东西。自从CPU引入中断以来,才真正地进入多任务系统工作,并且大大提高了工作效率。采 ...
  • 学习ARM开发(17)
    因为嵌入式系统里全部要使用中断的,那么我的S3C44B0怎么样中断流程呢?那我就需要了解整个流程了。要深入了解,最好的方法,就是去写程序 ...
  • 学习ARM开发(18)
    上一次已经了解ARM的中断处理过程,并且可以设置中断函数,那么它这样就可以工作了吗?答案是否定的。因为S3C44B0还有好几个寄存器是控制中 ...
  • 嵌入式系统调试仿真工具
    嵌入式硬件系统设计出来后就要进行调试,不管是硬件调试还是软件调试或者程序固化,都需要用到调试仿真工具。 随着处理器新品种、新 ...
  • 最近困扰在心中的一个小疑问终于解惑了~~
    最近在驱动方面一直在概念上不能很好的理解 有时候结合别人写的一点usb的例子能有点感觉,但是因为arm体系里面没有像单片机那样直接讲解引脚 ...
  • 学习ARM开发(1)
  • 学习ARM开发(2)
  • 学习ARM开发(4)
  • 学习ARM开发(6)
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved