當前位置:首頁 > 消費電子 > 消費電子
[導讀]本文提出了一種在以嵌入式系統(tǒng)、MCU為核心的消費類電子產(chǎn)品或工業(yè)產(chǎn)品中,將優(yōu)盤作為數(shù)據(jù)存儲器使用的設計方案,為在微計算機測控系統(tǒng)、儀器儀表、無紙化數(shù)據(jù)記錄儀、數(shù)碼相機等產(chǎn)品中添加優(yōu)盤外設功能提供有益的參考。

      引言

       隨著mp3播放器作為消費類產(chǎn)品的普及,MP3的設計與生產(chǎn)也越來越多。在當前的MP3播放器中,一般有以下幾種設計方案:

       ①  MCU內置硬解碼模塊。典型的芯片有Atmel公司的AT89C51SNDI等芯片。
       ②  外置獨立的MP3硬解碼芯片。此種方案的好處是可以使用眾多的MCU,可根據(jù)需要任意選擇。硬解碼芯片典型的有VS1011B、STA013等芯片。
       ③  使用功能強大的MCU進行軟解碼,如使用DSP或是高性能的ARM。此種方案較為靈活,通過軟件升級即可實現(xiàn)產(chǎn)品的升級。

       MP3播放器的存儲介質一般采用Flash存儲芯片。隨
著USB技術和閃存技術的發(fā)展,優(yōu)盤已經(jīng)成為一種大眾化的電子產(chǎn)品被廣泛使用,但優(yōu)盤一般只是作為PC的移動存儲器。本文研究的一種方案是在上述MP3設計方案②的基礎上,外擴優(yōu)盤讀寫電路,使存儲介質使用普通的優(yōu)盤。這樣可以解決普遍使用的優(yōu)盤只能作為PC外設存儲數(shù)據(jù)用的問題,使U盤的使用范圍擴展到MP3上。更大的意義還在于,本文提出了一種在以嵌入式系統(tǒng)、MCU為核心的消費類電子產(chǎn)品或工業(yè)產(chǎn)品中,將優(yōu)盤作為數(shù)據(jù)存儲器使用的設計方案,為在微計算機測控系統(tǒng)、儀器儀表、無紙化數(shù)據(jù)記錄儀、數(shù)碼相機等產(chǎn)品中添加優(yōu)盤外設功能提供有益的參考。

      1  硬件設計

      
S3C44B0X是Samsung公司開發(fā)生產(chǎn)的為嵌入式設備提供的一個低成本、高性能的ARM7TMDI核處理器,其最高運行頻率可達66 MHz。SL811HS是Cypress公司的一款遵從USB1.1協(xié)議的嵌入式Host/Slave USB芯片;可以支持低速和高速模式,能自動偵測低速模式1. 5 Mbps設備和高速模式12 Mbps全速設備。由于具有8位數(shù)據(jù)總線的支持,使該芯片可以較為簡單地與微控制器相連,SL811HS芯片與S3C44B0X的接口較為簡單。本系統(tǒng)中ARM讀/寫優(yōu)盤原理框圖如圖1所示。

優(yōu)盤讀/寫電路原理框圖

       SL811HS的控制命令和數(shù)據(jù)均通過D0~D7傳輸,A0為數(shù)據(jù)或地址選擇線。當A0置為低電平時,D0~D7上傳輸?shù)氖荢L811HS片內寄存器的地址;反之當A0置為高電平時傳輸?shù)膭t為數(shù)據(jù)。nWR、nRD、nCS、nRST0分別為寫控制線、讀控制線、片選線和復位線,S3C44B0X通過這幾根控制線完成對SL811HS片內緩沖區(qū)的讀寫、片選和復位等操作。INT是SL811HS的中斷請求信號線。當SL811HS檢測到優(yōu)盤插入、拔出時,通過將INT線拉高通知S3C44B0X。S3C44B0X可以通過查詢SL811HS片內狀態(tài)寄存器來得知是優(yōu)盤插入或是拔出。對狀態(tài)寄存器進行寫操作可以清除中斷,但需要注意的是ARM的結構特性。ARM內部通常是Little Endian方式存儲和使用4字節(jié)對齊方式[1],并且當采用16位數(shù)據(jù)總線時,地址線ADDR0是無效的[2]。在本系統(tǒng)中,SL811HS芯片A0端是與ADDR1相連接的。

       VS1011B是一款單芯片的MP3解碼芯片,在國際MP3業(yè)余愛好者中影響較大,集成解碼、A/D轉換、音頻放大等功能。VS1011B與S3C44B0X接口為SPI接口,其連接電路原理框圖如圖2所示。

VS1011B控制電路原理框圖

       VS1011B的控制與數(shù)據(jù)傳輸是通過SPI接口完成的,DREQ、xDCS、xCS、nRST1分別為數(shù)據(jù)請求端口、數(shù)字片選信號線、片選線、復位線。在VS1001B的新模式下,SDI(Serial Data Interface)數(shù)據(jù)和SCI(Serial Command Interface)數(shù)據(jù)傳輸可以共享ARM的一個SPI接口;而在兼容模式下,SDI數(shù)據(jù)傳輸要用DCLK、SDATA串行接口,SCI數(shù)據(jù)傳輸用SPI接口。為了簡化電路,此處選用了新模式。

       2  軟件設計

       2.1  優(yōu)盤讀寫軟件的實現(xiàn)

       USB組織定義了海量存儲設備類(mass storage class)的規(guī)范。這個類規(guī)范包括4個獨立的子類規(guī)范:USB Mass Storage Class Control/Bulk/Interrupt (CBI) Transport 、USB Mass Storage Class BulkOnly Transport、USB Mass Storage Class ATA Command Block、USB Mass Storage Class UFI Command Specification。其中優(yōu)盤屬于海量存儲設備,遵循bulkonly傳輸協(xié)議,子類采用UFI命令集。本設計軟件的總體結構如圖3所示。其中兩條點畫線之間的部分為讀/寫優(yōu)盤的軟件結構。

軟件總體結構圖

       2.1.1  USB物理層協(xié)議的實現(xiàn)

   

  該部分實現(xiàn)S3C44B0X對SL811HS芯片的直接底層數(shù)據(jù)的讀寫,包括對SL811HS的初始化及讀/寫一個字節(jié)的函數(shù)。限于篇幅,此處只列出對SL811HS芯片的初始化程序:

      /*********************************
        函數(shù)名稱:SL811_Init
        函數(shù)功能:初始化SL811HS芯片
        輸入?yún)?shù):無
        返回值:無
      *********************************/
      void SL811_Init(void){
        //初始化U盤為未插入狀態(tài)
        bFlags.bits.SLAVE_ONLINE = FALSE;
        bFlags.bits.SLAVE_FOUND = FALSE;
        bFlags.bits.SLAVE_REMOVED = FALSE;
        bFlags.bits.SLAVE_ENUMERATED = FALSE;
        bFlags.bits.SLAVE_IS_ATTACHED = FALSE;
        //允許硬件產(chǎn)生SOF(Start of Frame)
        SL811Write(CtrlReg,0x04);
        DelayMs(100);
        SL811Write(CtrlReg,0x01);
        //設置SOF,1 ms中斷
        SL811Write(cDATASet,0xe0);
        //設置為主機工作模式
        SL811Write(cSOFcnt,0xae);
        SL811Write(EP0Status,0x50);
        //地址設為0
        SL811Write(EP0Counter,0);
        //允許數(shù)據(jù)發(fā)送

SL811Write(EP0Control,0x01);
        SL811Write(IntEna,0x20);
        //清中斷
        SL811Write(IntStatus,INT_CLEAR);
      }

       2.1.2  USB設備協(xié)議層的實現(xiàn)

      
該部分實現(xiàn)對優(yōu)盤扇區(qū)的直接讀寫,其中兩個很重要的函數(shù)為Bulkin和Bulkout。此處只列出Bulkin函數(shù)的實現(xiàn):

       /**********************************
        函數(shù)名稱:epB
ulkRcv
        函數(shù)功能:實現(xiàn)bulkonly協(xié)議中的Bulkin函數(shù)
        輸入?yún)?shù):pBuffer為數(shù)據(jù)的地址,len為數(shù)據(jù)的長度
        返回值:TRUE為成功,F(xiàn)ALSE為失敗
      **********************************/
      unsigned char epBulkRcv(unsigned char *pBuffer,unsigned int len){
          usbstack.usbaddr=0x1;
          usbstack.endpoint=usbstack.epbulkin;
          usbstack.pid=PID_IN;
          //設置包長度為64
          usbstack.wPayload=64;
          usbstack.wLen=len;
          usbstack.buffer=pBuffer;
          if(usbstack.wLen){
            if(!usbXfer())
            return FALSE;
          }
        return TRUE;
      }

       2.1.3  FAT16/FAT32文件格式的實現(xiàn)

      
該部分程序是根據(jù)FAT16/FAT32文件系統(tǒng)的結構,實現(xiàn)對文件的讀、寫、創(chuàng)建、刪除等操作。優(yōu)盤上的數(shù)據(jù)按照其不同的特點和作用大致可分為5部分:MBR區(qū)(主引導記錄區(qū))、DBR區(qū)(系統(tǒng)引導記錄區(qū))、FAT區(qū)(文件分配表區(qū))、FDT區(qū)(文件目錄表區(qū))和DATA區(qū)(數(shù)據(jù)區(qū))。

       在實現(xiàn)對文件的讀/寫時,首先根據(jù)MBR區(qū)和DBR區(qū)的大小,找到FAT表的位置,然后根據(jù)FAT表找出相應文件的數(shù)據(jù)位置,即可對此文件進行相應的處理。其具體實現(xiàn)涉及FAT文件系統(tǒng)的結構,此處不再詳述。

      2.2  VS1011B的控制與音樂文件數(shù)據(jù)輸入

      
本方案mp3播放器的實現(xiàn)原理就是控制器 從優(yōu)盤讀取MP3文件數(shù)據(jù),當VS1011B的數(shù)據(jù)緩沖區(qū)需要數(shù)據(jù)時,將數(shù)據(jù)送入VS1011B進行解碼。VS1011B采用串行接口,有兩種接口模式:

       Native Modes(新模式)和Compatibility;
       Mode(兼容模式)。當?shù)刂窞?x0的MODE寄存器的SM_SDINEW位為1時為新模式;反之為兼容模式。上電時默認為新模式。

       在播放音樂之前,首先需要對VS1011B進行初始化,然后輸入音樂文件即可播放歌曲。其控制步驟如下:[3]

       ①  拉低nRST1。
       ②  等待DREQ引腳信號變高。
       ③  寫寄存器MODE的參數(shù),包
括正確設置SM_SDINEW和SM_SDISHARED位。
       ④  若時鐘數(shù)率非24.576 MHz,應設置SCI_CLOCKF。
       ⑤  若使用倍頻時鐘,試圖通過改變SCI_CLOCKF直接操作,應將適當?shù)牟蓸铀俾蕦懭隨CI_AUDATA寄存器,等待至少11 000個時鐘后才可以操作高速的SPI通信。
       ⑥  設置音量寄存器SCI_VOL。
       ⑦  若希望加強低音,可設置寄存器SCI_BASS。
       ⑧  從優(yōu)盤讀取一首MP3歌曲文件,并開始傳送音樂數(shù)據(jù)。應注意數(shù)據(jù)傳送的規(guī)則,DREQ信號是用來表示VS1011B的MP3數(shù)據(jù)緩沖區(qū)是否需要數(shù)據(jù)。當VS1011B的數(shù)據(jù)緩沖區(qū)可再接收32字節(jié)數(shù)據(jù)時,DREQ引腳電平變高。當軟件查詢到此引腳電平變高時,就再送入32個字節(jié)的MP3音樂數(shù)據(jù)。
       ⑨  本首歌曲完成播放,讀取下一首MP3歌曲,并轉到步驟⑧。

       結語

       本文介紹了使用優(yōu)盤存儲MP3歌曲文件的一種MP3播放器的設計,其中軟件設計的難度較大。此外VS1011B除支持MP3格式音樂文件外,還支持WAV格式等,改變一下軟件即可播放WAV文件格式的音樂。如果MP3播放器設計帶有液晶屏,則可以通過把相應的歌曲歌詞存儲在優(yōu)盤上,實現(xiàn)實時歌詞顯示等功能。

       雖然這里給出的只是優(yōu)盤在嵌入式系統(tǒng)中的一個應用示例,但在此基礎上很容易演變出別的功能。例如對本系統(tǒng)稍加改變,即可把優(yōu)盤換成USB移動硬盤,這樣可以有更大的存儲容量。在這種大存儲容量的基礎上,才能設計對存儲容量要求較大的MP4播放器、硬盤攝像機等。另外,本文的設計思路還可以應用在以嵌入式為核心的許多其他工業(yè)或消費類電子產(chǎn)品中,如數(shù)據(jù)采集保存器、數(shù)碼相機等,方便地實現(xiàn)與PC的數(shù)據(jù)交換。


參考文獻:
[1]  楊捷,徐志化.基于ARM7的無紙記錄儀的U盤讀寫方法[J].自動化儀表, 2006,27(1): 22-24.
[2]  劉曄波,朱欣華. SL811H/S在基于ARM7的嵌入式硬件平臺中的應用[J] .測控技術,2006, 25(10):74:77.
[3]  www.ouravr.com.
[4]  Samsung Electronics.S3C44B0X UserManual.[EB/OL].http://www.samsung.com,2000.4.13/2005.10.20.
[5]  Cypress Semiconductor Corporation. SL811 Embedded USB Host/Slave Controller Data Sheet, 2002.
[6]  VLSI Solution Corporation. VS1011B User Manual. Version 1.01, 2004.
[7]  廖日坤,李寧宇,等.基于DSP技術的MP3播放器的研究與設計[J] .測控技術,2004,32(增刊): 193194.

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉