⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ac97c.h

📁 ac97 at91sam9263ek的程序,其中ac97芯片可以放音
💻 H
字号:
/* ----------------------------------------------------------------------------
 *         ATMEL Microcontroller Software Support 
 * ----------------------------------------------------------------------------
 * Copyright (c) 2008, Atmel Corporation
 *
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * - Redistributions of source code must retain the above copyright notice,
 * this list of conditions and the disclaimer below.
 *
 * Atmel's name may not be used to endorse or promote products derived from
 * this software without specific prior written permission.
 *
 * DISCLAIMER: THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
 * DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
 * OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 * ----------------------------------------------------------------------------
 */

//------------------------------------------------------------------------------
/// \unit
///
/// !!!Purpose
/// 
/// This module provides definitions and functions for using the AC'97
/// controller (AC97C).
/// 
/// !!!Usage
/// 
/// -# Enable the AC'97 interface pins (see pio & board.h).
/// -# Configure the AC'97 controller using AC97C_Configure
/// -# Assign the input and output slots to channels, and the data size used to
///    transfer AC97 data stream.
///    - Three functions can be used:
///       - AC97C_AssignInputSlots: set slots for AC'97 data in, recording.
///       - AC97C_AssignOutputSlots: set slots for AC'97 data out, playing.
///       - AC97C_SetChannelSize: set data sizes in bits for AC'97 data stream.
///    - Three different channels can be configured:
///       - AC97C_CHANNEL_CODEC: AC'97 register access channel, its size is
///         fixed and #must not# change by AC97C_SetChannelSize
///       - AC97C_CHANNEL_A: AC'97 stream channel, with PDC support.
///       - AC97C_CHANNEL_B: AC'97 data channel, without PDC support.
/// -# Configure the used AC97 channel with AC97C_ConfigureChannel, to enable
///    the channel.
/// -# Then you can operate the connected AC'97 codec:
///    - AC97C_ReadCodec / AC97C_WriteCodec: Read / Write codec register.
///    - AC97C_Transfer: Transfer through AC97C channels to setup codec register
///     or transfer %audio data stream.
///       - AC97C_CODEC_TRANSFER: access the codec register.
///       - AC97C_CHANNEL_A_RECEIVE, AC97C_CHANNEL_B_RECEIVE: start reading.
///       - AC97C_CHANNEL_A_TRANSMIT, AC97C_CHANNEL_B_TRANSMIT: start writing.
///    Normally you can initialize a set of AC'97 codec registers to initialize
///    the codec for %audio playing and recording.
/// -# Example code for playing & recording:
///    - General process:
///       -# Configure the codec registers for the %audio settings and formats;
///       -# Setup the channel size if necessery;
///       -# Start %audio stream transfer.
///    - Audio playing sample:
/// \code
///    // Configure sample rate of codec
///    AC97C_WriteCodec(AD1981B_PMC_DAC, expectedSampleRate);
///    // Set channel size
///    AC97C_SetChannelSize(AC97C_CHANNEL_A, bitsPerSample);
///    // Start channel A transfer
///    AC97C_Transfer(AC97C_CHANNEL_A_TRANSMIT, 
///                   (unsigned char *) (pointerToAudioDataBuffer),
///                   numberOfSamplesToSend,
///                   (Ac97Callback) PlayingFinished, 
///                   0);
/// \endcode
///    - Audio recording sample:
/// \code
///    // Enable recording
///    AC97C_WriteCodec(AD1981B_REC_SEL, 0);
///    // Set sample rate
///    AC97C_WriteCodec(AD1981B_PMC_ADC, 7000);
///    // Always use 16-bits recording
///    AC97C_SetChannelSize(AC97C_CHANNEL_A, 16);
///    // Start recording
///    AC97C_Transfer(AC97C_CHANNEL_A_RECEIVE, 
///                   (unsigned char *) RECORD_ADDRESS,
///                   MAX_RECORD_SIZE,
///                   (Ac97Callback) RecordFinished,
///                   0);
/// \endcode
//------------------------------------------------------------------------------

#ifndef AC97C_H
#define AC97C_H

//------------------------------------------------------------------------------
//         Constants
//------------------------------------------------------------------------------

/// The channel is already busy with a transfer.
#define AC97C_ERROR_BUSY            1
/// The transfer has been stopped by the user.
#define AC97C_ERROR_STOPPED         2

/// Codec channel index.
#define AC97C_CHANNEL_CODEC         0
/// Channel A index.
#define AC97C_CHANNEL_A             1
/// Channel B index.
#define AC97C_CHANNEL_B             2

/// Codec transmit/receive transfer index.
#define AC97C_CODEC_TRANSFER        0
/// Channel A receive transfer index.
#define AC97C_CHANNEL_A_RECEIVE     1
/// Channel A transmit transfer index.
#define AC97C_CHANNEL_A_TRANSMIT    2
/// Channel B receive transfer index.
#define AC97C_CHANNEL_B_RECEIVE     3
/// Channel B transmit transfer index.
#define AC97C_CHANNEL_B_TRANSMIT    4

//------------------------------------------------------------------------------
//         Types
//------------------------------------------------------------------------------

/// AC97C transfer callback function.
typedef void (*Ac97Callback)(void *pArg,
                             unsigned char status,
                             unsigned int remaining);

//------------------------------------------------------------------------------
//         Exported functions
//------------------------------------------------------------------------------

extern void AC97C_Configure();

extern void AC97C_ConfigureChannel(unsigned char channel, unsigned int cfg);

extern void AC97C_AssignInputSlots(unsigned char channel, unsigned int slots);

extern void AC97C_AssignOutputSlots(unsigned char channel, unsigned int slots);

extern unsigned char AC97C_Transfer(
                unsigned char channel,
                unsigned char *pBuffer,
                unsigned int numSamples,
                Ac97Callback callback,
                void *pArg);

extern unsigned char AC97C_IsFinished(unsigned char channel);

extern void AC97C_WriteCodec(unsigned char address, unsigned short data);

extern unsigned short AC97C_ReadCodec(unsigned char address);

extern void AC97C_SetChannelSize(unsigned char channel, unsigned char size);

extern void AC97C_CancelTransfer(unsigned char channel);

#endif //#ifndef AC97C_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -