3199c94dc3899b6dfe7ff07bc461971b3e6442dd
[processor-sdk/performance-audio-sr.git] / pasdk / test_dsp / application / itopo / evmk2g / audio_dc_cfg.h
2 /*
3 Copyright (c) 2017, Texas Instruments Incorporated - http://www.ti.com/
4 All rights reserved.
6 * Redistribution and use in source and binary forms, with or without 
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 *
13 * Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the
16 * distribution.
17 *
18 * Neither the name of Texas Instruments Incorporated nor the names of
19 * its contributors may be used to endorse or promote products derived
20 * from this software without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
26 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
27 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
28 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
32 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 *
34 */
36 /**
37  * \file      audio_dc_cfg.h
38  *
39  * \brief     Audio daughter card configuration header file
40  *
41  */
43 #ifndef _AUDIO_DC_CFG_H_
44 #define _AUDIO_DC_CFG_H_
46 #include "audk2g.h"
47 #include "audk2g_audio.h"
48 /* TI-RTOS Header files */
49 #include <ti/drv/i2c/I2C.h>
50 #include <ti/drv/i2c/soc/I2C_soc.h>
52 /**
53  *  \brief    ADC configuration parameter structure
54  *
55  */
56 typedef struct _AdcConfig
57 {
58         uint8_t          gain;
59         Audk2gAdcLeftInputMux  adc1LMux;
60         Audk2gAdcLeftInputMux  adc2LMux;
61         Audk2gAdcRightInputMux adc1RMux;
62         Audk2gAdcRightInputMux adc2RMux;
63         Audk2gAdcRxWordLen     wlen;
64         Audk2gAdcDataFormat    format;
65         uint8_t          intEnable;
66 } AdcConfig;
68 /**
69  *  \brief    DAC configuration parameter structure
70  *
71  */
72 typedef struct _DacConfig
73 {
74         Audk2gDacAmuteCtrl    amuteCtrl;
75         uint8_t         amuteEnable;
76         Audk2gDacSamplingMode samplingMode;
77         Audk2gDacDataFormat   dataFormat;
78         uint8_t         softMuteEnable;
79         Audk2gDacAttnMode     attnMode;
80         Audk2gDacDeempCtrl    deempCtrl;
81         uint8_t         volume;
82 } DacConfig;
84 /**
85  *  \brief    Initializes ADC module
86  *
87  *  This function initializes and configures the ADC modules
88  *  on audio daughter card
89  *
90  *  \param     devId  [IN]  ADC Device Id
91  *  \param     config [IN]  ADC configuration parameters
92  *
93  *  \return    Platform_EOK on Success or error code
94  */
95 Audk2g_STATUS audioAdcConfig(Audk2gAdcDevId  devId, AdcConfig *config);
97 /**
98  *  \brief    Initializes DAC module
99  *
100  *  This function initializes and configures the DAC modules
101  *  on audio daughter card
102  *
103  *  \param     devId  [IN]  DAC Device Id
104  *  \param     config [IN]  DAC configuration parameters
105  *
106  *  \return    Platform_EOK on Success or error code
107  */
108 Audk2g_STATUS audioDacConfig(Audk2gDacDevId devId, DacConfig *config);
110 /**
111  *  \brief    Initializes DIR module
112  *
113  *  This function initializes and configures the DIR modules
114  *  on audio daughter card
115  *
116  *  \return    Audk2g_STATUS on Success or error code
117  */
118 Audk2g_STATUS audioDirConfig(void);
120 /**
121  *  \brief    Initializes HSR41 module
122  *
123  *  This function initializes and configures the HDMI module
124  *  with the audio daughter card
125  *
126  *  \return    Audk2g_STATUS on Success
127  */
128 Audk2g_STATUS audioHDMIConfig(void);
130 /**
131  *  \brief    Read HDMI input sampling rate
132  *
133  */
134 unsigned int read_hdmi_samprate();
136 /**
137  *  \brief    Clear HDMI interrupt on ~HMINT line
138  *
139  */
140 void clear_hdmi_hmint();
142 /* ------------------------------------------------------------------------ *
143  *                                                                          *
144  *  Variable types                                                          *
145  *                                                                          *
146  * ------------------------------------------------------------------------ */
148 #define Uint32  unsigned int
149 #define Uint16  unsigned short
150 #define Uint8   unsigned char
151 #define Int32   int
152 #define Int16   short
153 #define Int8    char
156 #endif /* _AUDIO_DC_CFG_H_ */
158 /* Nothing past this point */