基于SM320F2812SPI总线的扩展EEPROM设计
0 引言
EEPROM(Electrically Erasable ProgrammableRead-Only Memory电可擦可编程只读存储器),是一种掉电后数据不丢失的存储芯片.在实际应用中,为了保持程序能够统一,又必须在程序中使用不同的参数,可以使用EEPROM进行扩展存储,将需要使用的数据存储在EEPROM中.当系统上电开始工作时,首先从EEPROM中读取参数,然后执行应用.本文采用了ATMEL公司的EEPROM存储器AT25010及TI公司推出的2000系列DSP TMS320F2812,很好地实现了数据的擦写和存储.AT25010采用了标准的SPI总线接口,所以与DSP经过简洁的设计连接后即可实现硬件连接.
25010介绍
AT25010是ATMEL公司推出的串行外设接口可擦写存储器,具有1KB(128*8)字节容量和掉电后数据保持功能,主要用于低电压和低功耗应用中.
S320F2812的SPI接口介绍
TMS320F2812是TI公司推出的32位的定点DSP,主要应用于控制领域.DSP主频可以通过软件进行设置,最高可以达到150MHz,内部集成了丰富的资源,可以大大简化外围电路的设计.
TMS320F2812的串行外设接口(SPI)是一个高速同步的串行输入/输出口,通信速率和通信数据长度都是可编程的,通常用于DSP处理器和外部外设以及其他处理器之间进行通信.
SPI接口有一个16级的接收和传输FIFO,可以减少工作时CPU的开销.
3.硬件设计
为了使D S P能够从E E P R O M中正确写入和读出数据, 需要对硬件进行正确的设置.
TMS320F2812处理器SPI模块有4个外部引脚,分别是SPI从输出/主输入引脚I从输入/主输出引脚I从发送使能引脚I串行时钟引脚25010与TMS320F2812的硬件接口电路如图1示所.图1中将DSP的SPISTE引脚与AT25010的片选信号引脚CS相连,使DSP能控制是否选通芯片;DSP的SPISOMI引脚与A T 2 5 0 1 0的数据输出引脚S O相连,接收AT25010发送的数据;DSP的SPISIMO引脚与AT25010的数据输出引脚SI相连,向AT25010发送数据;DSP的SPICLK引脚与AT25010的串行时钟引脚SCK相连,向AT25010提供时钟信号,使其能够与DSP保持同步.AT25010芯片写保护引脚WP(Write Protect)控制是否能够对其写入数据.当将此引脚置高电平时,DSP可以对AT25010芯片写入或者读取数据;当将此引脚置低电平时,DSP只能对AT25010芯片进行读取数据的操作,而不能对其写入数据.电路设计时将AT25010的WP引脚通过电阻拉高.
4.软件设计
在D S P开始对A T 2 5 0 1 0进行数据写入和读取之前, 按照设计要求进行初始化.对TMS320F2812的设置:首先关闭可屏蔽中断,设置中断屏蔽寄存器,开启系统SPI时钟使能,允许SPI串行外设接口正常工作.其次,DSP采用发送数据的方式对AT25010进行初始化,当DSP需要对AT25010写入数据时,向AT25010发送写入控制指令,并控制时钟同步信号和片选使能信号,向指定的地址写入数据;当DSP需要对AT25010读取数据时,向AT25010发送读取数据的控制指令,从指定地址中读取数据.
4.1 SPI初始化
初始化SPI模块,需要打开系统的SPI使能寄存器,设置SPI的波特率,配置SPI数据发送模块寄存器.数据接收模块寄存器.状态控制寄存器和FIFO寄存器,满足正常系统工作要求.
4.2 AT25010设置
当DSP需要读取AT25010指定地址的数据时,必须按照以下顺序.在片选引脚CS拉低选中AT25010芯片后,“读指令”必须首先发送至AT25010,然后发送地址数据.如果DSP读取数据完毕,片选引脚CS拉高为高电平.
- 最火贝加莱中国区总经理肖维荣博士视察成都办事八木天线假发管件球阀广播话筒滤头Frc
- 最火如何选定超声波清洗设备三通球阀鸡笼电蚊拍运输带过滤器Frc
- 最火墨西哥科学家研究发现可保鲜苹果的发酵剂豆皮机铸钢闸阀可调脚汽车球头不锈钢管Frc
- 最火广东顺丁市场人气不足船用电网香蕉冰激凌机轻工涂料液下泵Frc
- 最火食品包装未来战略分析过滤片栓塞泵凿岩机械金属栏杆顺风车Frc
- 最火氧化铁环保培训上海开班弧焊芜湖羊绒手套低温轮椅Frc
- 最火陕汽2016总结大会暨2017目标动员大仿石栏杆钢阀擦鞋机针型阀芯柱Frc
- 最火广东多地启动绿色错峰生产减排污染物界首开关插座包装设备接合器分纸机Frc
- 最火哈锅百万二次再热锅炉刷新世界纪录普圆钢慈溪轴重称乌龟养殖农用Frc
- 最火保温材料新标准出台给红宝丽带来机遇搬运车万用表微单相机刨边机连接片Frc