一種基於ARM920T的IDE硬碟接口設計方案

2021-01-16 電子產品世界

  1 引言

本文引用地址:http://www.eepw.com.cn/article/248670.htm

  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方式,可以滿足用戶對速率的要求。

相關焦點

  • 基於ARM920T微處理器的IDE硬碟接口設計與實現
    本文針對一款基於ARM920T晶片的開發板,根據ATA硬碟接口規範,設計了IDE硬碟接口電路,實現了對IDE硬碟的讀寫,可以在Linux系統中對其上的文件系統自由訪問,達到了高速率和高可靠性的要求。2 ARM920T與S3C2410介紹ARM 包括一系列微處理晶片技術。
  • SST55VD020ATA/IDE 接口快閃記憶體固態硬碟設計方案
    ATA Flash Disk 固態硬碟設計方案同時可以製造成為 3.5 寸臺式機、伺服器的 ATA/IDE 固態硬碟,或 2.5 寸筆記本 ATA/Mini IDE 固態硬碟、移動固態硬碟,也可以成為 CF 卡的設計基礎方案。
  • 硬碟串口IDE與並口SATA接口之比較
    IDE 是傳統的並行接口ATA硬碟,但在實際的應用中,人們也習慣用IDE來稱呼最早出現IDE類型硬碟ATA-1,這種類型的接口隨著接口技術的發展已經被淘汰了,而其後發展分支出更多類型的硬碟接口,比如ATA、Ultra ATA、DMA、Ultra DMA等接口都屬於IDE硬碟。
  • 從IDE到NVMe:淺談硬碟接口協議標準的發展史
    作為存儲重要資料的載體,硬碟從誕生到現在都是電腦的重要組成部分,而無數的硬碟構成了整個網際網路社會,而每一個消費者的電腦中也有數塊硬碟,而硬碟也從傳統的機械硬碟一直進化到如今的SSD,那麼在過去的幾十年內,硬碟的接口標準究竟經歷了多少次變化?未來能否有更先進的接口標準推出?
  • IDE轉接USB 新型轉接器通吃硬碟光碟機_USB2.0接口,移動存儲,IDE硬碟...
    CNET中國·ZOL報導:近日,Kama公司開發了一種可以直接連接IDE設備的轉接器——SCPUS-1000。它可以讓用戶直接通過USB2.0接口將電腦硬碟或者光碟機連接起來,SCPUS-1000非常小巧,其大小大約有一塊普通的2.5英寸筆記本硬碟2/3那麼大。這對於經常外出或者需要複製數據的人來說是非常有用的。
  • 硬碟SATA接口的詳細解析
    SATA是主流硬碟接口之一,目前市面上SATA2.0和和SATA3.0都比較常見。雖然目前SATA的接口流行度顯然不能和之前比了,但是依然佔據著主流接口方案。(超薄SATA線纜組件,配帶電源和數據連接器)一、SATA的含義SATA全稱是SerialAdvanced Technology Attachment(串行高級技術附件,一種基於行業標準的串行硬體驅動器接口),是由Intel、IBM、Dell、APT、Maxtor和Seagate公司共同提出的硬碟接口規範。
  • 基於USB接口的區域網接入適配器的設計方案
    基於USB接口的區域網接入適配器的設計方案 程石;胡愛群;蔡 發表於 2020-04-04 10:53:00 目前,在區域網內部,計算機接入區域網的傳統方法是通過在計算機主板上安裝乙太網卡來實現網絡的互聯
  • SATA硬碟接口技術講解介紹
    在IDE和SCSI的大類別下,又可以分出多種具體的接口類型,又各自擁有不同的技術規範,具備不同的傳輸速度,比如ATA100和SATA;Ultra160 SCSI和Ultra320 SCSI都代表著一種具體的硬碟接口,各自的速度差異也較大。
  • 基於ARM的英文轉中文翻譯器設計
    因此,為了解決上述問題,根據實際工程項目應用需要,提出一種基於ARM的英文轉中文的翻譯器設計方案,該設計是在原有設備和支持中文列印的熱敏印表機之間增加一塊以ARM為核心的電路板作為英文轉中文的翻譯器,接收設備傳輸的英文數據,然後通過優化算法轉換成中文,能夠邊接收邊列印輸出。
  • 一種改進型的FIR數字濾波器設計
    根據這個描述就可以分析其頻率特性和相位特性,以驗證設計結果是否滿足指標要求;或者利用計算機仿真實現設計的濾波器,再分析濾波結果來判斷。 2 fir數字濾波器的傳統設計方法 傳統的fir數字濾波器設計流程分為2個部分:開發設計和產品實現。在開發設計部分完成方案設計和算法設計與驗證,一般用matlab語言進行仿真,當仿真結果滿意時,再進入產品的實現階段。
  • 一文看懂arm架構和x86架構有什麼區別
    什麼叫arm架構   ARM架構過去稱作進階精簡指令集機器(AdvancedRISCMachine,更早稱作:AcornRISCMachine),是一個32位精簡指令集(RISC)處理器架構,其廣泛地使用在許多嵌入式系統設計。由於節能的特點,ARM處理器非常適用於移動通訊領域,符合其主要設計目標為低耗電的特性。
  • 機械硬碟搭配SSD方案演示
    答案是能,但需要針對不同的機型,很多筆記本電腦通過置換光碟機位來實現固態硬碟的擴充,在不改變原有本盤的同時實現1+1方案。也就是說,如果你的電腦光碟機位配置SATA接口,那麼就是可行的,不搭配甚至根本沒有光碟機位的用戶此方案則無法實現。
  • 一種基於Arduino的光電編碼器檢測儀設計方案
    0 引言本文引用地址:http://www.eepw.com.cn/article/256786.htm  Arduino是一款基於單片機系統的電子產品開發平臺,它的軟硬體系統都具有高度的模塊化,而且軟體系統是完全開源的。
  • 帶你認識mSATA筆記本硬碟,看看筆記本硬碟都有哪些接口
    從外形尺寸、接口、厚度等認識筆記本電腦硬碟。筆記本硬碟接口:目前,市場上主流筆記本電腦硬碟都是新SATA接口硬碟,傳統的DE接口硬碟已經被淘汰,最新的筆記本硬碟接口是mSATA接口。(1)DE接口:也稱 Ultra ATA接口。早期的筆記本硬碟的接口方式主要是 Ultra ATA/DMA33,傳輸速率只有33MB,隨著筆記本硬碟轉速和容量的提高, Ultra ATA/DMA66/100/133也相繼運用到筆記本硬碟上。
  • 無線USB接口鍵盤控制器的設計方案
    本文介紹了一種基於USB接口的無線通訊鍵盤控制器的設計方案,包括硬體設計、設備驅動程序設計及應用軟體設計。為有效地解決這個問題,本文設計了一種可遠距離操控計算機的無線通訊鍵盤控制器設備,通過把USB接口與無線發送、接收模塊整合,設計出一種智能化、簡便化的無線通訊鍵盤控制器。系統主要包括USB模塊、無線發送模塊和無線接收模塊。
  • 詳述ARM控制逆變器電源電路設計方案
    本文將介紹一款基於ARM控制的逆變器電源電路設計方案及其應用。晶片還帶有豐富的通訊單元,包括1個乙太網接口、5個異步串行接口、1個USB從器件、1個CAN器件、I2C和SPI等模塊。  2.2 驅動和逆變電路  逆變主電路如圖2所示採用基於H橋的單相全橋逆變電路。單相全橋逆變電路主要由Q1、Q2、Q3、Q4四個MOSFET構成。
  • arm開發板與樹莓派有什麼區別
    ARM   ARM是英國的一個公司,主要設計ARM系列的處理器。   但是值得注意的是ARM公司通過出售晶片技術授權   也就是說ARM公司不做晶片的生產,只有買了這些技術授權的半導體公司才做晶片   我的個人理解是ARM提供處理器的核心技術方案,各個半導體公司加上自己的外設等等東西做成自己的晶片,所有採用arm提供技術授權的晶片都叫ARM   樹莓派   樹莓派是一種電路板子
  • 一種嵌入式Web伺服器的設計方案
    本文主要介紹了嵌入式Web伺服器設計方案,以及實現和主要應用。1.引言嵌入式Web伺服器(Embedded Web Server,EWS)是指將Web伺服器嵌入到現場測試和控制設備中,在相應的硬體平臺和軟體系統的支持下,使傳統的測試和控制設備轉變為具備了以TCP/IP為底層通信協議,Web技術為核心的基於網際網路的網絡測試和控制設備。
  • 專為希捷硬碟設計 傑科150i PLUS評測
    希捷傑科150i plus支持USM接口,採用了RTD1073方案設計。SATA國際標準組織SATA-IO正在著手開發一種新的接口標準「SATA Universal Storage Module」,簡稱「SATA USM」,意在為名目繁多的消費電子設備提供方便、統一的存儲接口。