基于ARM920T微处理器的IDE硬盘接口设计与实现

基于arm920t微处理器的ide硬盘接口设计与实现
1 引言
20世纪90年代后期,嵌入式系统在工业控制、远程监控和数据采集等领域的应用日趋广泛,人们对嵌入式系统的存储容量也提出了较高的要求。因此研制适用于嵌入式系统的大容量、高速率、高可靠性的数据存储系统变得日益重要。本文针对一款基于arm920t芯片的开发板,根据ata硬盘接口规范,设计了ide硬盘接口电路,实现了对ide硬盘的读写,可以在linux系统中对其上的文件系统自由访问,达到了高速率和高可靠性的要求。
2 arm920t与s3c2410介绍
arm 包括一系列微处理芯片技术。arm920t是arm系列微处理器的一种,它采用5阶段管道化arm9tdmi内核,同时配备了thumb扩展、embeddedice调试技术和harvard总线。在生产工艺相同的情况下,性能可达arm7tdmi芯片的两倍之多。arm920t系列主要应用于机顶盒产品、掌上电脑、笔记本电脑和打印机。
s3c2410处理器是samsung 公司基于arm公司的arm920t处理器核,采用0.18umsu造工艺的32位微控制器。该处理器拥有独立的16kb指令cache和16kb数据cache、mmu、支持tft的lcd控制器、nand闪存控制器、3路uart、4路dma、4路带pwm的timer、i/o口、rtc、8路10位adc、touchscreen接口、iic-bus接口、iis-bus接口、2个usb主机、1个usb设备、sd主机和mmc接口和2路spi。s3c2410处理器最高可运行在268mhz。
3 ide接口及其规范
ide(integrated drive electronics)是从ibm pc/at上使用的ata接口发展而来的。ide/ata磁盘驱动器与早期的ata驱动器相比,增加了任务文件寄存器,包括数据寄存器、状态寄存器以及反映地址的驱动器号、磁头号、道号和扇区号寄存器等。ata接口规范定义了信号电缆和电源线的电器特征、互联信号的电器和逻辑特征,还定义了存储设备中可操作的寄存器以及命令和协议。
3.1
寄存器
规范定义了两组寄存器:命令寄存器和控制寄存器。命令寄存器用来接收命令和传送数据,控制寄存器用来控制磁盘操作。常用的寄存器包括数据寄存器、命令寄存器、驱动器/磁头寄存器、柱面号寄存器、扇区号寄存器、扇区数寄存器和状态寄存器。
3.2
数据传输方式
ata接口规范定义了两种数据传输方式:可编程i/o(pio)方式和dma方式。pio传送方式下,cpu对控制器的访问都是通过pio进行的,包括从控制器读取状态信息和错误信息,以及向控制器发送命令和参数。在一次pio数据传输过程中,cpu先选址,然后使读/写信号有效,cpu或控制器放数据到数据总线,控制器或cpu读取数据,操作完成后,释放总线,这样一次数据传输完成。dma方式,即直接内存访问,cpu把缓冲区的地址与需要读写的长度告诉外设,外设在准备好后向cpu发出一个dma请求,要求cpu暂停使用内存,获得同意后就直接在内存和外设之间传输数据,完成后再把对内存的访问权归还给cpu。
4 硬件实现
如图1所示,s3c2410与硬盘之间接口电路分为3个部分:片选信号、数据信号和控制信号。硬盘上寄存器分为两组,分别由ide_cs0和ide_cs1选中,da0~da2则用于组内寄存器寻址;数据线dd0~dd15因存在输入/输出方向问题,故用noe(读信号)接buffer(74lvth162245)的dir引脚来控制缓冲器方向;控制信号部分因该cpu与硬盘之间dma时序不一致,故采用一块epm7032aetc44-7芯片用于调整其时序。pio模式下,不需要dmarq和ndmack信号,dma模式下,这两个信号才起作用。
5 软件实现
硬盘驱动程序实现分为初始化、打开设备、设备i/o操作和释放设备等几部分。
5.1
硬盘初始化与x86不同,在arm
体系结构中,对内存和外设的访问使用统一的指令,所以要对外设地址进行内存映射。也就是说,通过一张表将i/o地址映射到内存空间中来,这部分工作是在系统初始化期间完成的。
在ide子系统初始化期间,linux系统一旦发现一个ide控制器,就设置它的ide_hwif_t结构来反映这个控制器和与之相连的磁盘;向linux的vfs登记每一个控制器,并分别把它加到blk_dev和blkdevs向量表中;请求控制适当的irq中断(主ide控制器是14,次ide控制器是15)和i/o空间(主控制器0x1f0,次控制器0x170):为每一个找到的ide控制器在gendisk列表中增加一个条目。
ide硬盘的初始化工作由idedisk_init完成:
(1)在数组ide_hwifs中找出已登记得各ide控制器控制的所有ide硬盘(一个控制器最多控制两个硬盘),每个ide硬盘对应一个ide_drive_t结构。
(2)对找到的每个ide硬盘,调用函数ide_register_subdriver填写各ide硬盘结构中的相关信息域,主要是填写其驱动程序结构ide_driver_t。硬盘驱动中的函数do_rw_disk通过向磁盘控制寄存器写参数启动磁盘操作,完成真正的数据读写。
(3)对找到的每个ide硬盘,调用函数idedisk_setup进一步设置其ide_drive_t结构,包括设置该结构的settings域、doorlocking域、cyl、head、sect域、id域等。
5.2
打开设备
打开块设备的操作与打开普通文件的操作基本相同。
(1)在当前进程的文件描述符表中为打开文件找一个空位,申请一块内存,用于建立新文件的打开文件对象,即结构file。
(2)解析设备特殊文件名,获得其vfsinode和dentry结构,根据dentry结构填写file结构,尤其是将file结构的f_op域设为其vfsinode中的缺省文件操作。
(3)执行该文件操作集中的open操作,即blkdev_open,它根据设备特殊文件的主次设备号从blkdevs向量表中取出已经注册的文件操作集(file_operations)fops,用该结构代替file结构中的f_op域。
(4)执行中新文件操作集中的open操作,即bl带头kdev_open,它根据vfs
inode中的i_rdev域查找数组ide_hwifsp[],从中找出该ide硬盘所对应的ide_drive_t结构;如果ide_drive_t结构中注册有驱动程序,执行驱动程序集中的open操作。
(5)将打开文件对象插入到当前进程的文件描述符表中,返回文件描述符,即打开文件对象在进程文件描述符表中的索引。
5.3
设备i/o操作
读写块设备时要用到块缓冲区(bufer),对bufer的管理采用bufercache机制。它管理bufer的创建、撤销、回收、查找、更新等,同时还要与系统中的其它部分(如文件系统、内存管理等)交互。linux将buffer
cache从块设备驱动程序中独立出来,作为对块设备读写的通用机制,所以对块设备的读、写、同步等操作采用的都是由操作系统提供的公共函数,一般为block_read()和block_write()。
为了减少对块设备操作的次数,读写块设备时采用延迟操作,尽量将多个读写操作合并,所以操作请求不是马上递交给物理设备,而是提供了一种手段记录每次的请求(request),并为每类块设备提供一个请求队列用来排队、合并、重组对该块设备的请求。
当需要从硬盘读时,block_read()函数首先查找buffer cache
如果在其中能找到需要的buffer,则立刻返回:否则,生成一个读请求,并将其加入相应的请求队列排队。
当需要向硬盘写时,block_write()为此次写操作生成一个buffer,而后生成一个写请求,并将其加入相应的请求队列排队。
块设备驱动程序提供了一个请求处理函数,对硬盘而言是函数do_rw_disk。在适当的时候,硬盘的请求处理函数启动,do_rw_disk处理在请求队列上排队的请求,通过向硬盘发出读、写命令完成对设备的真正操作。其伪代码如下:
c程序
5.4 释放设备
由设备驱动程序中的release操作完成,一般完成与打开设备相反的动作:释放打开设备特殊文件时在file结构上所创建的私有结构;如果是最后一个设备的释放,则从硬件上关闭设备。
6 结束语
通过上述方法对ide硬盘接口的设计与实现,我们可以在s3c2410开发板上安全自由地对硬盘上的各种文件系统进行访问,由于采用dma方式,可以满足用户对速率的要求。

模组中的贵族—KK模组的替换品牌
LED广告机的发展趋势分析
微软称Windows 7销量已达9000万
紫光计算机新品发布会已定档,塑国产商用计算机新势力
如何回收直流电机驱动中的能量呢?
基于ARM920T微处理器的IDE硬盘接口设计与实现
一加7售价疑似曝光 最低售价折合人民币约3800元
比TrustZone更可靠?全新加密技术PUF提升物联网信息安全
安全光栅的安装与调试
红外光电开关电路原理图
MCP存储器以及MCP存储器的应用介绍
各种气体传感器的性能特点
苹果iOS10.3三天两个测试版:是为解决Beta6的流畅性倒退,可省2GB空间功能666!
用于无人机的检测的FMCW雷达
华润微电子建设12英寸集成电路生产线一期总投资220亿
OTP语音芯片在人脸识别门锁的应用方案
性别偏见探索和缓解的中文数据集-CORGI-PM
三星屏下摄像头新专利 采用隐藏式前置摄像头方案
触摸屏物体识别技术有哪些 触摸屏怎么区分电容屏和电阻屏
6.5W导热凝胶进入军工显示器领域