aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClemens Ladisch <clemens@ladisch.de>2011-01-10 10:14:52 -0500
committerTakashi Iwai <tiwai@suse.de>2011-01-10 10:46:31 -0500
commit5b8bf2a54fb13e40519ee846ce27bc8a2d7a7878 (patch)
tree2aa57e62574054f6f9d5d8bf5eb55c72c227e787
parentbc29e262c3062682c6099bd455ae8544916f723e (diff)
ALSA: oxygen: simplify model-specific MCLK handling
Replace the get_i2s_mclk callback with tables of MCLK values. This simplifies the MCLK-handling code in both the framework and the model- specific drivers. Signed-off-by: Clemens Ladisch <clemens@ladisch.de> Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r--sound/pci/oxygen/oxygen.c3
-rw-r--r--sound/pci/oxygen/oxygen.h10
-rw-r--r--sound/pci/oxygen/oxygen_lib.c36
-rw-r--r--sound/pci/oxygen/oxygen_pcm.c39
-rw-r--r--sound/pci/oxygen/oxygen_regs.h8
-rw-r--r--sound/pci/oxygen/xonar_cs43xx.c3
-rw-r--r--sound/pci/oxygen/xonar_pcm179x.c82
-rw-r--r--sound/pci/oxygen/xonar_wm87x6.c3
8 files changed, 89 insertions, 95 deletions
diff --git a/sound/pci/oxygen/oxygen.c b/sound/pci/oxygen/oxygen.c
index fe7ed4fc9f46..784d500c700f 100644
--- a/sound/pci/oxygen/oxygen.c
+++ b/sound/pci/oxygen/oxygen.c
@@ -568,7 +568,6 @@ static const struct oxygen_model model_generic = {
568 .mixer_init = generic_wm8785_mixer_init, 568 .mixer_init = generic_wm8785_mixer_init,
569 .cleanup = generic_cleanup, 569 .cleanup = generic_cleanup,
570 .resume = generic_resume, 570 .resume = generic_resume,
571 .get_i2s_mclk = oxygen_default_i2s_mclk,
572 .set_dac_params = set_ak4396_params, 571 .set_dac_params = set_ak4396_params,
573 .set_adc_params = set_wm8785_params, 572 .set_adc_params = set_wm8785_params,
574 .update_dac_volume = update_ak4396_volume, 573 .update_dac_volume = update_ak4396_volume,
@@ -589,6 +588,8 @@ static const struct oxygen_model model_generic = {
589 .dac_volume_max = 255, 588 .dac_volume_max = 255,
590 .function_flags = OXYGEN_FUNCTION_SPI | 589 .function_flags = OXYGEN_FUNCTION_SPI |
591 OXYGEN_FUNCTION_ENABLE_SPI_4_5, 590 OXYGEN_FUNCTION_ENABLE_SPI_4_5,
591 .dac_mclks = OXYGEN_MCLKS(256, 256, 128),
592 .adc_mclks = OXYGEN_MCLKS(256, 256, 128),
592 .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 593 .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
593 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 594 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
594}; 595};
diff --git a/sound/pci/oxygen/oxygen.h b/sound/pci/oxygen/oxygen.h
index 70eff3747158..2c5fb9edcb11 100644
--- a/sound/pci/oxygen/oxygen.h
+++ b/sound/pci/oxygen/oxygen.h
@@ -16,6 +16,10 @@
16#define PCM_AC97 5 16#define PCM_AC97 5
17#define PCM_COUNT 6 17#define PCM_COUNT 6
18 18
19#define OXYGEN_MCLKS(f_single, f_double, f_quad) ((MCLK_##f_single << 0) | \
20 (MCLK_##f_double << 2) | \
21 (MCLK_##f_quad << 4))
22
19#define OXYGEN_IO_SIZE 0x100 23#define OXYGEN_IO_SIZE 0x100
20 24
21#define OXYGEN_EEPROM_ID 0x434d /* "CM" */ 25#define OXYGEN_EEPROM_ID 0x434d /* "CM" */
@@ -81,8 +85,6 @@ struct oxygen_model {
81 void (*resume)(struct oxygen *chip); 85 void (*resume)(struct oxygen *chip);
82 void (*pcm_hardware_filter)(unsigned int channel, 86 void (*pcm_hardware_filter)(unsigned int channel,
83 struct snd_pcm_hardware *hardware); 87 struct snd_pcm_hardware *hardware);
84 unsigned int (*get_i2s_mclk)(struct oxygen *chip, unsigned int channel,
85 struct snd_pcm_hw_params *hw_params);
86 void (*set_dac_params)(struct oxygen *chip, 88 void (*set_dac_params)(struct oxygen *chip,
87 struct snd_pcm_hw_params *params); 89 struct snd_pcm_hw_params *params);
88 void (*set_adc_params)(struct oxygen *chip, 90 void (*set_adc_params)(struct oxygen *chip,
@@ -105,6 +107,8 @@ struct oxygen_model {
105 u8 dac_volume_max; 107 u8 dac_volume_max;
106 u8 misc_flags; 108 u8 misc_flags;
107 u8 function_flags; 109 u8 function_flags;
110 u8 dac_mclks;
111 u8 adc_mclks;
108 u16 dac_i2s_format; 112 u16 dac_i2s_format;
109 u16 adc_i2s_format; 113 u16 adc_i2s_format;
110}; 114};
@@ -171,8 +175,6 @@ void oxygen_update_spdif_source(struct oxygen *chip);
171/* oxygen_pcm.c */ 175/* oxygen_pcm.c */
172 176
173int oxygen_pcm_init(struct oxygen *chip); 177int oxygen_pcm_init(struct oxygen *chip);
174unsigned int oxygen_default_i2s_mclk(struct oxygen *chip, unsigned int channel,
175 struct snd_pcm_hw_params *hw_params);
176 178
177/* oxygen_io.c */ 179/* oxygen_io.c */
178 180
diff --git a/sound/pci/oxygen/oxygen_lib.c b/sound/pci/oxygen/oxygen_lib.c
index c44c91e6fb18..77e1f0805633 100644
--- a/sound/pci/oxygen/oxygen_lib.c
+++ b/sound/pci/oxygen/oxygen_lib.c
@@ -414,28 +414,40 @@ static void oxygen_init(struct oxygen *chip)
414 (OXYGEN_FORMAT_16 << OXYGEN_MULTICH_FORMAT_SHIFT)); 414 (OXYGEN_FORMAT_16 << OXYGEN_MULTICH_FORMAT_SHIFT));
415 oxygen_write8(chip, OXYGEN_REC_CHANNELS, OXYGEN_REC_CHANNELS_2_2_2); 415 oxygen_write8(chip, OXYGEN_REC_CHANNELS, OXYGEN_REC_CHANNELS_2_2_2);
416 oxygen_write16(chip, OXYGEN_I2S_MULTICH_FORMAT, 416 oxygen_write16(chip, OXYGEN_I2S_MULTICH_FORMAT,
417 OXYGEN_RATE_48000 | chip->model.dac_i2s_format | 417 OXYGEN_RATE_48000 |
418 OXYGEN_I2S_MCLK_256 | OXYGEN_I2S_BITS_16 | 418 chip->model.dac_i2s_format |
419 OXYGEN_I2S_MASTER | OXYGEN_I2S_BCLK_64); 419 OXYGEN_I2S_MCLK(chip->model.dac_mclks) |
420 OXYGEN_I2S_BITS_16 |
421 OXYGEN_I2S_MASTER |
422 OXYGEN_I2S_BCLK_64);
420 if (chip->model.device_config & CAPTURE_0_FROM_I2S_1) 423 if (chip->model.device_config & CAPTURE_0_FROM_I2S_1)
421 oxygen_write16(chip, OXYGEN_I2S_A_FORMAT, 424 oxygen_write16(chip, OXYGEN_I2S_A_FORMAT,
422 OXYGEN_RATE_48000 | chip->model.adc_i2s_format | 425 OXYGEN_RATE_48000 |
423 OXYGEN_I2S_MCLK_256 | OXYGEN_I2S_BITS_16 | 426 chip->model.adc_i2s_format |
424 OXYGEN_I2S_MASTER | OXYGEN_I2S_BCLK_64); 427 OXYGEN_I2S_MCLK(chip->model.adc_mclks) |
428 OXYGEN_I2S_BITS_16 |
429 OXYGEN_I2S_MASTER |
430 OXYGEN_I2S_BCLK_64);
425 else 431 else
426 oxygen_write16(chip, OXYGEN_I2S_A_FORMAT, 432 oxygen_write16(chip, OXYGEN_I2S_A_FORMAT,
427 OXYGEN_I2S_MASTER | OXYGEN_I2S_MUTE_MCLK); 433 OXYGEN_I2S_MASTER |
434 OXYGEN_I2S_MUTE_MCLK);
428 if (chip->model.device_config & (CAPTURE_0_FROM_I2S_2 | 435 if (chip->model.device_config & (CAPTURE_0_FROM_I2S_2 |
429 CAPTURE_2_FROM_I2S_2)) 436 CAPTURE_2_FROM_I2S_2))
430 oxygen_write16(chip, OXYGEN_I2S_B_FORMAT, 437 oxygen_write16(chip, OXYGEN_I2S_B_FORMAT,
431 OXYGEN_RATE_48000 | chip->model.adc_i2s_format | 438 OXYGEN_RATE_48000 |
432 OXYGEN_I2S_MCLK_256 | OXYGEN_I2S_BITS_16 | 439 chip->model.adc_i2s_format |
433 OXYGEN_I2S_MASTER | OXYGEN_I2S_BCLK_64); 440 OXYGEN_I2S_MCLK(chip->model.adc_mclks) |
441 OXYGEN_I2S_BITS_16 |
442 OXYGEN_I2S_MASTER |
443 OXYGEN_I2S_BCLK_64);
434 else 444 else
435 oxygen_write16(chip, OXYGEN_I2S_B_FORMAT, 445 oxygen_write16(chip, OXYGEN_I2S_B_FORMAT,
436 OXYGEN_I2S_MASTER | OXYGEN_I2S_MUTE_MCLK); 446 OXYGEN_I2S_MASTER |
447 OXYGEN_I2S_MUTE_MCLK);
437 oxygen_write16(chip, OXYGEN_I2S_C_FORMAT, 448 oxygen_write16(chip, OXYGEN_I2S_C_FORMAT,
438 OXYGEN_I2S_MASTER | OXYGEN_I2S_MUTE_MCLK); 449 OXYGEN_I2S_MASTER |
450 OXYGEN_I2S_MUTE_MCLK);
439 oxygen_clear_bits32(chip, OXYGEN_SPDIF_CONTROL, 451 oxygen_clear_bits32(chip, OXYGEN_SPDIF_CONTROL,
440 OXYGEN_SPDIF_OUT_ENABLE | 452 OXYGEN_SPDIF_OUT_ENABLE |
441 OXYGEN_SPDIF_LOOPBACK); 453 OXYGEN_SPDIF_LOOPBACK);
diff --git a/sound/pci/oxygen/oxygen_pcm.c b/sound/pci/oxygen/oxygen_pcm.c
index dc3c68f76df4..d5533e34ece9 100644
--- a/sound/pci/oxygen/oxygen_pcm.c
+++ b/sound/pci/oxygen/oxygen_pcm.c
@@ -274,17 +274,6 @@ static unsigned int oxygen_rate(struct snd_pcm_hw_params *hw_params)
274 } 274 }
275} 275}
276 276
277unsigned int oxygen_default_i2s_mclk(struct oxygen *chip,
278 unsigned int channel,
279 struct snd_pcm_hw_params *hw_params)
280{
281 if (params_rate(hw_params) <= 96000)
282 return OXYGEN_I2S_MCLK_256;
283 else
284 return OXYGEN_I2S_MCLK_128;
285}
286EXPORT_SYMBOL(oxygen_default_i2s_mclk);
287
288static unsigned int oxygen_i2s_bits(struct snd_pcm_hw_params *hw_params) 277static unsigned int oxygen_i2s_bits(struct snd_pcm_hw_params *hw_params)
289{ 278{
290 if (params_format(hw_params) == SNDRV_PCM_FORMAT_S32_LE) 279 if (params_format(hw_params) == SNDRV_PCM_FORMAT_S32_LE)
@@ -344,6 +333,26 @@ static int oxygen_hw_params(struct snd_pcm_substream *substream,
344 return 0; 333 return 0;
345} 334}
346 335
336static u16 get_mclk(struct oxygen *chip, unsigned int channel,
337 struct snd_pcm_hw_params *params)
338{
339 unsigned int mclks, shift;
340
341 if (channel == PCM_MULTICH)
342 mclks = chip->model.dac_mclks;
343 else
344 mclks = chip->model.adc_mclks;
345
346 if (params_rate(params) <= 48000)
347 shift = 0;
348 else if (params_rate(params) <= 96000)
349 shift = 2;
350 else
351 shift = 4;
352
353 return OXYGEN_I2S_MCLK(mclks >> shift);
354}
355
347static int oxygen_rec_a_hw_params(struct snd_pcm_substream *substream, 356static int oxygen_rec_a_hw_params(struct snd_pcm_substream *substream,
348 struct snd_pcm_hw_params *hw_params) 357 struct snd_pcm_hw_params *hw_params)
349{ 358{
@@ -360,8 +369,8 @@ static int oxygen_rec_a_hw_params(struct snd_pcm_substream *substream,
360 OXYGEN_REC_FORMAT_A_MASK); 369 OXYGEN_REC_FORMAT_A_MASK);
361 oxygen_write16_masked(chip, OXYGEN_I2S_A_FORMAT, 370 oxygen_write16_masked(chip, OXYGEN_I2S_A_FORMAT,
362 oxygen_rate(hw_params) | 371 oxygen_rate(hw_params) |
363 chip->model.get_i2s_mclk(chip, PCM_A, hw_params) |
364 chip->model.adc_i2s_format | 372 chip->model.adc_i2s_format |
373 get_mclk(chip, PCM_A, hw_params) |
365 oxygen_i2s_bits(hw_params), 374 oxygen_i2s_bits(hw_params),
366 OXYGEN_I2S_RATE_MASK | 375 OXYGEN_I2S_RATE_MASK |
367 OXYGEN_I2S_FORMAT_MASK | 376 OXYGEN_I2S_FORMAT_MASK |
@@ -396,9 +405,8 @@ static int oxygen_rec_b_hw_params(struct snd_pcm_substream *substream,
396 if (!is_ac97) 405 if (!is_ac97)
397 oxygen_write16_masked(chip, OXYGEN_I2S_B_FORMAT, 406 oxygen_write16_masked(chip, OXYGEN_I2S_B_FORMAT,
398 oxygen_rate(hw_params) | 407 oxygen_rate(hw_params) |
399 chip->model.get_i2s_mclk(chip, PCM_B,
400 hw_params) |
401 chip->model.adc_i2s_format | 408 chip->model.adc_i2s_format |
409 get_mclk(chip, PCM_B, hw_params) |
402 oxygen_i2s_bits(hw_params), 410 oxygen_i2s_bits(hw_params),
403 OXYGEN_I2S_RATE_MASK | 411 OXYGEN_I2S_RATE_MASK |
404 OXYGEN_I2S_FORMAT_MASK | 412 OXYGEN_I2S_FORMAT_MASK |
@@ -479,8 +487,7 @@ static int oxygen_multich_hw_params(struct snd_pcm_substream *substream,
479 oxygen_write16_masked(chip, OXYGEN_I2S_MULTICH_FORMAT, 487 oxygen_write16_masked(chip, OXYGEN_I2S_MULTICH_FORMAT,
480 oxygen_rate(hw_params) | 488 oxygen_rate(hw_params) |
481 chip->model.dac_i2s_format | 489 chip->model.dac_i2s_format |
482 chip->model.get_i2s_mclk(chip, PCM_MULTICH, 490 get_mclk(chip, PCM_MULTICH, hw_params) |
483 hw_params) |
484 oxygen_i2s_bits(hw_params), 491 oxygen_i2s_bits(hw_params),
485 OXYGEN_I2S_RATE_MASK | 492 OXYGEN_I2S_RATE_MASK |
486 OXYGEN_I2S_FORMAT_MASK | 493 OXYGEN_I2S_FORMAT_MASK |
diff --git a/sound/pci/oxygen/oxygen_regs.h b/sound/pci/oxygen/oxygen_regs.h
index 331d3d96fa21..63dc7a0ab555 100644
--- a/sound/pci/oxygen/oxygen_regs.h
+++ b/sound/pci/oxygen/oxygen_regs.h
@@ -139,9 +139,11 @@
139#define OXYGEN_I2S_FORMAT_I2S 0x0000 139#define OXYGEN_I2S_FORMAT_I2S 0x0000
140#define OXYGEN_I2S_FORMAT_LJUST 0x0008 140#define OXYGEN_I2S_FORMAT_LJUST 0x0008
141#define OXYGEN_I2S_MCLK_MASK 0x0030 /* MCLK/LRCK */ 141#define OXYGEN_I2S_MCLK_MASK 0x0030 /* MCLK/LRCK */
142#define OXYGEN_I2S_MCLK_128 0x0000 142#define OXYGEN_I2S_MCLK_SHIFT 4
143#define OXYGEN_I2S_MCLK_256 0x0010 143#define MCLK_128 0
144#define OXYGEN_I2S_MCLK_512 0x0020 144#define MCLK_256 1
145#define MCLK_512 2
146#define OXYGEN_I2S_MCLK(f) (((f) & 3) << OXYGEN_I2S_MCLK_SHIFT)
145#define OXYGEN_I2S_BITS_MASK 0x00c0 147#define OXYGEN_I2S_BITS_MASK 0x00c0
146#define OXYGEN_I2S_BITS_16 0x0000 148#define OXYGEN_I2S_BITS_16 0x0000
147#define OXYGEN_I2S_BITS_20 0x0040 149#define OXYGEN_I2S_BITS_20 0x0040
diff --git a/sound/pci/oxygen/xonar_cs43xx.c b/sound/pci/oxygen/xonar_cs43xx.c
index a25197ca39a1..b651938f3248 100644
--- a/sound/pci/oxygen/xonar_cs43xx.c
+++ b/sound/pci/oxygen/xonar_cs43xx.c
@@ -412,7 +412,6 @@ static const struct oxygen_model model_xonar_d1 = {
412 .cleanup = xonar_d1_cleanup, 412 .cleanup = xonar_d1_cleanup,
413 .suspend = xonar_d1_suspend, 413 .suspend = xonar_d1_suspend,
414 .resume = xonar_d1_resume, 414 .resume = xonar_d1_resume,
415 .get_i2s_mclk = oxygen_default_i2s_mclk,
416 .set_dac_params = set_cs43xx_params, 415 .set_dac_params = set_cs43xx_params,
417 .set_adc_params = xonar_set_cs53x1_params, 416 .set_adc_params = xonar_set_cs53x1_params,
418 .update_dac_volume = update_cs43xx_volume, 417 .update_dac_volume = update_cs43xx_volume,
@@ -431,6 +430,8 @@ static const struct oxygen_model model_xonar_d1 = {
431 .dac_volume_min = 127 - 60, 430 .dac_volume_min = 127 - 60,
432 .dac_volume_max = 127, 431 .dac_volume_max = 127,
433 .function_flags = OXYGEN_FUNCTION_2WIRE, 432 .function_flags = OXYGEN_FUNCTION_2WIRE,
433 .dac_mclks = OXYGEN_MCLKS(256, 256, 128),
434 .adc_mclks = OXYGEN_MCLKS(256, 256, 128),
434 .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 435 .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
435 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 436 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
436}; 437};
diff --git a/sound/pci/oxygen/xonar_pcm179x.c b/sound/pci/oxygen/xonar_pcm179x.c
index e15ecee2ccf7..9787193f6ed3 100644
--- a/sound/pci/oxygen/xonar_pcm179x.c
+++ b/sound/pci/oxygen/xonar_pcm179x.c
@@ -335,10 +335,6 @@ static void pcm1796_init(struct oxygen *chip)
335 data->h6 ? PCM1796_OS_64 : PCM1796_OS_128; 335 data->h6 ? PCM1796_OS_64 : PCM1796_OS_128;
336 pcm1796_registers_init(chip); 336 pcm1796_registers_init(chip);
337 data->current_rate = 48000; 337 data->current_rate = 48000;
338 if (!data->h6)
339 oxygen_write16_masked(chip, OXYGEN_I2S_MULTICH_FORMAT,
340 OXYGEN_I2S_MCLK_512,
341 OXYGEN_I2S_MCLK_MASK);
342} 338}
343 339
344static void xonar_d2_init(struct oxygen *chip) 340static void xonar_d2_init(struct oxygen *chip)
@@ -476,7 +472,7 @@ static void xonar_st_init(struct oxygen *chip)
476 oxygen_write16(chip, OXYGEN_I2S_A_FORMAT, 472 oxygen_write16(chip, OXYGEN_I2S_A_FORMAT,
477 OXYGEN_RATE_48000 | 473 OXYGEN_RATE_48000 |
478 OXYGEN_I2S_FORMAT_I2S | 474 OXYGEN_I2S_FORMAT_I2S |
479 (data->h6 ? OXYGEN_I2S_MCLK_256 : OXYGEN_I2S_MCLK_512) | 475 OXYGEN_I2S_MCLK(data->h6 ? MCLK_256 : MCLK_512) |
480 OXYGEN_I2S_BITS_16 | 476 OXYGEN_I2S_BITS_16 |
481 OXYGEN_I2S_MASTER | 477 OXYGEN_I2S_MASTER |
482 OXYGEN_I2S_BCLK_64); 478 OXYGEN_I2S_BCLK_64);
@@ -560,26 +556,6 @@ static void xonar_st_resume(struct oxygen *chip)
560 xonar_stx_resume(chip); 556 xonar_stx_resume(chip);
561} 557}
562 558
563static unsigned int mclk_from_rate(struct oxygen *chip, unsigned int rate)
564{
565 struct xonar_pcm179x *data = chip->model_data;
566
567 if (rate <= 48000)
568 return data->h6 ? OXYGEN_I2S_MCLK_256 : OXYGEN_I2S_MCLK_512;
569 else
570 return OXYGEN_I2S_MCLK_128;
571}
572
573static unsigned int get_pcm1796_i2s_mclk(struct oxygen *chip,
574 unsigned int channel,
575 struct snd_pcm_hw_params *params)
576{
577 if (channel == PCM_MULTICH)
578 return mclk_from_rate(chip, params_rate(params));
579 else
580 return oxygen_default_i2s_mclk(chip, channel, params);
581}
582
583static void update_pcm1796_oversampling(struct oxygen *chip) 559static void update_pcm1796_oversampling(struct oxygen *chip)
584{ 560{
585 struct xonar_pcm179x *data = chip->model_data; 561 struct xonar_pcm179x *data = chip->model_data;
@@ -640,45 +616,32 @@ static void update_cs2000_rate(struct oxygen *chip, unsigned int rate)
640 616
641 switch (rate) { 617 switch (rate) {
642 case 32000: 618 case 32000:
643 if (data->h6)
644 rate_mclk = OXYGEN_RATE_32000 | OXYGEN_I2S_MCLK_256;
645 else
646 rate_mclk = OXYGEN_RATE_32000 | OXYGEN_I2S_MCLK_512;
647 break;
648 case 44100:
649 if (data->h6)
650 rate_mclk = OXYGEN_RATE_44100 | OXYGEN_I2S_MCLK_256;
651 else
652 rate_mclk = OXYGEN_RATE_44100 | OXYGEN_I2S_MCLK_512;
653 break;
654 default: /* 48000 */
655 if (data->h6)
656 rate_mclk = OXYGEN_RATE_48000 | OXYGEN_I2S_MCLK_256;
657 else
658 rate_mclk = OXYGEN_RATE_48000 | OXYGEN_I2S_MCLK_512;
659 break;
660 case 64000: 619 case 64000:
661 rate_mclk = OXYGEN_RATE_32000 | OXYGEN_I2S_MCLK_256; 620 rate_mclk = OXYGEN_RATE_32000;
662 break; 621 break;
622 case 44100:
663 case 88200: 623 case 88200:
664 rate_mclk = OXYGEN_RATE_44100 | OXYGEN_I2S_MCLK_256;
665 break;
666 case 96000:
667 rate_mclk = OXYGEN_RATE_48000 | OXYGEN_I2S_MCLK_256;
668 break;
669 case 176400: 624 case 176400:
670 rate_mclk = OXYGEN_RATE_44100 | OXYGEN_I2S_MCLK_512; 625 rate_mclk = OXYGEN_RATE_44100;
671 break; 626 break;
627 default:
628 case 48000:
629 case 96000:
672 case 192000: 630 case 192000:
673 rate_mclk = OXYGEN_RATE_48000 | OXYGEN_I2S_MCLK_512; 631 rate_mclk = OXYGEN_RATE_48000;
674 break; 632 break;
675 } 633 }
676 oxygen_write16_masked(chip, OXYGEN_I2S_A_FORMAT, rate_mclk, 634
677 OXYGEN_I2S_RATE_MASK | OXYGEN_I2S_MCLK_MASK); 635 if (rate <= 96000 && (rate > 48000 || data->h6)) {
678 if ((rate_mclk & OXYGEN_I2S_MCLK_MASK) <= OXYGEN_I2S_MCLK_256) 636 rate_mclk |= OXYGEN_I2S_MCLK(MCLK_256);
679 reg = CS2000_REF_CLK_DIV_1; 637 reg = CS2000_REF_CLK_DIV_1;
680 else 638 } else {
639 rate_mclk |= OXYGEN_I2S_MCLK(MCLK_512);
681 reg = CS2000_REF_CLK_DIV_2; 640 reg = CS2000_REF_CLK_DIV_2;
641 }
642
643 oxygen_write16_masked(chip, OXYGEN_I2S_A_FORMAT, rate_mclk,
644 OXYGEN_I2S_RATE_MASK | OXYGEN_I2S_MCLK_MASK);
682 cs2000_write_cached(chip, CS2000_FUN_CFG_1, reg); 645 cs2000_write_cached(chip, CS2000_FUN_CFG_1, reg);
683 msleep(3); /* PLL lock delay */ 646 msleep(3); /* PLL lock delay */
684} 647}
@@ -1047,7 +1010,6 @@ static const struct oxygen_model model_xonar_d2 = {
1047 .cleanup = xonar_d2_cleanup, 1010 .cleanup = xonar_d2_cleanup,
1048 .suspend = xonar_d2_suspend, 1011 .suspend = xonar_d2_suspend,
1049 .resume = xonar_d2_resume, 1012 .resume = xonar_d2_resume,
1050 .get_i2s_mclk = get_pcm1796_i2s_mclk,
1051 .set_dac_params = set_pcm1796_params, 1013 .set_dac_params = set_pcm1796_params,
1052 .set_adc_params = xonar_set_cs53x1_params, 1014 .set_adc_params = xonar_set_cs53x1_params,
1053 .update_dac_volume = update_pcm1796_volume, 1015 .update_dac_volume = update_pcm1796_volume,
@@ -1069,6 +1031,8 @@ static const struct oxygen_model model_xonar_d2 = {
1069 .misc_flags = OXYGEN_MISC_MIDI, 1031 .misc_flags = OXYGEN_MISC_MIDI,
1070 .function_flags = OXYGEN_FUNCTION_SPI | 1032 .function_flags = OXYGEN_FUNCTION_SPI |
1071 OXYGEN_FUNCTION_ENABLE_SPI_4_5, 1033 OXYGEN_FUNCTION_ENABLE_SPI_4_5,
1034 .dac_mclks = OXYGEN_MCLKS(512, 128, 128),
1035 .adc_mclks = OXYGEN_MCLKS(256, 256, 128),
1072 .dac_i2s_format = OXYGEN_I2S_FORMAT_I2S, 1036 .dac_i2s_format = OXYGEN_I2S_FORMAT_I2S,
1073 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 1037 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
1074}; 1038};
@@ -1082,7 +1046,6 @@ static const struct oxygen_model model_xonar_hdav = {
1082 .suspend = xonar_hdav_suspend, 1046 .suspend = xonar_hdav_suspend,
1083 .resume = xonar_hdav_resume, 1047 .resume = xonar_hdav_resume,
1084 .pcm_hardware_filter = xonar_hdmi_pcm_hardware_filter, 1048 .pcm_hardware_filter = xonar_hdmi_pcm_hardware_filter,
1085 .get_i2s_mclk = get_pcm1796_i2s_mclk,
1086 .set_dac_params = set_hdav_params, 1049 .set_dac_params = set_hdav_params,
1087 .set_adc_params = xonar_set_cs53x1_params, 1050 .set_adc_params = xonar_set_cs53x1_params,
1088 .update_dac_volume = update_pcm1796_volume, 1051 .update_dac_volume = update_pcm1796_volume,
@@ -1102,6 +1065,8 @@ static const struct oxygen_model model_xonar_hdav = {
1102 .dac_volume_max = 255, 1065 .dac_volume_max = 255,
1103 .misc_flags = OXYGEN_MISC_MIDI, 1066 .misc_flags = OXYGEN_MISC_MIDI,
1104 .function_flags = OXYGEN_FUNCTION_2WIRE, 1067 .function_flags = OXYGEN_FUNCTION_2WIRE,
1068 .dac_mclks = OXYGEN_MCLKS(512, 128, 128),
1069 .adc_mclks = OXYGEN_MCLKS(256, 256, 128),
1105 .dac_i2s_format = OXYGEN_I2S_FORMAT_I2S, 1070 .dac_i2s_format = OXYGEN_I2S_FORMAT_I2S,
1106 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 1071 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
1107}; 1072};
@@ -1114,7 +1079,6 @@ static const struct oxygen_model model_xonar_st = {
1114 .cleanup = xonar_st_cleanup, 1079 .cleanup = xonar_st_cleanup,
1115 .suspend = xonar_st_suspend, 1080 .suspend = xonar_st_suspend,
1116 .resume = xonar_st_resume, 1081 .resume = xonar_st_resume,
1117 .get_i2s_mclk = get_pcm1796_i2s_mclk,
1118 .set_dac_params = set_st_params, 1082 .set_dac_params = set_st_params,
1119 .set_adc_params = xonar_set_cs53x1_params, 1083 .set_adc_params = xonar_set_cs53x1_params,
1120 .update_dac_volume = update_pcm1796_volume, 1084 .update_dac_volume = update_pcm1796_volume,
@@ -1132,6 +1096,8 @@ static const struct oxygen_model model_xonar_st = {
1132 .dac_volume_min = 255 - 2*60, 1096 .dac_volume_min = 255 - 2*60,
1133 .dac_volume_max = 255, 1097 .dac_volume_max = 255,
1134 .function_flags = OXYGEN_FUNCTION_2WIRE, 1098 .function_flags = OXYGEN_FUNCTION_2WIRE,
1099 .dac_mclks = OXYGEN_MCLKS(512, 128, 128),
1100 .adc_mclks = OXYGEN_MCLKS(256, 256, 128),
1135 .dac_i2s_format = OXYGEN_I2S_FORMAT_I2S, 1101 .dac_i2s_format = OXYGEN_I2S_FORMAT_I2S,
1136 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 1102 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
1137}; 1103};
@@ -1159,6 +1125,7 @@ int __devinit get_xonar_pcm179x_model(struct oxygen *chip,
1159 case GPIO_DB_H6: 1125 case GPIO_DB_H6:
1160 chip->model.shortname = "Xonar HDAV1.3+H6"; 1126 chip->model.shortname = "Xonar HDAV1.3+H6";
1161 chip->model.dac_channels_mixer = 8; 1127 chip->model.dac_channels_mixer = 8;
1128 chip->model.dac_mclks = OXYGEN_MCLKS(256, 128, 128);
1162 break; 1129 break;
1163 } 1130 }
1164 break; 1131 break;
@@ -1174,6 +1141,7 @@ int __devinit get_xonar_pcm179x_model(struct oxygen *chip,
1174 chip->model.control_filter = xonar_st_h6_control_filter; 1141 chip->model.control_filter = xonar_st_h6_control_filter;
1175 chip->model.dac_channels_pcm = 8; 1142 chip->model.dac_channels_pcm = 8;
1176 chip->model.dac_channels_mixer = 8; 1143 chip->model.dac_channels_mixer = 8;
1144 chip->model.dac_mclks = OXYGEN_MCLKS(256, 128, 128);
1177 break; 1145 break;
1178 } 1146 }
1179 break; 1147 break;
diff --git a/sound/pci/oxygen/xonar_wm87x6.c b/sound/pci/oxygen/xonar_wm87x6.c
index da92cc24eed2..4f9657084603 100644
--- a/sound/pci/oxygen/xonar_wm87x6.c
+++ b/sound/pci/oxygen/xonar_wm87x6.c
@@ -1122,7 +1122,6 @@ static const struct oxygen_model model_xonar_ds = {
1122 .suspend = xonar_ds_suspend, 1122 .suspend = xonar_ds_suspend,
1123 .resume = xonar_ds_resume, 1123 .resume = xonar_ds_resume,
1124 .pcm_hardware_filter = wm8776_adc_hardware_filter, 1124 .pcm_hardware_filter = wm8776_adc_hardware_filter,
1125 .get_i2s_mclk = oxygen_default_i2s_mclk,
1126 .set_dac_params = set_wm87x6_dac_params, 1125 .set_dac_params = set_wm87x6_dac_params,
1127 .set_adc_params = set_wm8776_adc_params, 1126 .set_adc_params = set_wm8776_adc_params,
1128 .update_dac_volume = update_wm87x6_volume, 1127 .update_dac_volume = update_wm87x6_volume,
@@ -1140,6 +1139,8 @@ static const struct oxygen_model model_xonar_ds = {
1140 .dac_volume_min = 255 - 2*60, 1139 .dac_volume_min = 255 - 2*60,
1141 .dac_volume_max = 255, 1140 .dac_volume_max = 255,
1142 .function_flags = OXYGEN_FUNCTION_SPI, 1141 .function_flags = OXYGEN_FUNCTION_SPI,
1142 .dac_mclks = OXYGEN_MCLKS(256, 256, 128),
1143 .adc_mclks = OXYGEN_MCLKS(256, 256, 128),
1143 .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 1144 .dac_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
1144 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST, 1145 .adc_i2s_format = OXYGEN_I2S_FORMAT_LJUST,
1145}; 1146};