×
嵌入式开发 > 详情

嵌入式网络收音机的ARM实现

发布时间:2020-06-16 发布时间:
|

收音机作为接收广播的工具,经过漫长的发展过程,由单波段发展到多波段,由电子管,晶体管发展到集成电路,由机械调谐发展到数字调谐功能等,其技术和品质都有了长足的进步。

如今,在收音机这个家族中新的成员也在不断加入,如卫星广播接收机等。当社会进入网络时代后,更是出现了网络收音机这种跨越全球的信息接收设备。但是,目前这种网络收音机大多是通过基于PC机上的软件开发来实现的其功能的,也就是说这种网络收音机不能脱离电脑这种相对比较大的和比较昂贵的设备。为了克服PC机形式的网络收音机的缺点,本文研究了一种基于ARM嵌入式技术的网络收音机的设计方案。

该方案以ARM处理器及其外围模块作为硬件平台,以嵌入式Linux作为操作系统,以Mplayer作为网络播放软件,再配合设计的用户应用程序,共同实现嵌入式网络收音机的全部功能。这种设计方法在网络收音机的设计史上是一个创新。同时,随着网络技术的高速发展,该设计将具有极好的市场应用前景。

本文作者创新点:

1、首次提出了用嵌入式技术设计网络收音机的系统设计方案,极具创新特点。

2、实现了Mplayer软件在Linux系统平台下向ARM9的移置。

1系统的结构及工作原理

系统的层次结构如图1所示。系统以S3C2410及其外围电路为硬件平台,以嵌入式Linux和设备驱动程序作为系统的软件平台,为上层Mplayer播放器和用户应用程序提供用户接口支持[1]。在这三层结构的支持下,共同来实现嵌入式网络收音机的全部功能。

图1 系统层次结构图

系统的硬件结构框图如图2所示。本系统选用的ARM处理器是Sumsing(三星)公司的一款ARM9系列的芯片,型号为S3C2410。网卡芯片采用的是Cirrus Logic公司的一颗网络处理芯片CS8900。FLASH芯片采用的是 K9F5608,用来存储启动引导程序U-boot、内核及文件系统,SDRAM芯片采用的是HY57V281620,作为该系统的内存。16*4的字符型液晶显示模块用来显示网络电台、音频文件名等相关信息。音频D/A转换芯片选用的是飞利浦公司的UDA1341芯片,该芯片具有IIS接口,可以方便的与S3C2410连接。

图2 系统硬件结构框图

系统在Linux提供的TCP/IP协议的支持下,通过应用程序和Mplayer控制,经过网卡连接到internet上指定的网络电台服务器,下载网络电台列表。系统支持在按键的控制下的网络电台选择和LCD上显示电台信息等功能。Mplayer解析出选中的电台的IP地址后,再连接到要收听的电台的网站,系统便可以接收并解析出该网站发出的流媒体数据。系统将接收到的流媒体数据保存到SDRAM中。之后,经过Mplayer的解码,送到音频D/A转换芯片,即可收听到该网络电台播放的声音等信息。

2 系统的硬件设计

2.1 S3C2410

本系统的硬件核心平台采用的是Samsung 公司的处理器S3C2410。该处理器内部集成了ARM 公司ARM920T 处理器核的32 位微控制器,资源丰富,带独立的16KB 的指令Cache 和16KB 数据Cache、MMU虚拟内存管理单、LCD 控制器、RAM控制器、NAND 闪存控制器、3 路UART、4路DMA、4 路带PWM的Timer、并行I/O 口、8 路10 位ADC、Touch Screen 接口、I2C 接口、I2S 接口、2 个USB接口控制器、2 路SPI,主频最高可达203MHz[2]。其内部结构如图3所示。

图3 S3C2410内部结构图

2.2 网络接口

系统的网卡芯片采用Cirrus Logic公司的一种局域网处理芯片CS8900,该芯片内部集成了RAM、10BASE-T收发滤波器,并且提供8位和16位两种接口。其片选信号连接到S3C2410的nGCS1,因此网卡的地址空间映射到0X08000000~0X0FFFFFFF。在Linux内核中,一般都含有CS8900的驱动程序,使用时只需修改驱动与处理器的地址映射关系,并在配置内核的Device Driver选项中,选中CS8900项。

2.3 SDRAM存储器

本设计的SDRAM采用的是HY57V281620芯片。该芯片是一个数据宽度为16BIT,容量为16M字节的SDRAM。HY57V281620与S3C2410的连接图如图4所示。

图4 HY57V281620电路图

HY57V281620的ncs引脚接到处理器的nGCS6。由于在处理器的存储空间中,字节是存储容量的唯一单位。而HY57V281620的数据宽度为16位,它的每一个存储单元都包含2个字节。因此HY57V281620的A0引脚接到了S3C2410处理器的地址线ADDR01上面。 HY57V281620的容量为16MB,因此它需要ADDR00~ADDR23共24跟地址线来寻址,所以,BA0~BA1引脚应该接到ADDR22~ADDR23地址线上。



『本文转载自网络,版权归原作者所有,如有侵权请联系删除』

热门文章 更多
寻找半导体产业未来10年的驱动力