1. 程式人生 > >Linux ALSA音效卡驅動之一:ALSA架構簡介

Linux ALSA音效卡驅動之一:ALSA架構簡介

一.  概述

    ALSA是Advanced Linux Sound Architecture 的縮寫,目前已經成為了linux的主流音訊體系結構,想了解更多的關於ALSA的這一開源專案的資訊和知識,請檢視以下網址:http://www.alsa-project.org/

    在核心裝置驅動層,ALSA提供了alsa-driver,同時在應用層,ALSA為我們提供了alsa-lib,應用程式只要呼叫alsa-lib提供的API,即可以完成對底層音訊硬體的控制。

                                                           圖 1.1   alsa的軟體體系結構

由圖1.1可以看出,使用者空間的alsa-lib對應用程式提供統一的API介面,這樣可以隱藏了驅動層的實現細節,簡化了應用程式的實現難度。核心空間中,alsa-soc其實是對alsa-driver的進一步封裝,他針對嵌入式裝置提供了一些列增強的功能。本系列博文僅對嵌入式系統中的alsa-driver和alsa-soc進行討論。

 二.  ALSA裝置檔案結構

    我們從alsa在linux中的裝置檔案結構開始我們的alsa之旅. 看看我的電腦中的alsa驅動的裝置檔案結構:

$ cd /dev/snd
$ ls -l

crw-rw----+ 1 root audio 116, 8 2011-02-23 21:38 controlC0
crw-rw----+ 1 root audio 116, 4 2011-02-23 21:38 midiC0D0
crw-rw----+ 1 root audio 116, 7 2011-02-23 21:39 pcmC0D0c
crw-rw----+ 1 root audio 116, 6 2011-02-23 21:56 pcmC0D0p
crw-rw----+ 1 root audio 116, 5 2011-02-23 21:38 pcmC0D1p
crw-rw----+ 1 root audio 116, 3 2011-02-23 21:38 seq
crw-rw----+ 1 root audio 116, 2 2011-02-23 21:38 timer

$


    我們可以看到以下裝置檔案:

  • controlC0 -->                 用於音效卡的控制,例如通道選擇,混音,麥克風的控制等
  • midiC0D0  -->                用於播放midi音訊
  • pcmC0D0c --〉               用於錄音的pcm裝置
  • pcmC0D0p --〉               用於播放的pcm裝置
  • seq  --〉                        音序器
  • timer --〉                       定時器

其中,C0D0代表的是音效卡0中的裝置0,pcmC0D0c最後一個c代表capture,pcmC0D0p最後一個p代表playback,這些都是alsa-driver中的命名規則。從上面的列表可以看出,我的音效卡下掛了6個裝置,根據音效卡的實際能力,驅動實際上可以掛上更多種類的裝置,在include/sound/core.h中,定義了以下裝置型別:

  1. #define SNDRV_DEV_TOPLEVEL  ((__force snd_device_type_t) 0)
  2. #define SNDRV_DEV_CONTROL   ((__force snd_device_type_t) 1)
  3. #define SNDRV_DEV_LOWLEVEL_PRE  ((__force snd_device_type_t) 2)
  4. #define SNDRV_DEV_LOWLEVEL_NORMAL ((__force snd_device_type_t) 0x1000)
  5. #define SNDRV_DEV_PCM       ((__force snd_device_type_t) 0x1001)
  6. #define SNDRV_DEV_RAWMIDI   ((__force snd_device_type_t) 0x1002)
  7. #define SNDRV_DEV_TIMER     ((__force snd_device_type_t) 0x1003)
  8. #define SNDRV_DEV_SEQUENCER ((__force snd_device_type_t) 0x1004)
  9. #define SNDRV_DEV_HWDEP     ((__force snd_device_type_t) 0x1005)
  10. #define SNDRV_DEV_INFO      ((__force snd_device_type_t) 0x1006)
  11. #define SNDRV_DEV_BUS       ((__force snd_device_type_t) 0x1007)
  12. #define SNDRV_DEV_CODEC     ((__force snd_device_type_t) 0x1008)
  13. #define SNDRV_DEV_JACK          ((__force snd_device_type_t) 0x1009)
  14. #define SNDRV_DEV_LOWLEVEL  ((__force snd_device_type_t) 0x2000)

 通常,我們更關心的是pcm和control這兩種裝置。

三.  驅動的程式碼檔案結構

    在Linux2.6程式碼樹中,Alsa的程式碼檔案結構如下:

    sound
            /core
                     /oss
                    /seq
            /ioctl32
            /include
            /drivers
            /i2c
            /synth
                    /emux
            /pci
                    /(cards)
            /isa
                    /(cards)
            /arm
            /ppc
            /sparc
            /usb
            /pcmcia /(cards)
            /oss
            /soc
                    /codecs

  • core               該目錄包含了ALSA驅動的中間層,它是整個ALSA驅動的核心部分
  • core/oss        包含模擬舊的OSS架構的PCM和Mixer模組
  • core/seq        有關音序器相關的程式碼
  • include          ALSA驅動的公共標頭檔案目錄,該目錄的標頭檔案需要匯出給使用者空間的應用程式使用,通常,驅動模組私有的標頭檔案不應放置在這裡
  •  drivers           放置一些與CPU、BUS架構無關的公用程式碼
  • i2c                 ALSA自己的I2C控制程式碼
  • pci                 pci音效卡的頂層目錄,子目錄包含各種pci音效卡的程式碼
  • isa                 isa音效卡的頂層目錄,子目錄包含各種isa音效卡的程式碼
  • soc                針對system-on-chip體系的中間層程式碼
  • soc/codecs    針對soc體系的各種codec的程式碼,與平臺無關

相關推薦

Linux ALSA 音效驅動之一ALSA架構簡介

一.  概述     ALSA是Advanced Linux Sound Architecture 的縮寫,目前已經成為了linux的主流音訊體系結構,想了解更多的關於ALSA的這一開源專案的資訊和知識,請檢視以下網址:http://www.alsa-project.org/。     在核心裝置驅動層,

Linux ALSA音效驅動之一ALSA架構簡介

一.  概述     ALSA是Advanced Linux Sound Architecture 的縮寫,目前已經成為了linux的主流音訊體系結構,想了解更多的關於ALSA的這一開源專案的資訊和知識,請檢視以下網址:http://www.alsa-project.org/。     在核心裝置驅動層

Linux ALSA音效驅動之一ALSA系統架構

Linux ALSA 系統架構ALSA 是Linux音效卡驅動的架構,下面基於linux-2.6.32描述下ALSA系統架構。ALSA系統可以分為alsa-lib、alsa- driver,而alsa-driver又分為core層和底層硬體層。作為開發者,我們只需移植底層硬

Linux ALSA音效驅動之六ASoC架構中的Machine

前面一節的內容我們提到,ASoC被分為Machine、Platform和Codec三大部分,其中的Machine驅動負責Platform和Codec之間的耦合以及部分和裝置或板子特定的程式碼,再次引用上一節的內容:Machine驅動負責處理機器特有的一些控制元件和音訊

Linux ALSA音效驅動之八ASoC架構中的Platform

1.  Platform驅動在ASoC中的作用 前面幾章內容已經說過,ASoC被分為Machine,Platform和Codec三大部件,Platform驅動的主要作用是完成音訊資料的管理,最終通過CPU的數字音訊介面(DAI)把音訊資料傳送給Codec進行處理,最終由Co

Linux ALSA音效驅動之三PCM裝置的建立

1. PCM是什麼         PCM是英文Pulse-code modulation的縮寫,中文譯名是脈衝編碼調製。我們知道在現實生活中,人耳聽到的聲音是模擬訊號,PCM就是要把聲音從模擬轉換成數字訊號的一種技術,他的原理簡單地說就是利用一個固定的頻率對模擬訊號進行取

ALSA音效驅動中的DAPM詳解之一kcontrol

DAPM是Dynamic Audio Power Management的縮寫,直譯過來就是動態音訊電源管理的意思,DAPM是為了使基於linux的移動裝置上的音訊子系統,在任何時候都工作在最小功耗狀態下。DAPM對使用者空間的應用程式來說是透明的,所有與電源相關的開關都在A

Linux ALSA音效驅動之五移動裝置中的ALSA

1.  ASoC的由來 ASoC--ALSA System on Chip ,是建立在標準ALSA驅動層上,為了更好地支援嵌入式處理器和移動裝置中的音訊Codec的一套軟體體系。在ASoc出現之前,核心對於SoC中的音訊已經有部分的支援,不過會有一些侷限性:  

Linux ALSA音效驅動之五移動裝置中的ALSA(ASoC)

1.  ASoC的由來 ASoC--ALSA System on Chip ,是建立在標準ALSA驅動層上,為了更好地支援嵌入式處理器和移動裝置中的音訊Codec的一套軟體體系。在ASoc出現之前,核心對於SoC中的音訊已經有部分的支援,不過會有一些侷限性:    C

Linux ALSA音效驅動之二音效的建立

1. struct snd_card 1.1. snd_card是什麼 snd_card可以說是整個ALSA音訊驅動最頂層的一個結構,整個音效卡的軟體邏輯結構開始於該結構,幾乎所有與聲音相關的邏輯裝置都是在snd_card的管理之下,音效卡驅動的第一個動作通常就是建立一

Linux ALSA音效驅動之七ASoC架構中的Codec

1.  Codec簡介 在移動裝置中,Codec的作用可以歸結為4種,分別是: 對PCM等訊號進行D/A轉換,把數字的音訊訊號轉換為模擬訊號對Mic、Linein或者其他輸入源的模擬訊號進行A/D轉換,把模擬的聲音訊號轉變CPU能夠處理的數字訊號對音訊通路進行控制,比如

Linux ALSA音效驅動之四Control裝置的建立

Control介面 Control介面主要讓使用者空間的應用程式(alsa-lib)可以訪問和控制音訊codec晶片中的多路開關,滑動控制元件等。對於Mixer(混音)來說,Control介面顯得尤為重要,從ALSA 0.9.x版本開始,所有的mixer工作都是通過co

ALSA音效驅動中的DAPM詳解之二widget-具備路徑和電源管理資訊的kcontrol

上一篇文章中,我們介紹了音訊驅動中對基本控制單元的封裝:kcontrol。利用kcontrol,我們可以完成對音訊系統中的mixer,mux,音量控制,音效控制,以及各種開關量的控制,通過對各種kcontrol的控制,使得音訊硬體能夠按照我們預想的結果進行工作。同時我

ALSA音效驅動中的DAPM詳解之七dapm事件機制(dapm event)

前面的六篇文章,我們已經討論了dapm關於動態電源管理的有關知識,包括widget的建立和初始化,widget之間的連線以及widget的上下電順序等等。本章我們準備討論dapm框架中的另一個機制:事件機制。通過dapm事件機制,widget可以對它所關心的dapm事

ALSA音效驅動中的DAPM詳解之五建立widget之間的連線關係

前面我們主要著重於codec、platform、machine驅動程式中如何使用和建立dapm所需要的widget,route,這些是音訊驅動開發人員必須要了解的內容,經過前幾章的介紹,我們應該知道如何在alsa音訊驅動的3大部分(codec、platform、machin

ALSA音效驅動中的DAPM詳解之四驅動程式中初始化並註冊widget和route

前幾篇文章我們從dapm的資料結構入手,瞭解了代表音訊控制元件的widget,代表連線路徑的route以及用於連線兩個widget的path。之前都是一些概念的講解以及對資料結構中各個欄位的說明,從本章開始,我們要從程式碼入手,分析dapm的詳細工作原理: 如何註冊widg

alsa音效驅動分析總結 (二)

alsa音效卡驅動分析總結  來自:http://blog.chinaunix.net/uid-20672559-id-3515392.html 現在我們開始分析ASOC: ASoC被分為Machine、Platform和Codec三大部分。其中的Machine驅動負責

alsa音效驅動移植

1 配置核心支援UDA1341:  /* 下面是需要配置的巨集,後面函式的編譯取決這些巨集 */CONFIG_SND_S3C24XX_I2S  // s3c24xx-i2s.c CONFIG_SND_

ALSA 驅動 linux 4.1.36 中變化

bstr jpg ons 變化 image width ble isa component linux 4.1.36 中變化ret = request_irq(IRQ_DMA2, s3c2440_dma2_irq, IRQF_DISABLED, "myalsa for pl

alsa-lib 交叉編譯以及音效驅動測試

alsa-lib移植筆記 l下載alsa-utils, alsa-lib, 版本要一致 l編譯alsa-lib ./configure --host=arm-none-linux-gnueabi --disable-python --prefix=/usr/share/arm-alsa/ 如