《電子技術應用》
您所在的位置:首頁 > 模擬設計 > 設計應用 > 基于IIS總線的嵌入式音頻系統設計[圖]
基于IIS總線的嵌入式音頻系統設計[圖]
摘要: 介紹了基于IIS總線的嵌入式音頻設備的硬件體系結構及其Linux驅動程序的設計。在音頻驅動程序設計綜合使用了DMA、分段多緩存區和內存映射技術以提高系統性能,滿足音頻實時性的要求。
Abstract:
Key words :
嵌入式音頻系統廣泛應用于GPS自動導航、PDA、3G手機等嵌入式領域,但目前國內在這方面的研究較少。

音頻系統設計包括軟件設計和硬件設計兩方面,在硬件上使用了基于IIS總線的音頻系統體系結構。IIS(Inter-IC Sound bus)又稱I2S,是菲利浦公司提出的串行數字音頻總線協議。目前很多音頻芯片和MCU都提供了對IIS的支持。

在軟件上,作為一個功能復雜的嵌入式系統,需要有嵌入式操作系統支撐。Linux是一個源代碼開放的類UNIX系統,由于其具有內核可裁剪性,且提供對包括ARM、PPC在內的多種嵌入式處理器的支持,所以廣泛應用于嵌入式高端產品中。雖然Linux提供了眾多API來降低驅動程序制作的復雜度,但是由于音頻應用對實時性有很高的要求,且需要處理的數據量較大,所以必須合理分配資源,使用合適的算法。本文針對三星公司的S3C44B0 ARM處理器構造了基于lis的音頻系統,并介紹了該音頻系統基于Linux2.4.0內核的驅動程序構造技術。

1 硬件體系結構

IIS總線只處理聲音數據。其他信號(如控制信號)必須單獨傳輸。為了使芯片的引出管腳盡可能少,IIS只使用了三根串行總線。這三根線分別是:提供分時復用功能的數據線、字段選擇線(聲道選擇)、時鐘信號線。

在三星公司的ARM芯片中,為了實現全雙工模式,使用了兩條串行數據線,分別作為輸入和輸出。此外三星公司的IIS接口提供三種數據傳輸模式:

· 正常傳輸模式。此模式基于FIFO寄存器。該模式下CPU將通過輪詢方式訪問FIFO寄存器,通過IISCON寄存器的第七位控制FIFO。

· DMA模式。此模式是一種外部設備控制方式。它使用竊取總線控制權的方法使外部設備與主存交換數據,從而提高系統的吞吐能力。

在三星公司的ARM芯片中有4個通道DMA控制器用于控制各種外部設備,其中IIS與其他串行外設共用兩個橋聯DMA(BDMA)類型的DMA通道。通過設置CPU的IISFCON寄存器可以使IIS接口工作在DMA模式下。此模式下FIFO寄存器組的控制權掌握在DMA控制器上。當FIFO滿時,由DMA控制器對FIFO中的數據進行處理。DMA模式的選擇由IISCON寄存器的第四和第五位控制。

· 傳輸/接收模式。該模式下,IIS數據線將通過雙通道DMA同時接收和發送音頻數據。本系統使用該數據傳輸模式。

圖1是44BOX芯片與菲利浦公司的UDAl341TS音頻芯片的連接示意圖。

基于IIS總線的嵌入式音頻系統設計

在這個體系結構中,為了實現全雙工,數據傳輸使用兩個BDMA通道。數據傳輸(以回放為例)先由內部總線送到內存,然后傳到BDMA控制器通道0,再通過IIS控制器寫入IIS總線并傳輸給音頻芯片。通道1用來錄音。

三星公司的BDMA控制器沒有內置的存儲區域,在驅動程序中必須為音頻設備分配DMA緩存區。緩存區的地址在通道DMA控制器的地址寄存器中設置。

UDAl341TS芯片除了提供IIS接口和麥克風揚聲器接口,還提供L3接口控制音量等。L3接口分別連到S3C44B0的3個通用數據輸出引腳上。

2 音頻設備底層軟件設計

嵌入式系統硬件設備種類繁多,且缺乏PC中標準的體系結構,所以必須為各種設備編寫驅動程序。

驅動程序的主要任務是控制音頻數據在硬件中流動,并為音頻應用提供標準接口。由于嵌入式系統資源有限,且處理器能力不強,所以在音頻設備的驅動程序設計中,合理分配系統資源是難點。

需要注意的是,在三星公司的ARM芯片中,I/O設備的寄存器作為內存空間的一部分,可以使用普通的內存訪問語句讀寫I/O寄存器,進而控制外部設備。這是該嵌入式系統與傳統的基于Intel處理器的PC最大的不同。

2.1 驅動程序功能

設備驅動程序中需要完成的任務包括:對設備以及對應資源初始化和釋放;讀取應用程序傳送給設備文件的數據并回送應用程序請求的數據。這需要在用戶空間、內核空間、總線及外設之間傳輸數據。

2.2 驅動程序構架

Linux驅動程序中將音頻設備按功能分成不同類型,每種類型對應不同的驅動程序。UDAl341TS音頻芯片提供如下功能:

· 數字化音頻。這個功能有時被稱為DSP或Codec設備。其功能是實現播放數字化聲音文件或錄制聲音。

· 混頻器。用來控制各種輸入輸出的音量大小,在本系統中對應L3接口。

在Linux設備驅動程序將設備看成文件,在驅動程序中將結構file_operations中的各個函數指針與驅動程序對應例程函數綁定,以實現虛擬文件系統VFS對邏輯文件的操作。數字音頻設備(audio)、混頻器(mixer)對應的設備文件分別是/dev/dsp和/dev/mixer。

2.3 設備的初始化和卸載

/dev/dsp的驅動設計主要包含:設備的初始化和卸載、內存與DMA緩存區的管理、設備無關操作(例程)的實現以及中斷處理程序。

在設備初始化中對音頻設備的相關寄存器初始化,并在設備注冊中使用了兩個設備注冊函數register sound_dsp()和regiter_sound_mixer()注冊音頻設備和混頻器設備。這兩個函數在2.2以上版本的內核drivers/sound/sound_core.c文件中實現。其作用是注冊設備,得到設備標識,并且實現設備無關操作的綁定。在這些注冊函數里使用的第一個參數都是struct file_operations類型的參數。該參數定義了設備無關接口的操作。

設備卸載時使用注銷函數。注銷時用輸入注冊時得到的設備號即可。在注銷時還必須釋放驅動程序使用的各種系統資源包括DMA、設備中斷等。

2.4 DMA緩存區設計和內存管理

在音頻設備的驅動程序設計中,DMA緩存區設計和內存管理部分最為復雜。由于音頻設備有很高的實時性要求,所以合理地使用內存能加快對音頻數據的處理,并減少時延。

三星公司的BDMA控制器沒有內置DMA存儲區域,在驅動程序中必須為音頻設備分配DMA緩存區。這樣就能通過DMA直接將需要回放或是錄制的聲音數據存放在內核的DMA緩存區中。

為了方便各種物·理設備使用DMA資源,在程序中使用strcut s3c44b_DMA數據結構管理系統各個DMA通道的資源,如圖2。每個DMA通道被多個外部設備共用,為各個外設分配的DMA緩存區的大小和數目可能不·一致,所有分配的數據塊使用DMA緩存數據塊DMA_buf管理。各個不同設備申請的數據緩存區形成一個單向鏈表,每個鏈表節點包含一個起點字段,存放實際DMA緩存起始位置的物理地址。在設備第一次使用DMA時,使用kmalloc函數為DM A_buf分配內存,并且使用consistent_alloc函數為DMA分配實際的連續物理緩存區,然后將節點插入隊列中。從第二次開始通過緩存區的標示符對緩存區進行操作。

基于IIS總線的嵌入式音頻系統設計

內存管理中的重要問題是緩存區塊設計。常見的設計思路是使用一個緩存區,CPU先對緩存區處理,然后掛起,音頻設備對緩存區操作,音頻設備處理完后喚醒CPU,如此循環。需要處理大量音頻數據的音頻設備驅動程序,可以使用雙緩沖。以錄音為例,系統使用緩存2存放音頻設備量化好的聲音,CPU(應用程序)則處理緩存1中的聲音數據;當Codec設備填充完緩存2,它移向緩存1填充數據,而CPU轉向處理緩存2里的數據;不斷交替循環,如圖3(a)、(b)所示。

基于IIS總線的嵌入式音頻系統設計

使用這種方法處理音頻數據,能夠提高系統的并行能力。應用程序可以在音頻工作的同時處理傳輸進來的音頻數據。由于實際系統被設計成支持全雙工的音頻系統,所以必須為輸入和輸出同時分配內存,對應的數據結構設計如圖4所示。

基于IIS總線的嵌入式音頻系統設計

圖4中音頻設備緩存控制塊管理音頻設備的緩存區。在控制塊中輸入/輸出緩存指針分別指向輸入和輸出緩存結構audio_buf,輸入輸出控制塊指針分別指向對應的DMA控制塊。因為輸人輸出使用了不同DMA通道,所以音頻設備緩存控制塊有兩個DMA控制塊控制指針。在audio_buf中分別有兩個DMA起點字段分別指向雙緩存區的起始物理地址。緩存區狀態字段包含緩存.區是否被映射、是否激活、是否暫停等信息。應用程序處理緩存中數據的速度依賴于緩存的大小和數據傳輸速度。例如使用"8kHz/8位/單工" 的采洋方式錄音,音頻芯片產生64kbps的數據流量。如果是兩個4K字節的緩存,那么應用程序就只有0.5s處理緩存中的數據并把它存到Flash芯片中(或者傳輸到其它設備中)。若0.5s內不能處理這些數據,緩存就會溢出。若采用高品質的采樣,例如使用CD音質的采樣,那么Codec產生數據的速度將達1376kbps,CPU處理音頻數據的時間就只有23ms。在CPU負載較大的情況下,將可能出現數據丟失的問題。

為了解決音頻應用I/O數據量大的問題,最簡單易行的方法是使用比較大的緩存區域。但實際上大的緩存區需要更長的填充時間,在使用時會出現延時,并可能占用過多CPU資源。為了解決延時的問題,使用多段緩存機制。在這種機制下,將可用的緩存區分割成若干個相同大小的塊。對較大的緩存區的操作轉變成對較小的緩沖區塊的操作,在不增加緩存區操作時間的情況下提供較大的緩存。不同的音頻應用,精度不一樣,需要的緩存大小也不一樣。所以在應用程序層上,驅動程序還必須提供接口讓應用程序改變塊的大小和個數。這個接口可以在ioctl中實現。對緩存區塊的大小控制通過對audio_buf中的對應字段設置實現。

使用內存映射(mmap)技術是另一種提高系統性能的途徑。Linux系統的內存空間分為內核??臻g和用戶空間,驅動程序工作在內核空間,并負責在內核空間和用戶空間傳輸數據。音頻應用一般數據量比較大,而且有較高的質量要求,在驅動程序中還可以使用內存映射進一步提高CPU的利用率。內存映射通過remap page_range將分配給DMA緩存區的內核空間的內存映射到用戶空間,用戶不需使用copy_to_user和copy_from_user將數據在內核空間與用戶空間中拷貝。圖4中緩存區狀態和緩存區起點兩個字段也用于內存映射服務。在實現時由于DMA的緩存結構復雜,需要將每個緩存塊分別映射。

2.5 設備無關操作

設備無關操作對應于file_operations指向的各個例程,它讓用戶用訪問文件的方式訪問設備。對設備的打開和讀寫是啟動程序為用戶程序提供的最主要接口,分別對應于file_eratlons中的open、read和write例程。在open例程中需要完成的任務主要是設備初始化,包括:

· 通過設置IIS寄存器控制音頻設備的初始化,并且初始化設備的工作參數(包括速度、聲道、采樣寬度);

· 為設備分配DMA通道;

· 根據采樣參數計算出緩存內段的大小(程序也可以指定緩存內段的大小);

當緩存區和DMA設置好后,讀寫操作主要對緩存操作。對設備的操作除了讀寫操作外,還有音頻播放中的暫停和繼續。這兩個操作在ioctl接口中實現,通過對相應的IIS總線控制器(IISCON寄存器)操作實現。

此外,在對音頻操作時還要注意:一次采樣得到的數據必須一次處理,否則不能正確播放數據。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          欧美日韩精品伦理作品在线免费观看| 欧美日韩中文字幕综合视频| 国产精品美女主播| 国产精品久久久久久av下载红粉| 亚洲欧洲视频| 欧美在线看片a免费观看| 一区二区日本视频| 亚洲国产精品视频| 99热这里只有成人精品国产| 在线观看视频一区二区欧美日韩| 国产欧美欧美| 亚洲国产美女精品久久久久∴| 亚洲精品欧美专区| 久久精品一本久久99精品| 亚洲电影激情视频网站| 国产精品国产三级国产专区53| 亚洲第一精品夜夜躁人人躁| 红桃视频国产一区| 狠狠色噜噜狠狠色综合久| 亚洲视频在线二区| 亚洲人体一区| 99国产精品| 久久久久久穴| 国产精品国产自产拍高清av王其| 欧美 日韩 国产精品免费观看| 国外成人在线| 性亚洲最疯狂xxxx高清| 欧美综合77777色婷婷| 国产精品久久久久7777婷婷| 欧美亚洲系列| 老司机一区二区| 一区二区三区精品视频| 亚洲经典视频在线观看| 欧美三级电影大全| 国产精品女主播在线观看| 欧美日韩国产成人在线免费| 欧美日韩成人在线| 午夜久久影院| 亚洲福利视频三区| 亚洲人成欧美中文字幕| 国产欧美日韩免费| 国产亚洲va综合人人澡精品| 久久夜色精品亚洲噜噜国产mv| 伊人久久成人| 亚洲日本中文字幕免费在线不卡| 性一交一乱一区二区洋洋av| 亚洲美女中出| 欧美一二三区精品| 99re8这里有精品热视频免费| 午夜日韩av| 国产精品一区视频| 欧美揉bbbbb揉bbbbb| 国产精品系列在线播放| 久久综合成人精品亚洲另类欧美| 久久天天躁狠狠躁夜夜爽蜜月| 久久在线免费观看| 韩国三级电影一区二区| 国产精品国产三级欧美二区| 欧美连裤袜在线视频| 亚洲精品久久久一区二区三区| 狠狠操狠狠色综合网| 久久婷婷人人澡人人喊人人爽| 国自产拍偷拍福利精品免费一| 亚洲精品国产精品国自产观看浪潮| 国产精品人人做人人爽| 亚洲高清123| 国产午夜精品美女视频明星a级| 亚洲精品裸体| 欧美多人爱爱视频网站| 国产网站欧美日韩免费精品在线观看| 国产亚洲观看| 亚洲人被黑人高潮完整版| 午夜在线a亚洲v天堂网2018| 国产日韩精品在线播放| 激情伊人五月天久久综合| 欧美体内she精视频在线观看| 免费久久精品视频| 欧美一级日韩一级| 欧美日韩成人综合| 欧美日韩国产成人在线| 欧美日韩一区免费| 欧美日韩在线三区| 欧美中文字幕久久| 国产精品不卡在线| 亚洲二区三区四区| 国产精品欧美在线| 久久亚洲国产精品日日av夜夜| 欧美日韩卡一卡二| 国产一区二区三区免费观看| 国产主播在线一区| 久久蜜桃香蕉精品一区二区三区| 国产一区二区三区自拍| 亚洲一品av免费观看| 午夜视频精品| 亚洲毛片在线| 国产一区二区三区免费观看| 国产精品免费看久久久香蕉| 久久国产精品色婷婷| 欧美激情二区三区| 久久人人九九| 免费短视频成人日韩| 艳女tv在线观看国产一区| 欧美在线免费观看| 久久久久88色偷偷免费| 欧美性生交xxxxx久久久| 欧美有码在线视频| 亚洲天堂网站在线观看视频| 亚洲青色在线| 欧美午夜不卡影院在线观看完整版免费| 99re6热在线精品视频播放速度| 亚洲第一色在线| 亚洲精品中文字幕在线| 亚洲精选久久| 亚洲精品男同| 亚洲国内高清视频| 欧美亚洲不卡| 欧美激情综合亚洲一二区| 欧美国产日本韩| 久久大逼视频| 亚洲国产视频一区| 亚洲视频在线观看一区| 欧美午夜电影网| 男女视频一区二区| 国产欧美日本在线| 欧美人成在线| 欧美成人激情视频| 国产精品视频yy9099| 国产精品午夜在线观看| 亚洲影院在线| aⅴ色国产欧美| 裸体女人亚洲精品一区| 亚洲日本欧美在线| 国产欧美激情| 欧美日韩大片一区二区三区| 国产精品99久久久久久久久| 在线看欧美日韩| 亚洲精品你懂的| 国产综合久久久久影院| 一区二区三区在线看| 亚洲精品欧美在线| 国产啪精品视频| 欧美日韩综合久久| 欧美在线视频免费播放| 国产精品久久久久久五月尺| 亚洲精选视频免费看| 久久黄色网页| 亚洲视频免费在线观看| 亚洲黄色av一区| 国产精品每日更新在线播放网址| 亚洲欧美另类在线| 欧美一区二区三区在线免费观看| 亚洲黄色片网站| 免费观看成人| 黄色av成人| 亚洲美女啪啪| 欧美国产一区二区| 欧美午夜电影一区| 久久精品91| 暖暖成人免费视频| 先锋影音久久久| 亚洲视频专区在线| 国产视频一区免费看| 在线观看亚洲一区| 欧美精品v日韩精品v国产精品| 久久精品首页| 国产中文一区二区| 一区二区三区国产| 亚洲一二三区在线观看| 欧美一区国产一区| 亚洲精品三级| 日韩系列欧美系列| 欧美日韩一级大片网址| 亚洲国产精品一区二区www| 亚洲国产一区二区三区a毛片| 久久精品国产69国产精品亚洲| 女同性一区二区三区人了人一| 国产三级精品三级| 国产亚洲激情视频在线| 欧美寡妇偷汉性猛交| 136国产福利精品导航| 国产精品久久久久国产精品日日| 久久国产欧美日韩精品| 国产精品毛片一区二区三区| 好吊色欧美一区二区三区视频| 久久一区二区三区国产精品| 亚洲精品久久7777| 国模私拍一区二区三区| 久久精品国产在热久久| 国产亚洲精品久| 欧美日韩免费观看一区二区三区| 国产伦理精品不卡| 永久免费视频成人| 最新成人在线| 亚洲免费在线观看| 欧美香蕉大胸在线视频观看| 激情视频一区二区| 毛片基地黄久久久久久天堂| 欧美一区日本一区韩国一区| 欧美日韩免费| 亚洲精品免费在线观看| 黄色av日韩| 亚洲自拍偷拍福利| 欧美在线免费播放| 国产日韩av一区二区| 国产欧美日韩一区二区三区在线| 欧美国产欧美亚州国产日韩mv天天看完整| 在线观看国产成人av片| 欧美二区乱c少妇| 欧美日韩精品欧美日韩精品一| 亚洲春色另类小说| 亚洲欧洲视频在线| 亚洲午夜激情网页| 翔田千里一区二区| 久久久综合香蕉尹人综合网| 免费观看在线综合色| 亚洲欧洲偷拍精品| 亚洲一区制服诱惑| 欧美午夜精品伦理| 欧美激情2020午夜免费观看| 亚洲黄色成人网| 日韩亚洲成人av在线| 久久这里只精品最新地址| 国产精品久久久久久模特| 国产亚洲综合在线| 欧美精品在线视频| 国产人久久人人人人爽| 国产农村妇女精品一二区| 午夜精品国产精品大乳美女| 国产精品久久午夜| 黄色欧美成人| 欧美日韩一区二区在线| 99精品热6080yy久久| 久久久免费精品视频| 亚洲二区视频| 欧美大片在线看免费观看| 久久久另类综合| 国产亚洲欧美aaaa| 国产精品欧美日韩久久| 中文亚洲视频在线| 亚洲精品久久久久中文字幕欢迎你| 亚洲国产老妈| 欧美成人中文字幕在线| 欧美国产三级| 91久久精品www人人做人人爽| 亚洲人成77777在线观看网| 91久久国产综合久久蜜月精品| 国产精品久久久一区二区三区| 欧美亚洲第一区| 国产精品私房写真福利视频| 欧美不卡激情三级在线观看| 在线观看精品一区| 欧美成人黑人xx视频免费观看| 一区二区三区视频在线播放| 亚洲天天影视| 欧美va亚洲va国产综合| 国产精品久久久久一区二区三区| 欧美伊人久久久久久午夜久久久久| 久久尤物视频| 激情综合五月天| 亚洲欧美电影院| 亚洲欧美日本另类| 一区二区三区免费在线观看| 亚洲免费在线播放| 亚洲天堂av电影| 亚洲高清不卡在线观看| 国产精品久久久久9999吃药| 久久久久久久97| 久久国产加勒比精品无码| 久久久久网址| 亚洲缚视频在线观看| 亚洲国产一区二区三区在线播| 欧美三级网址| 欧美日韩精品三区| 欧美www在线| 欧美视频在线播放| 夜夜嗨av一区二区三区免费区| 在线观看中文字幕亚洲| 亚洲欧洲精品一区二区| 欧美一区二区三区播放老司机| 在线看日韩av| 国产伦精品一区二区三区照片91| 国产精品国产三级国产专播品爱网| 欧美日韩国产综合一区二区| 亚洲欧洲在线看| 亚洲日本理论电影| 在线播放一区| 亚洲激情专区| 麻豆av一区二区三区久久| 亚洲欧美日韩在线播放| 伊人久久大香线蕉av超碰演员| 欧美日韩亚洲一区在线观看| 亚洲在线视频免费观看| 久久精品夜夜夜夜久久| 女生裸体视频一区二区三区| 99国产精品久久久久久久| 国产日韩欧美不卡| 国产日韩亚洲欧美综合| 欧美一区二区视频97| 欧美日韩亚洲综合一区| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产日韩欧美高清| 欧美粗暴jizz性欧美20| 欧美大学生性色视频| 亚洲日本va在线观看| 亚洲区第一页| 国产综合久久久久久鬼色| 欧美日精品一区视频| 亚洲国内高清视频| 亚洲欧美日韩中文视频| 亚洲国产导航| 在线看一区二区| 久久激情视频免费观看| 一本高清dvd不卡在线观看| 久久国产直播| 久久久久久夜精品精品免费| 亚洲图片欧美日产| 久久影院亚洲| 国产亚洲欧美一区二区| 亚洲伦理久久| 国产精品久久久久aaaa| 久久婷婷亚洲| 麻豆精品精华液| 在线一区二区三区四区五区| 男女精品视频| 狠狠综合久久av一区二区小说| 欧美另类在线观看| 欧美巨乳波霸| 亚洲一卡二卡三卡四卡五卡|