历史上的今天
返回首页

历史上的今天

今天是:2025年02月17日(星期一)

正在发生

2018年02月17日 | 基于ARM 的嵌入式系统与CF卡存储技术

2018-02-17 来源:eefocus

      1 引言

      随着应用需求的不断提高,许多嵌入式系统在应用时都要求带有扩展的大容量存储器来存储数据。CF 卡(ComPACt Flsah Card)由于价格便宜、存储容量大、体积小、兼容性好等优点被广泛应用于嵌入式产品。然而现有的CF 卡接口电路存在接口复杂,稳定性不高等缺点,不能满足客户的需求。通过深入研究ARM 处理器AT91RM9200 的外部总线接口(EBI)、CF 卡和CPLD 的工作原理,提出利用CPLD来改进CF 卡接口电路以解决现有接口电路中存在的缺点。

     2 器件简介

     2.1 外部总线接口

      系统采用了以ARM920T 为内核的AT91RM9200作为微处理器,它是完全围绕ARM920T Thumb 处理器构建的系统。它有丰富的系统与应用外设及标准的接口,包括一个高速片上SRAM 工作区及一个低等待时间的外部总线接口(EBI)以完成应用所要求的片外存储区和内部存储器映射外设配置的无缝连接。外部总线接口结构如图1 所示。

外部总线接口结构

     EBI 通过集成电路支持CF 卡与SmartMedia 协议,从而极大地降低了对外部组件的需求。此外,EBI可处理多达8 个外设的数据传输,每个外设分配8 个在内置存储控制器中定义的地址空间。数据通过16 位或32 位数据总线进行传输,地址总线高达26位,8个芯片选择口(NCS[7:0])和在不同外部存储控制器间复用的多个控制引脚进行复用。

 

  2.2 CF 卡

 

  CF 卡(Compact Flash Card)是采用Flash Memory技术的存储卡,具有体积小、价格低廉、兼容性强、存储量大等优点。CF 卡支持三种接口模式,分别是PCCard Memory Mode、PC Card I/O Mode、True IDEMode。因为True IDE Mode 不经常使用,故接口电路以PC Card Memory Mode 和PC Card I/O Mode设计。

 

  2.3 CPLD

 

  CPLD(Complex Programmable LogIC Device)是一种较PLD 复杂的逻辑元件[2],是一种用户根据各自需要而自行构造逻辑功能的数字集成电路。其基本设计方法是借助集成开发软件平台,用原理图、硬件描述语言等方法,生成相应的目标文件,通过下载电缆(“在系统”编程)将代码传送到目标芯片中,实现设计的数字系统。

 

  该文采用的CPLD 是ALTEra 公司的MAX7000S系列的EPM7128SQL100-10。它有84 个引脚,其中5 根用于ISP(IN System Programmable)下载,可方便的对其进行“在系统”编程。EPM7128SQL100-10支持对电压工作,可以利用Altera 公司的第四代开发平台qUARTus Ⅱ方便地进行仿真、综合和下载。

 

  3 硬件接口电路设计

 

  硬件接口电路的电路图如图2 所示。在此电路中用CPLD 来实现一般CF 卡接口电路中的双向缓冲器和与非门等一些逻辑器件的逻辑功能,使接口电路变的更为简单、稳定、高速,而且可以通过现场修改程序来实现不同的功能。

 

rtrt

 

  CF 卡中的_CD1、_CD2 是CF 卡是否安装的状态检测信号,在CF 卡中接地。当CF 卡没有安装时,电路中_CD1、_CD2 由上拉电阻将其输出拉为高电平;当CF 卡安装时,_CD1、_CD2 由CF 卡接地输出为低电平,_CD1、_CD2 相当于CF 卡的总开关。在实际接口电路中_CD1、_CD2 要接10 kΩ 的上拉电阻。

 

  将片选任务寄存器的CS4A 编程为1 则可使能EBI 的复用引脚NCS4/CFCS、NCS5/CFCE1、NCS6/CFCE2 为CompactFlash 信号CFCS、CFCE1、CFCE2,使能NOE/NRD/CFOE、NWR0/NEW/CFWE、NWR1/NBS1/CFIOR、NWR3/NBS3/CFIOW、A25/CFRNW为Compact Flash 信号CFOE、CFWE、CFIOR、CFIOW、CFRNW。这样就可以通过访问保留给NCS4 的地址空间来访问外部的CF 卡。在NCS4 的地址空间中用当前的传输地址来分辨I/O 模式,通用存储模式是标志存储模式。传输地址总线的A23 用作I/O 模式选择。该文CF 卡用A22/REG 来分离通用存储模式和标志存储模式。

 

  在I/O 模式下,CompactFlash 的逻辑驱动CFIOR与CFIOW 信号上SMC 的读写信号,此时CFOE 与CFWE 信号失效。同样在通用存储模式和标志存储模式下驱动CFOE 与CFWE 信号上的SMC,CFIOR与CFIOW 信号失效。该逻辑如图3 所示。

 

454

 

  CFOE 与CFWE 通过CPLD 和CF 卡的OE 与WE连接起来,这是CF 卡在Memory Mode 的读写使能。

 

  CFIOE 与CFIOW 通过是I/O Mode 的使能。除了使能信号外,其他的信号对2 种模式都是相同的。

 

  CFCE1 与CFCE2 信号使能CF 卡的数据总线由上或是由下访问,具体信息见表1。只有当NCS4 引脚上的SMC 配置为驱动8 位存储器时才可进行奇字节访问,NCS4 地址空间中的片选寄存器必须如表1所示进行设置。

 

55

  _CD1、_CD2 为低电平时,CPU 的地址总线的低11 位A[10∶0]于CF 卡的地址总线A[10∶0]连通,CPU的数据总线的低16 位D[15∶0]与CF 卡的地址总线D[15∶0]连通。CPU 的A25/CFRNW 信号是数据流的方向的,NCS4/CFCS 信号是数据总线的传输使能。详细内容请参阅表2。

ere

  CPU 是高速器件,CF 卡是低速器件,在CPU 给CF 卡传输数据的时候就会发生因为接收速度慢而丢失数据的情况。所以需要用_WAIT 信号来延迟CPU 的发送,这样才能使CPU 的发送时序与CF 卡的接受时序匹配,使得数据的传输正确无误。实际电路中CF 卡的_WAIT 信号通过CPLD 来控制CPU 的NWAIT 信号,_WAIT 要接10 kΩ 的上拉电阻。RDY/BSY 是CF 卡的工作状态信号,当RDY/BSY 为1 时,CF 卡已经做好准备接收新的数据;当RDY/BSY 为0 时,CF 卡正在接受数据,这个信号也要接个10 kΩ上拉电阻。CF 卡的复位RESET 信号也是由系统的复位nRESET 信号在CPLD 中反相后产生的,以保持和系统的复位信号同步。

  4 CPLD 程序开发

  CPLD 程序在quartus Ⅱ下用Verilog HDL 语言编写。程序经过编译后,下载到CPLD 中固化。连接电路板和CF 卡,对CF 卡进行数据的读写操作,测试结果表明数据传输正确无误,且传输速率更高。

  5 结束语

  该文重点研究了如何利用CPLD 来连接基于ARM 的嵌入式系统与CF 卡。其中使用的CPLD 不但简化了接口电路,使其适合现场编程,同时改进的接口电路还适合产生各种复杂组合逻辑和时序逻辑。这种存储技术的正确性已在电路板上得到验证,它为基于ARM 的嵌入式系统的CF 卡存储提供了一种有效的解决方案。


推荐阅读

史海拾趣

Gould Fiber Optics公司的发展小趣事
根据实验需求选择合适的电源电路类型,如线性电源、开关电源等。线性电源输出稳定但效率低,适用于对纹波要求高的场合;开关电源效率高但纹波较大,适用于对效率要求高的场合。
FDK AMERICA公司的发展小趣事

随着环保意识的日益增强,FDK AMERICA公司积极响应绿色制造理念。公司投入大量资金研发环保型电子产品,采用环保材料和绿色生产工艺,减少对环境的影响。同时,公司还积极参与各类环保活动,倡导绿色消费理念。这种环保举措不仅提升了公司的社会形象,也为公司赢得了更多消费者的青睐。

DESIGNERSYSTEMS公司的发展小趣事

随着科技的快速发展,电子设备的设计要求越来越高。DESIGNERSYSTEMS公司投入大量研发资源,不断推动技术突破。他们成功开发出一套高效、智能的设计软件,能够大大提高设计效率和精度。这一技术突破使得DESIGNERSYSTEMS在电子设备设计领域具备了更强的竞争力,吸引了更多客户的合作。

Abilis Systems公司的发展小趣事

随着科技的快速发展,电子设备的设计要求越来越高。DESIGNERSYSTEMS公司投入大量研发资源,不断推动技术突破。他们成功开发出一套高效、智能的设计软件,能够大大提高设计效率和精度。这一技术突破使得DESIGNERSYSTEMS在电子设备设计领域具备了更强的竞争力,吸引了更多客户的合作。

台湾晶豪(ESMT)公司的发展小趣事

随着电子行业的不断发展,晶豪科技也积极应对市场变化。公司扩大代工厂的晶圆开工规模,以满足不断增长的客户需求。这一举措不仅使公司能够更灵活地应对市场波动,还为客户提供了更稳定的产品供应。同时,随着晶圆开工量的增加,公司的销售额也实现了稳步增长。

Agilent Technologies公司的发展小趣事

随着电子行业的不断发展,晶豪科技也积极应对市场变化。公司扩大代工厂的晶圆开工规模,以满足不断增长的客户需求。这一举措不仅使公司能够更灵活地应对市场波动,还为客户提供了更稳定的产品供应。同时,随着晶圆开工量的增加,公司的销售额也实现了稳步增长。

问答坊 | AI 解惑

用放大器搭个双向带自锁efuse

    功能是,u1-vout(输出过高)过流后 q2d 立马就关掉了 lock被拉高 当reset将lock拉低后,又可以恢复保护 芯片大致手册如下:        主要是支持单电源比较方便   ...…

查看全部问答>

学Verilog时候的错题合辑

Verilog错题合辑(1) 1.Always语句错误 always@( posedge sclk or nss) ❌ always@( posedge sclk or posedge nss) ✔     在always 语句里不能既 用posedge 这种 ...…

查看全部问答>

请问2个二极管中间1个电容,这样的电路会烧电容吗?

左边+7V是常用电源,电流比较小,但是始终在,右边+5V正常悬空,有时候会插入,电流较大, 右边的+5V会另外通过个MOS管控制断开左边的+7V,也就说正常C1上面是7V的,当5V插入的时候,7V会断开, 如果+5V的通断频率太高,会不会烧C1这个电容? ...…

查看全部问答>

EEWorld邀你来拆解(第7期)——拆拆减肥利器----开箱

本帖最后由 吾妻思萌 于 2022-11-16 22:10 编辑 很快就收到了减肥利器,前几天因为电脑坏了一直没来的及更新开箱,今天趁着电脑修好的功夫更新开箱。 收到了北京EEW的发来的邮包,迫不及待打开拿出了今天的主角跳绳 不得不说 ...…

查看全部问答>

本站的电子资源很丰富

本站的电子资源很丰富,可以找到很多自己喜欢的电子书之类的。值得点赞。 …

查看全部问答>

GD32F470 TLI 接口的DE频率如何设置

用GD32F470开发板的LCD Demo程序驱动AT070TN94 屏,结果是花屏,测了下DE 的频率是63us,厂家说调成35us,在demo 程序中哪里设置呢?求解答,谢谢! …

查看全部问答>

请问 ARM CONTEXT M0 免费提供的 除了核心 包不包括ADC FLASH 等部件

请问 ARM CONTEXT M0 免费提供的 除了核心 包不包括ADC  FLASH 等部件 …

查看全部问答>

低功耗电流采样基于OPA501

低功耗电流采样        在日常生活中TWS(真无线蓝牙耳机)已经非常之常见,事实上也非常方便,实在是太香了,除了容易掉,我已经掉了两TWS~那只能拜拜了~家境贫寒的我已经不能再买TWS耳机了。   人 ...…

查看全部问答>

求分析:做的升压电路板有声音,不知道是怎么解决好的

已经量产的板子,客户遭到投诉有滋滋的声音,拿到公司,查也没有查出来, 后面观察到板子有一个为了省成本,有一个驱动IC 没要,后面加上去了,就解决了, 现在是做的升级版,加了一套升压进去,工作电流也翻了一倍,之前是1A , 现在是2A ...…

查看全部问答>

小智科普丨同步整流基本原理

导语:同步整流技术采用通态电阻极低的电力MOSFET来取代整流二极管,能大大降低整流电路的损耗,提高DC/DC变换器的效率,满足低压、大电流整流器的需要。本文将从同步整流电路的原理图着手,介绍了电力MOSFET的反向电阻工作区及同步整流技术的基本 ...…

查看全部问答>