基于s3c2410的嵌入式系统硬件结构设计.ppt
《基于s3c2410的嵌入式系统硬件结构设计.ppt》由会员分享,可在线阅读,更多相关《基于s3c2410的嵌入式系统硬件结构设计.ppt(296页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1,Part 5 基于S3C2410的硬件系统设计(一),1,3,2,4,S3C2410X简介 存储器接口设计 I/O接口设计 UART设计 IIC接口设计 中断接口 时钟和功耗管理 PWM定时器,5,6,看门狗定时器 日历时钟 DMA LCD控制器 A/D转换与触摸屏 USB接口 SPI,7,8,10,9,11,12,13,14,15,2,5.1 S3C2410X概述,主要内容 主要特性 系统结构 引脚信号,3,5.1 S3C2410X概述,S3C2410X是韩国三星公司推出的16/32位RISC微控制器,其CPU采用的是ARM920T内核,加上丰富的片内外设,为手持设备和其它应用,提供了低
2、价格、低功耗、高性能微控制器的解决方案。,4,主要特性 具有16KB指令Cache、 16KB数据Cache和存储器管理单元MMU。 外部存储器控制器,可扩展8组,每组128MB,总容量达1GB;支持从Nand flash存储器启动。 55个中断源,可以设定1个为快速中断,有24个外部中断,并且触发方式可以设定。 4通道的DMA,并且有外部请求引脚。 3个通道的UART,带有16字节的TX/RX FIFO,支持IrDA1.0功能。 具有2通道的SPI、1个通道的IIC串行总线接口和1个通道的IIS音频总线接口。 有2个USB主机总线的端口,1个USB设备总线的端口。 有4个具有PWM功能的16
3、位定时器和1个16位内部定时器。,芯片体系结构,5,芯片体系结构,主要特性 8通道的10位A/D转换器,最高速率可达500kB/s;提供有触摸屏接口。 具有117个通用I/O口和24通道的外部中断源。 兼容MMC的SD卡接口。 具有电源管理功能,可以使系统以普通方式、慢速方式、空闲方式和掉电方式工作。 看门狗定时器。 具有日历功能的RTC。 有LCD控制器,支持4K色的STN和256K色的TFT,配置有DMA通道。 具有PLL功能的时钟发生器,时钟频率高达203MHz。 双电源系统:1.8/2.0V内核供电,3.3V存储器和I/O供电。,6,二、系统结构 主要由两大部分构成: ARM920T内
4、核片内外设。,7,1、ARM920T内核 由三部分:ARM9内核ARM9TDMI、32KB的Cache、MMU。,8,2、片内外设 分为高速外设和低速外设,分别用AHB总线和APB总线。,9,三、引脚信号 S3C微控制器是272-FBGA封装。 其信号可以分成: addr0-addr26、 Data0-data31、 GPA0-GPA22 GPB10、GPC15、 GPD15、GPE15、 GPF7、GPG15、 GPH10、EINT23、 nGCS0nGCS7、 AIN7、IIC、SPI、 OM0-OM3 等,大部分都是复用的,BACK,10,5.2 S3C2410X的存储器,主要内容 存储
5、器配置 存储器概述 控制寄存器 Flash及控制器 Flash控制器概述 控制器主要特性 控制器的寄存器 控制器的工作原理,11,5.2.1 S3C2410X的存储器配置,一、概 述 S3C2410X的存储器管理器提供访问外部存储器的所有控制信号:27位地址信号、32位数据信号、8个片选信号、以及读/写控制信号等。 S3C2410X的存储空间分成8组,最大容量是1GB,bank0-bank5为固定128MB,bank6和bank7的容量可编程改变,可以是2、4、8、16、32、64、128MB,并且bank7的开始地址与bank6的结束地址相连接,但是二者的容量必须相等。 bank0可以作为引
6、导ROM,其数据线宽只能是16位和32位,复位时由OM0、OM1引脚确定;其它存储器的数据线宽可以是8位、16位和32位。 S3C2410X的存储器格式,可以为大端格式,也可以为小端格式。,12,ARM9 内核,存储器 控制器,存储器,存储器及存储器映射I/O,ARM9定义了局部总线的接口时序,各芯片厂商制定了自己的接口时序,ARM9局部总线,一般在两者之间加入存储器控制器,13,14,二、存储器的控制寄存器 内存控制器为访问外部存储空间提供存储器控制信号, S3C2410X存储器控制器共有13个寄存器。,15,1、总线宽度和等待控制寄存器 back,STn:控制存储器组n的UB/LB引脚输出
7、信号。 1:使UB/LB与nBE3:0相连; 0:使UB/LB与nWBE3:0相连 WSn:使用/禁用存储器组n的WAIT状态 1:使能WAIT;0:禁止WAIT DWn:控制存储器组n的数据线宽 00:8位;01:16位;10:32位;11:保留,16,Tacs:设置nGCSn有效前地址的建立时间 00:0个;01:1个;10:2个;11:4个时钟周期 Tcos:设置nOE有效前片选信号的建立时间 00:0个;01:1个;10:2个;11:4个时钟周期 Tacc:访问周期 000:1个;001:2个;010:3个;011:4个时钟 100:6个:101:8个;110:10个;111:14个,
8、2、BANKn-存储器组控制寄存器(n=0-5),17,Tcoh:nOE无效后片选信号的保持时间 00:0个;01:1个;10:2个;11:4个时钟 Tcah: nGCSn无效后地址信号的保持时间 00:0个;01:1个;10:2个;11:4个时钟 Tacp:页模式的访问周期 00:2个;01:3个;10:4个;11:6个时钟 PMC:页模式的配置,每次读写的数据数 00:1个;01:4个;10:8个;11:16个 注:00为通常模式。 注:紫色为某实验箱上的配置,其值为0 x0700,back,18,MT:设置存储器类型 00:ROM或者SRAM,3:0为Tacp和PMC; 11:SDRAM
9、, 3:0为Trcd和SCAN; 01、10:保留 Trcd:由行地址信号切换到列地址信号的延时时钟数 00:2个时钟;01:3个时钟;10:4个时钟 SCAN:列地址位数 00:8位;01:9位;10:10位,3、BANK6/7-存储器组6/7控制寄存器,back,19,REFEN:刷新控制。1:使能刷新;0:禁止刷新 TREFMD:刷新方式。1:自刷新0:自动刷新 Trp:设置SDRAM行刷新时间(时钟数) 00:2个时钟;01:3个;10:3个;11:4个时钟 Tsrc:设置SDRAM行操作时间(时钟数) 00:4个时钟;01:5个;10:6个;11:7个时钟 注: SDRAM的行周期=
10、 Trp + Tsrc。 Refresh_count:刷新计数值,4、REFRESH-刷新控制寄存器,20,Refresh_count:刷新计数器值 计算公式: 刷新周期=(211- Refresh_count+1)/HCLK 例子:设刷新周期=15.6s,HCLK=60MHz 则刷新计数器值=211+1-6015.6=1113 1113=0 x459=0b10001011001,back,21,高24位未用。 BURST_EN:ARM突发操作控制 0:禁止突发操作;1:可突发操作 SCKE_EN:SCKE使能控制SDRAM省电模式 0:关闭省电模式;1:使能省电模式 SCLK_EN:SCLK
11、省电控制,使其只在SDRAM访问周期内使能SCLK 0:SCLK一直有效;1:SCLK只在访问期间有效 BK76MAP:控制BANK6/7的大小及映射,5、BANKSIZE-BANK6/7组大小控制寄存器,22,BK76MAP:控制BANK6/7的大小及映射 100:2MB;101:4MB; 110:8MB 111:16MB; 000:32MB;001:64MB 010:128MB,back,23,WBL:突发写的长度。0:固定长度;1:保留 TM:测试模式。00:模式寄存器集;其它保留 CL:列地址反应时间 000:1个时钟;010:2个时钟; 011:3个时钟;其它保留 BT:猝发类型 0
12、:连续;1:保留 BL:猝发时间000:1个时钟;其它保留,6、MRSRB6/7-BANK6/7模式设置寄存器,24,head.s ENTRY(memsetup) movr1, #MEM_CTL_BASE adrlr2, mem_cfg_val addr3, r1, #52 1:ldrr4, r2, #4 strr4, r1, #4 cmpr1, r3 bne1b movpc, lr mem_cfg_val: .longvBWSCON .longvBANKCON0 .longvBANKCON1 .longvBANKCON2 .longvBANKCON3 .longvBANKCON4 .long
13、vBANKCON5 .longvBANKCON6 .longvBANKCON7 .longvREFRESH .longvBANKSIZE .longvMRSRB6 .longvMRSRB7,smdk2410.h /* initial values for DRAM */ #define MEM_CTL_BASE 0 x48000000 #define vBWSCON0 x22111110 #define vBANKCON00 x00000700 #define vBANKCON10 x00000700 #define vBANKCON20 x00000700 #define vBANKCON3
14、0 x00000700 #define vBANKCON40 x00000700 #define vBANKCON50 x00000700 #define vBANKCON60 x00018005 #define vBANKCON70 x00018005 #define vREFRESH0 x008e0459 #define vBANKSIZE0 xb2 #define vMRSRB60 x30 #define vMRSRB70 x30,VIVI For s3c2410中Bootloader之存储器初始化,25,;Tacc 10:8 存取周期 110 = 10 clocks 111 = 14
15、clocks,;Bank1,3 16位,其余32位,For 44b0 x中Bootloader之存储器初始化,26,5.2.2 Flash,FLASH存储器又称闪存,是一种可在线多次擦除的非易失性存储器,即掉电后数据不会丢失。FLASH存储器还具有体积小、功耗低、抗振性强等优点,是嵌入式系统的首选存储设备。 FLASH存储器主要分为两种,一种为NOR型FLASH,另一种为NAND型FLASH 。,一、概述,27,(1) 接口差别 NOR型FLASH采用的是SRAM接口,提供有足够的地址引脚来寻址,可以很容易地存取其片内的每一个字节; NAND型FLASH使用复杂的I/O口来串行地存取数据,各个
16、产品或厂商的方法可能各不相同。通常是采用8个引脚来传送控制、地址和数据信息。 (2) 读写的基本单位 NOR型FLASH操作是以“字”为基本单位; NAND型FLASH操作是以“页面”为基本单位,页的大小一般为512字节。 (3) 性能比较 NOR型FLASH的地址线和数据线是分开的,传输效率很高,程序可以在芯片内执行。NOR型的读速度比NAND型稍快一些; NAND型的写入速度比NOR型快很多(由于NAND型读写的基本单位为“页面”,所以对于小量数据的写入,总体速度要比NOR型慢);,二、NOR型与NAND型FLASH的区别,28,(4) 容量和成本 NAND型FLASH具有极高的单元密度,
17、容量可以做得比较大,加上其生产过程更为简单,价格也就相应地降低了。 NOR主要应用在代码存储介质中,NAND适合于数据存储,NAND在CompactFlash、Secure Digital、PC Cards和MMC存储卡市场上所占份额最大。 (5) 软件支持 在NOR型FLASH上运行代码不需要任何的软件支持,而在NAND型FLASH上进行同样操作时,通常需要驱动程序,也就是内存技术驱动程序MTD (Memory Technology Drivers)。NAND型和NOR型FLASH在进行写入和擦除操作时都需要MTD(说明,MTD已集成在FLASH芯片内部,它是对FLASH进行操作的接口)。,
18、29,这里以SST39VF160为例,介绍NOR型FLASH存储器的结构及操作。 SST39VF160是SST公司的CMOS多功能FLASH(MPF)器件,存储容量为2M字节,16位数据宽度(即一个字为2字节),工作电压为2.73.6V。SST39VF160由SST特有的高性能SuperFlash技术制造而成,SuperFlash技术提供了固定的擦除和编程时间,与擦除/编程周期数无关。芯片管脚配置如下图所示。,三、NOR型Flash存储器,30,SST39VF160管脚描述,NOR型FLASH存储器采用的是SRAM接口,其地址线和数据线是分开的。,31,SST39VF160工作模式选择,32,
19、NOR型FLASH存储器容量越来越大,为了方便数据管理,将FLASH划分为块(Block),每个块又分成扇区(Sector)。 SST39VF160的块大小为32K字,扇区大小为2K字。 读操作,可以对任何地址的任何字节进行,不受限制; 写操作,以字形式进行编程。编程前包含字的扇区必须完全擦除; 擦除操作,以扇区(2K)、块(32K)或全片为单位进行擦除。 擦除后数据变为0 xFF。,33,SST39VF160的存储器操作由命令来启动。命令通过标准微处理器写时序写入器件。,34,内部操作状态检测: SST39VFl60提供两种软件方式来检测内部操作是否完成。软件检测方式涉及两个状态位:利用数据
20、轮询特性Data Polling bit(DQ7)和跳转位特性Toggle bit(DQ6)。 在WE的上升沿,写入结束检测功能被使能,同时内部写入或擦除操作也被初始化。 这里只介绍Toggle bit方式。 在内部写入或擦除的过程中,任何对DQ6连续的读操作都会产生一个不断翻转的1和O。当内部写入或擦除完成时,DQ6位将停止翻转。,void Waitfor_endofprg(void)volatile unsigned int old_Status,now_Status;old_Status= * (volatile unsigned short *)0 x00);/从任意地址读出数据whi
21、le(1) new_Status=*(volatile unsigned short*)0 x00): /从同一地址读出数据 if(old_Status,150,void Test_Iic(void) unsigned int i,j; static U8 data256; Uart_Printf( IIC Test using AT24C02 n); rGPEUP |= 0 xc000; /Pull-up disable rGPECON |= 0 xa00000; /GPE15:IICSDA /GPE14:IICSCL rIICCON = (17) | (06) | (15) | (0 xf
22、); rIICADD = 0 x10; /2410 slave address = 7:1 rIICSTAT = 0 x10; /IIC bus data output /enable(Rx/Tx),151,Uart_Printf(Write test data into AT24C02(0-255)n); for(i=0;i256;i+) _Wr24C02(0 xa0,(U8)i,i); for(i=0;i256;i+) datai = 0; Uart_Printf(nRead test data from AT24C02n); for(i=0;i256;i+) _Rd24C02(0 xa0
23、,(U8)i,存储器地址,所写数据,存储器地址,存储数据,152,for(i=0;i16;i+) for(j=0;j16;j+) Uart_Printf(%2x ,datai*16+j); Uart_Printf(n); ,153,void _Wr24C02(U8 slvAddr,U8 addr,U8 data) rIICDS = slvAddr; /发送从设备地址 rIICSTAT = 0 xf0; /启动发送 while(rIICCON /清除中断状态.,154,while(rIICCON /等待结束生效 ,155,I2C写AT24C04程序 /* * name:Wr24C040 * fu
24、nc: Write data to 24C04O * para: slvAddr-chip slave address * addr:data address * data:data value */ void Wr24C040(U32 slvAddr,U32 addr,U8 data) iGetACK= 0; /*Send control byte*/ rIICDS = slvAddr; /0 xa0 rIICSTAT=0 xf0; /Master Tx,Start while(iGetACK=0);/wait ACK iGetACK=0; /* send address */ rIICDS
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 s3c2410 嵌入式 系统 硬件 结构设计
限制150内