diff options
Diffstat (limited to 'sound/pci/ice1712/juli.c')
-rw-r--r-- | sound/pci/ice1712/juli.c | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/sound/pci/ice1712/juli.c b/sound/pci/ice1712/juli.c index 1a435df423c6..e8038c0ceb72 100644 --- a/sound/pci/ice1712/juli.c +++ b/sound/pci/ice1712/juli.c | |||
@@ -32,6 +32,11 @@ | |||
32 | #include "envy24ht.h" | 32 | #include "envy24ht.h" |
33 | #include "juli.h" | 33 | #include "juli.h" |
34 | 34 | ||
35 | struct juli_spec { | ||
36 | struct ak4114 *ak4114; | ||
37 | unsigned int analog: 1; | ||
38 | }; | ||
39 | |||
35 | /* | 40 | /* |
36 | * chip addresses on I2C bus | 41 | * chip addresses on I2C bus |
37 | */ | 42 | */ |
@@ -137,12 +142,13 @@ static struct snd_akm4xxx akm_juli_dac __devinitdata = { | |||
137 | 142 | ||
138 | static int __devinit juli_add_controls(struct snd_ice1712 *ice) | 143 | static int __devinit juli_add_controls(struct snd_ice1712 *ice) |
139 | { | 144 | { |
145 | struct juli_spec *spec = ice->spec; | ||
140 | int err; | 146 | int err; |
141 | err = snd_ice1712_akm4xxx_build_controls(ice); | 147 | err = snd_ice1712_akm4xxx_build_controls(ice); |
142 | if (err < 0) | 148 | if (err < 0) |
143 | return err; | 149 | return err; |
144 | /* only capture SPDIF over AK4114 */ | 150 | /* only capture SPDIF over AK4114 */ |
145 | err = snd_ak4114_build(ice->spec.juli.ak4114, NULL, | 151 | err = snd_ak4114_build(spec->ak4114, NULL, |
146 | ice->pcm_pro->streams[SNDRV_PCM_STREAM_CAPTURE].substream); | 152 | ice->pcm_pro->streams[SNDRV_PCM_STREAM_CAPTURE].substream); |
147 | if (err < 0) | 153 | if (err < 0) |
148 | return err; | 154 | return err; |
@@ -166,13 +172,19 @@ static int __devinit juli_init(struct snd_ice1712 *ice) | |||
166 | 0x41, 0x02, 0x2c, 0x00, 0x00 | 172 | 0x41, 0x02, 0x2c, 0x00, 0x00 |
167 | }; | 173 | }; |
168 | int err; | 174 | int err; |
175 | struct juli_spec *spec; | ||
169 | struct snd_akm4xxx *ak; | 176 | struct snd_akm4xxx *ak; |
170 | 177 | ||
178 | spec = kzalloc(sizeof(*spec), GFP_KERNEL); | ||
179 | if (!spec) | ||
180 | return -ENOMEM; | ||
181 | ice->spec = spec; | ||
182 | |||
171 | err = snd_ak4114_create(ice->card, | 183 | err = snd_ak4114_create(ice->card, |
172 | juli_ak4114_read, | 184 | juli_ak4114_read, |
173 | juli_ak4114_write, | 185 | juli_ak4114_write, |
174 | ak4114_init_vals, ak4114_init_txcsb, | 186 | ak4114_init_vals, ak4114_init_txcsb, |
175 | ice, &ice->spec.juli.ak4114); | 187 | ice, &spec->ak4114); |
176 | if (err < 0) | 188 | if (err < 0) |
177 | return err; | 189 | return err; |
178 | 190 | ||
@@ -180,12 +192,12 @@ static int __devinit juli_init(struct snd_ice1712 *ice) | |||
180 | /* it seems that the analog doughter board detection does not work | 192 | /* it seems that the analog doughter board detection does not work |
181 | reliably, so force the analog flag; it should be very rare | 193 | reliably, so force the analog flag; it should be very rare |
182 | to use Juli@ without the analog doughter board */ | 194 | to use Juli@ without the analog doughter board */ |
183 | ice->spec.juli.analog = (ice->gpio.get_data(ice) & GPIO_ANALOG_PRESENT) ? 0 : 1; | 195 | spec->analog = (ice->gpio.get_data(ice) & GPIO_ANALOG_PRESENT) ? 0 : 1; |
184 | #else | 196 | #else |
185 | ice->spec.juli.analog = 1; | 197 | spec->analog = 1; |
186 | #endif | 198 | #endif |
187 | 199 | ||
188 | if (ice->spec.juli.analog) { | 200 | if (spec->analog) { |
189 | printk(KERN_INFO "juli@: analog I/O detected\n"); | 201 | printk(KERN_INFO "juli@: analog I/O detected\n"); |
190 | ice->num_total_dacs = 2; | 202 | ice->num_total_dacs = 2; |
191 | ice->num_total_adcs = 2; | 203 | ice->num_total_adcs = 2; |