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