/* ---------------------------------------------------------------------------- | |
* 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 | |