This source file includes following definitions.
- check_asic_status
- write_control_reg
- set_input_auto_mute
- set_digital_mode
- set_professional_spdif
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40 static int check_asic_status(struct echoaudio *chip)
41 {
42 u32 asic_status;
43
44 send_vector(chip, DSP_VC_TEST_ASIC);
45
46
47
48 if (read_dsp(chip, &asic_status) < 0) {
49 dev_err(chip->card->dev,
50 "check_asic_status: failed on read_dsp\n");
51 chip->asic_loaded = false;
52 return -EIO;
53 }
54
55 chip->asic_loaded = (asic_status == ASIC_ALREADY_LOADED);
56 return chip->asic_loaded ? 0 : -EIO;
57 }
58
59
60
61
62
63
64 static int write_control_reg(struct echoaudio *chip, u32 value, char force)
65 {
66 __le32 reg_value;
67
68
69 if (chip->digital_in_automute)
70 value |= GML_DIGITAL_IN_AUTO_MUTE;
71 else
72 value &= ~GML_DIGITAL_IN_AUTO_MUTE;
73
74 dev_dbg(chip->card->dev, "write_control_reg: 0x%x\n", value);
75
76
77 reg_value = cpu_to_le32(value);
78 if (reg_value != chip->comm_page->control_register || force) {
79 if (wait_handshake(chip))
80 return -EIO;
81 chip->comm_page->control_register = reg_value;
82 clear_handshake(chip);
83 return send_vector(chip, DSP_VC_WRITE_CONTROL_REG);
84 }
85 return 0;
86 }
87
88
89
90
91
92
93
94
95 static int set_input_auto_mute(struct echoaudio *chip, int automute)
96 {
97 dev_dbg(chip->card->dev, "set_input_auto_mute %d\n", automute);
98
99 chip->digital_in_automute = automute;
100
101
102
103 return set_input_clock(chip, chip->input_clock);
104 }
105
106
107
108
109 static int set_digital_mode(struct echoaudio *chip, u8 mode)
110 {
111 u8 previous_mode;
112 int err, i, o;
113
114 if (chip->bad_board)
115 return -EIO;
116
117
118 if (snd_BUG_ON(chip->pipe_alloc_mask))
119 return -EAGAIN;
120
121 if (snd_BUG_ON(!(chip->digital_modes & (1 << mode))))
122 return -EINVAL;
123
124 previous_mode = chip->digital_mode;
125 err = dsp_set_digital_mode(chip, mode);
126
127
128
129
130 if (err >= 0 && previous_mode != mode &&
131 (previous_mode == DIGITAL_MODE_ADAT || mode == DIGITAL_MODE_ADAT)) {
132 spin_lock_irq(&chip->lock);
133 for (o = 0; o < num_busses_out(chip); o++)
134 for (i = 0; i < num_busses_in(chip); i++)
135 set_monitor_gain(chip, o, i,
136 chip->monitor_gain[o][i]);
137
138 #ifdef ECHOCARD_HAS_INPUT_GAIN
139 for (i = 0; i < num_busses_in(chip); i++)
140 set_input_gain(chip, i, chip->input_gain[i]);
141 update_input_line_level(chip);
142 #endif
143
144 for (o = 0; o < num_busses_out(chip); o++)
145 set_output_gain(chip, o, chip->output_gain[o]);
146 update_output_line_level(chip);
147 spin_unlock_irq(&chip->lock);
148 }
149
150 return err;
151 }
152
153
154
155
156 static int set_professional_spdif(struct echoaudio *chip, char prof)
157 {
158 u32 control_reg;
159 int err;
160
161
162 control_reg = le32_to_cpu(chip->comm_page->control_register);
163 control_reg &= GML_SPDIF_FORMAT_CLEAR_MASK;
164
165
166 control_reg |= GML_SPDIF_TWO_CHANNEL | GML_SPDIF_24_BIT |
167 GML_SPDIF_COPY_PERMIT;
168 if (prof) {
169
170 control_reg |= GML_SPDIF_PRO_MODE;
171
172 switch (chip->sample_rate) {
173 case 32000:
174 control_reg |= GML_SPDIF_SAMPLE_RATE0 |
175 GML_SPDIF_SAMPLE_RATE1;
176 break;
177 case 44100:
178 control_reg |= GML_SPDIF_SAMPLE_RATE0;
179 break;
180 case 48000:
181 control_reg |= GML_SPDIF_SAMPLE_RATE1;
182 break;
183 }
184 } else {
185
186 switch (chip->sample_rate) {
187 case 32000:
188 control_reg |= GML_SPDIF_SAMPLE_RATE0 |
189 GML_SPDIF_SAMPLE_RATE1;
190 break;
191 case 48000:
192 control_reg |= GML_SPDIF_SAMPLE_RATE1;
193 break;
194 }
195 }
196
197 if ((err = write_control_reg(chip, control_reg, false)))
198 return err;
199 chip->professional_spdif = prof;
200 dev_dbg(chip->card->dev, "set_professional_spdif to %s\n",
201 prof ? "Professional" : "Consumer");
202 return 0;
203 }