Lines Matching +full:i2s +full:- +full:input
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
3 * Copyright (c) by James Courtier-Dutton <James@superbug.demon.co.uk>
11 /* Audigy2 P16V pointer-offset register set, accessed through the PTR2 and DATA2 registers …
25 #define PLAYBACK_LIST_SIZE 0x01 /* Size of list in bytes << 16. E.g. 8 periods -> 0x00380000 */
41 /* [0:1] Capture input 0 channel select. 0 = Capture output 0.
45 * [3:2] Capture input 1 channel select. 0 = Capture output 0.
49 * [5:4] Capture input 2 channel select. 0 = Capture output 0.
53 * [7:6] Capture input 3 channel select. 0 = Capture output 0.
57 * [9:8] Playback input 0 channel select. 0 = Play output 0.
61 * [11:10] Playback input 1 channel select. 0 = Play output 0.
65 * [13:12] Playback input 2 channel select. 0 = Play output 0.
69 * [15:14] Playback input 3 channel select. 0 = Play output 0.
75 * [26:24] FX engine channel capture 0 = 0x60-0x67.
76 * 1 = 0x68-0x6f.
77 * 2 = 0x70-0x77.
78 * 3 = 0x78-0x7f.
79 * 4 = 0x80-0x87.
80 * 5 = 0x88-0x8f.
81 * 6 = 0x90-0x97.
82 * 7 = 0x98-0x9f.
93 * [18:16] Channel 0 Detected sample rate. 0 - 44.1khz
94 * 1 - 48 khz
95 * 2 - 96 khz
96 * 3 - 192 khz
97 * 7 - undefined rate.
98 * [19] Channel 0. 1 - Valid, 0 - Not Valid.
100 * [23] Channel 1. 1 - Valid, 0 - Not Valid.
102 * [27] Channel 2. 1 - Valid, 0 - Not Valid.
104 * [31] Channel 3. 1 - Valid, 0 - Not Valid.
106 /* 0x18 - 0x1f unused */
108 /* 0x21 - 0x3f unused */
118 * 0 - SPDIF channel.
119 * 1 - I2S channel.
120 * 2 - SRC48 channel.
121 * 3 - SRCMulti_SPDIF channel.
122 * 4 - SRCMulti_I2S channel.
123 * 5 - SPDIF channel.
124 * 6 - fxengine capture.
125 * 7 - AC97 capture.
129 * Writing 0xffff0000 -> 77770000 so it must be some sort of route.
132 /* 0x41,42 take values from 0 - 0xffffffff, but have no effect on playback */
134 /* 0x41-45 unused */
140 /* 0x47-0x4f unused */
141 /* 0x50-0x5f Capture cache data */
145 * [4] 0 = 10K2 audio, 1 = SRCMulti I2S mixer output.
150 /* 0xffffffff -> 0xC0000015
155 /* 0x61 -> 0x6c are Volume controls */
156 #define PLAYBACK_VOLUME_MIXER1 0x61 /* SRC48 Low to mixer input volume control. */
157 #define PLAYBACK_VOLUME_MIXER2 0x62 /* SRC48 High to mixer input volume control. */
158 #define PLAYBACK_VOLUME_MIXER3 0x63 /* SRCMULTI SPDIF Low to mixer input volume control. */
159 #define PLAYBACK_VOLUME_MIXER4 0x64 /* SRCMULTI SPDIF High to mixer input volume control. */
160 #define PLAYBACK_VOLUME_MIXER5 0x65 /* SRCMULTI I2S Low to mixer input volume control. */
161 #define PLAYBACK_VOLUME_MIXER6 0x66 /* SRCMULTI I2S High to mixer input volume control. */
162 #define PLAYBACK_VOLUME_MIXER7 0x67 /* P16V Low to SRCMULTI SPDIF mixer input volume control. */
163 #define PLAYBACK_VOLUME_MIXER8 0x68 /* P16V High to SRCMULTI SPDIF mixer input volume control. */
164 #define PLAYBACK_VOLUME_MIXER9 0x69 /* P16V Low to SRCMULTI I2S mixer input volume control. */
168 #define PLAYBACK_VOLUME_MIXER10 0x6a /* P16V High to SRCMULTI I2S mixer input volume control. */
170 #define PLAYBACK_VOLUME_MIXER11 0x6b /* E10K2 Low to SRC48 mixer input volume control. */
171 #define PLAYBACK_VOLUME_MIXER12 0x6c /* E10K2 High to SRC48 mixer input volume control. */
173 #define SRC48_ENABLE 0x6d /* SRC48 input audio enable */
178 #define SRCMULTI_ENABLE 0x6e /* SRCMulti input audio enable. Default 0xffffffff …
181 * [15:8] The corresponding E10K2 channel to SRCMulti I2S enabled.
201 * [30] 0 = SRCMulti_I2S input from fxengine 0x68-0x6f.
202 * 1 = SRCMulti_I2S input from SRC48 output.
203 * [31] 0 = SRCMulti_SPDIF input from fxengine 0x60-0x67.
204 * 1 = SRCMulti_SPDIF input from SRC48 output.
206 /* 0xffffffff -> C00100FF */
207 /* 0 -> Not playback sound, irq still running */
214 /* 0xffffffff -> 3FF30FFF */
218 /* 0xffffffff -> F33FFFFF */
222 /* 0x74-0x75 unknown */