Linux Audio

Check our new training course

Loading...
v5.9
   1// SPDX-License-Identifier: GPL-2.0-or-later
   2/*
   3 *  Copyright (c) 2004 James Courtier-Dutton <James@superbug.demon.co.uk>
   4 *  Driver CA0106 chips. e.g. Sound Blaster Audigy LS and Live 24bit
   5 *  Version: 0.0.25
   6 *
   7 *  FEATURES currently supported:
   8 *    Front, Rear and Center/LFE.
   9 *    Surround40 and Surround51.
  10 *    Capture from MIC an LINE IN input.
  11 *    SPDIF digital playback of PCM stereo and AC3/DTS works.
  12 *    (One can use a standard mono mini-jack to one RCA plugs cable.
  13 *     or one can use a standard stereo mini-jack to two RCA plugs cable.
  14 *     Plug one of the RCA plugs into the Coax input of the external decoder/receiver.)
  15 *    ( In theory one could output 3 different AC3 streams at once, to 3 different SPDIF outputs. )
  16 *    Notes on how to capture sound:
  17 *      The AC97 is used in the PLAYBACK direction.
  18 *      The output from the AC97 chip, instead of reaching the speakers, is fed into the Philips 1361T ADC.
  19 *      So, to record from the MIC, set the MIC Playback volume to max,
  20 *      unmute the MIC and turn up the MASTER Playback volume.
  21 *      So, to prevent feedback when capturing, minimise the "Capture feedback into Playback" volume.
  22 *   
  23 *    The only playback controls that currently do anything are: -
  24 *    Analog Front
  25 *    Analog Rear
  26 *    Analog Center/LFE
  27 *    SPDIF Front
  28 *    SPDIF Rear
  29 *    SPDIF Center/LFE
  30 *   
  31 *    For capture from Mic in or Line in.
  32 *    Digital/Analog ( switch must be in Analog mode for CAPTURE. )
  33 * 
  34 *    CAPTURE feedback into PLAYBACK
  35 * 
  36 *  Changelog:
  37 *    Support interrupts per period.
  38 *    Removed noise from Center/LFE channel when in Analog mode.
  39 *    Rename and remove mixer controls.
  40 *  0.0.6
  41 *    Use separate card based DMA buffer for periods table list.
  42 *  0.0.7
  43 *    Change remove and rename ctrls into lists.
  44 *  0.0.8
  45 *    Try to fix capture sources.
  46 *  0.0.9
  47 *    Fix AC3 output.
  48 *    Enable S32_LE format support.
  49 *  0.0.10
  50 *    Enable playback 48000 and 96000 rates. (Rates other that these do not work, even with "plug:front".)
  51 *  0.0.11
  52 *    Add Model name recognition.
  53 *  0.0.12
  54 *    Correct interrupt timing. interrupt at end of period, instead of in the middle of a playback period.
  55 *    Remove redundent "voice" handling.
  56 *  0.0.13
  57 *    Single trigger call for multi channels.
  58 *  0.0.14
  59 *    Set limits based on what the sound card hardware can do.
  60 *    playback periods_min=2, periods_max=8
  61 *    capture hw constraints require period_size = n * 64 bytes.
  62 *    playback hw constraints require period_size = n * 64 bytes.
  63 *  0.0.15
  64 *    Minor updates.
  65 *  0.0.16
  66 *    Implement 192000 sample rate.
  67 *  0.0.17
  68 *    Add support for SB0410 and SB0413.
  69 *  0.0.18
  70 *    Modified Copyright message.
  71 *  0.0.19
  72 *    Finally fix support for SB Live 24 bit. SB0410 and SB0413.
  73 *    The output codec needs resetting, otherwise all output is muted.
  74 *  0.0.20
  75 *    Merge "pci_disable_device(pci);" fixes.
  76 *  0.0.21
  77 *    Add 4 capture channels. (SPDIF only comes in on channel 0. )
  78 *    Add SPDIF capture using optional digital I/O module for SB Live 24bit. (Analog capture does not yet work.)
  79 *  0.0.22
  80 *    Add support for MSI K8N Diamond Motherboard with onboard SB Live 24bit without AC97. From kiksen, bug #901
  81 *  0.0.23
  82 *    Implement support for Line-in capture on SB Live 24bit.
  83 *  0.0.24
  84 *    Add support for mute control on SB Live 24bit (cards w/ SPI DAC)
  85 *  0.0.25
  86 *    Powerdown SPI DAC channels when not in use
  87 *
  88 *  BUGS:
  89 *    Some stability problems when unloading the snd-ca0106 kernel module.
  90 *    --
  91 *
  92 *  TODO:
  93 *    4 Capture channels, only one implemented so far.
  94 *    Other capture rates apart from 48khz not implemented.
  95 *    MIDI
  96 *    --
  97 *  GENERAL INFO:
  98 *    Model: SB0310
  99 *    P17 Chip: CA0106-DAT
 100 *    AC97 Codec: STAC 9721
 101 *    ADC: Philips 1361T (Stereo 24bit)
 102 *    DAC: WM8746EDS (6-channel, 24bit, 192Khz)
 103 *
 104 *  GENERAL INFO:
 105 *    Model: SB0410
 106 *    P17 Chip: CA0106-DAT
 107 *    AC97 Codec: None
 108 *    ADC: WM8775EDS (4 Channel)
 109 *    DAC: CS4382 (114 dB, 24-Bit, 192 kHz, 8-Channel D/A Converter with DSD Support)
 110 *    SPDIF Out control switches between Mic in and SPDIF out.
 111 *    No sound out or mic input working yet.
 112 * 
 113 *  GENERAL INFO:
 114 *    Model: SB0413
 115 *    P17 Chip: CA0106-DAT
 116 *    AC97 Codec: None.
 117 *    ADC: Unknown
 118 *    DAC: Unknown
 119 *    Trying to handle it like the SB0410.
 120 *
 121 *  This code was initially based on code from ALSA's emu10k1x.c which is:
 122 *  Copyright (c) by Francisco Moraes <fmoraes@nc.rr.com>
 123 */
 124#include <linux/delay.h>
 125#include <linux/init.h>
 126#include <linux/interrupt.h>
 127#include <linux/pci.h>
 128#include <linux/slab.h>
 129#include <linux/module.h>
 130#include <linux/dma-mapping.h>
 131#include <sound/core.h>
 132#include <sound/initval.h>
 133#include <sound/pcm.h>
 134#include <sound/ac97_codec.h>
 135#include <sound/info.h>
 136
 137MODULE_AUTHOR("James Courtier-Dutton <James@superbug.demon.co.uk>");
 138MODULE_DESCRIPTION("CA0106");
 139MODULE_LICENSE("GPL");
 140MODULE_SUPPORTED_DEVICE("{{Creative,SB CA0106 chip}}");
 141
 142// module parameters (see "Module Parameters")
 143static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
 144static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR;
 145static bool enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP;
 146static uint subsystem[SNDRV_CARDS]; /* Force card subsystem model */
 147
 148module_param_array(index, int, NULL, 0444);
 149MODULE_PARM_DESC(index, "Index value for the CA0106 soundcard.");
 150module_param_array(id, charp, NULL, 0444);
 151MODULE_PARM_DESC(id, "ID string for the CA0106 soundcard.");
 152module_param_array(enable, bool, NULL, 0444);
 153MODULE_PARM_DESC(enable, "Enable the CA0106 soundcard.");
 154module_param_array(subsystem, uint, NULL, 0444);
 155MODULE_PARM_DESC(subsystem, "Force card subsystem model.");
 156
 157#include "ca0106.h"
 158
 159static const struct snd_ca0106_details ca0106_chip_details[] = {
 160	 /* Sound Blaster X-Fi Extreme Audio. This does not have an AC97. 53SB079000000 */
 161	 /* It is really just a normal SB Live 24bit. */
 162	 /* Tested:
 163	  * See ALSA bug#3251
 164	  */
 165	 { .serial = 0x10131102,
 166	   .name   = "X-Fi Extreme Audio [SBxxxx]",
 167	   .gpio_type = 1,
 168	   .i2c_adc = 1 } ,
 169	 /* Sound Blaster X-Fi Extreme Audio. This does not have an AC97. 53SB079000000 */
 170	 /* It is really just a normal SB Live 24bit. */
 171	 /*
 172 	  * CTRL:CA0111-WTLF
 173	  * ADC: WM8775SEDS
 174	  * DAC: CS4382-KQZ
 175	  */
 176	 /* Tested:
 177	  * Playback on front, rear, center/lfe speakers
 178	  * Capture from Mic in.
 179	  * Not-Tested:
 180	  * Capture from Line in.
 181	  * Playback to digital out.
 182	  */
 183	 { .serial = 0x10121102,
 184	   .name   = "X-Fi Extreme Audio [SB0790]",
 185	   .gpio_type = 1,
 186	   .i2c_adc = 1 } ,
 187	 /* New Dell Sound Blaster Live! 7.1 24bit. This does not have an AC97.  */
 188	 /* AudigyLS[SB0310] */
 189	 { .serial = 0x10021102,
 190	   .name   = "AudigyLS [SB0310]",
 191	   .ac97   = 1 } , 
 192	 /* Unknown AudigyLS that also says SB0310 on it */
 193	 { .serial = 0x10051102,
 194	   .name   = "AudigyLS [SB0310b]",
 195	   .ac97   = 1 } ,
 196	 /* New Sound Blaster Live! 7.1 24bit. This does not have an AC97. 53SB041000001 */
 197	 { .serial = 0x10061102,
 198	   .name   = "Live! 7.1 24bit [SB0410]",
 199	   .gpio_type = 1,
 200	   .i2c_adc = 1 } ,
 201	 /* New Dell Sound Blaster Live! 7.1 24bit. This does not have an AC97.  */
 202	 { .serial = 0x10071102,
 203	   .name   = "Live! 7.1 24bit [SB0413]",
 204	   .gpio_type = 1,
 205	   .i2c_adc = 1 } ,
 206	 /* New Audigy SE. Has a different DAC. */
 207	 /* SB0570:
 208	  * CTRL:CA0106-DAT
 209	  * ADC: WM8775EDS
 210	  * DAC: WM8768GEDS
 211	  */
 212	 { .serial = 0x100a1102,
 213	   .name   = "Audigy SE [SB0570]",
 214	   .gpio_type = 1,
 215	   .i2c_adc = 1,
 216	   .spi_dac = 0x4021 } ,
 217	 /* New Audigy LS. Has a different DAC. */
 218	 /* SB0570:
 219	  * CTRL:CA0106-DAT
 220	  * ADC: WM8775EDS
 221	  * DAC: WM8768GEDS
 222	  */
 223	 { .serial = 0x10111102,
 224	   .name   = "Audigy SE OEM [SB0570a]",
 225	   .gpio_type = 1,
 226	   .i2c_adc = 1,
 227	   .spi_dac = 0x4021 } ,
 228	/* Sound Blaster 5.1vx
 229	 * Tested: Playback on front, rear, center/lfe speakers
 230	 * Not-Tested: Capture
 231	 */
 232	{ .serial = 0x10041102,
 233	  .name   = "Sound Blaster 5.1vx [SB1070]",
 234	  .gpio_type = 1,
 235	  .i2c_adc = 0,
 236	  .spi_dac = 0x0124
 237	 } ,
 238	 /* MSI K8N Diamond Motherboard with onboard SB Live 24bit without AC97 */
 239	 /* SB0438
 240	  * CTRL:CA0106-DAT
 241	  * ADC: WM8775SEDS
 242	  * DAC: CS4382-KQZ
 243	  */
 244	 { .serial = 0x10091462,
 245	   .name   = "MSI K8N Diamond MB [SB0438]",
 246	   .gpio_type = 2,
 247	   .i2c_adc = 1 } ,
 248	 /* MSI K8N Diamond PLUS MB */
 249	 { .serial = 0x10091102,
 250	   .name   = "MSI K8N Diamond MB",
 251	   .gpio_type = 2,
 252	   .i2c_adc = 1,
 253	   .spi_dac = 0x4021 } ,
 254	/* Giga-byte GA-G1975X mobo
 255	 * Novell bnc#395807
 256	 */
 257	/* FIXME: the GPIO and I2C setting aren't tested well */
 258	{ .serial = 0x1458a006,
 259	  .name = "Giga-byte GA-G1975X",
 260	  .gpio_type = 1,
 261	  .i2c_adc = 1 },
 262	 /* Shuttle XPC SD31P which has an onboard Creative Labs
 263	  * Sound Blaster Live! 24-bit EAX
 264	  * high-definition 7.1 audio processor".
 265	  * Added using info from andrewvegan in alsa bug #1298
 266	  */
 267	 { .serial = 0x30381297,
 268	   .name   = "Shuttle XPC SD31P [SD31P]",
 269	   .gpio_type = 1,
 270	   .i2c_adc = 1 } ,
 271	/* Shuttle XPC SD11G5 which has an onboard Creative Labs
 272	 * Sound Blaster Live! 24-bit EAX
 273	 * high-definition 7.1 audio processor".
 274	 * Fixes ALSA bug#1600
 275         */
 276	{ .serial = 0x30411297,
 277	  .name = "Shuttle XPC SD11G5 [SD11G5]",
 278	  .gpio_type = 1,
 279	  .i2c_adc = 1 } ,
 280	 { .serial = 0,
 281	   .name   = "AudigyLS [Unknown]" }
 282};
 283
 284/* hardware definition */
 285static const struct snd_pcm_hardware snd_ca0106_playback_hw = {
 286	.info =			SNDRV_PCM_INFO_MMAP | 
 287				SNDRV_PCM_INFO_INTERLEAVED |
 288				SNDRV_PCM_INFO_BLOCK_TRANSFER |
 289				SNDRV_PCM_INFO_MMAP_VALID |
 290				SNDRV_PCM_INFO_SYNC_START,
 291	.formats =		SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S32_LE,
 292	.rates =		(SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_96000 |
 293				 SNDRV_PCM_RATE_192000),
 294	.rate_min =		48000,
 295	.rate_max =		192000,
 296	.channels_min =		2,  //1,
 297	.channels_max =		2,  //6,
 298	.buffer_bytes_max =	((65536 - 64) * 8),
 299	.period_bytes_min =	64,
 300	.period_bytes_max =	(65536 - 64),
 301	.periods_min =		2,
 302	.periods_max =		8,
 303	.fifo_size =		0,
 304};
 305
 306static const struct snd_pcm_hardware snd_ca0106_capture_hw = {
 307	.info =			(SNDRV_PCM_INFO_MMAP | 
 308				 SNDRV_PCM_INFO_INTERLEAVED |
 309				 SNDRV_PCM_INFO_BLOCK_TRANSFER |
 310				 SNDRV_PCM_INFO_MMAP_VALID),
 311	.formats =		SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S32_LE,
 312#if 0 /* FIXME: looks like 44.1kHz capture causes noisy output on 48kHz */
 313	.rates =		(SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_48000 |
 314				 SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_192000),
 315	.rate_min =		44100,
 316#else
 317	.rates =		(SNDRV_PCM_RATE_48000 |
 318				 SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_192000),
 319	.rate_min =		48000,
 320#endif /* FIXME */
 321	.rate_max =		192000,
 322	.channels_min =		2,
 323	.channels_max =		2,
 324	.buffer_bytes_max =	65536 - 128,
 325	.period_bytes_min =	64,
 326	.period_bytes_max =	32768 - 64,
 327	.periods_min =		2,
 328	.periods_max =		2,
 329	.fifo_size =		0,
 330};
 331
 332unsigned int snd_ca0106_ptr_read(struct snd_ca0106 * emu, 
 333					  unsigned int reg, 
 334					  unsigned int chn)
 335{
 336	unsigned long flags;
 337	unsigned int regptr, val;
 338  
 339	regptr = (reg << 16) | chn;
 340
 341	spin_lock_irqsave(&emu->emu_lock, flags);
 342	outl(regptr, emu->port + PTR);
 343	val = inl(emu->port + DATA);
 344	spin_unlock_irqrestore(&emu->emu_lock, flags);
 345	return val;
 346}
 347
 348void snd_ca0106_ptr_write(struct snd_ca0106 *emu, 
 349				   unsigned int reg, 
 350				   unsigned int chn, 
 351				   unsigned int data)
 352{
 353	unsigned int regptr;
 354	unsigned long flags;
 355
 356	regptr = (reg << 16) | chn;
 357
 358	spin_lock_irqsave(&emu->emu_lock, flags);
 359	outl(regptr, emu->port + PTR);
 360	outl(data, emu->port + DATA);
 361	spin_unlock_irqrestore(&emu->emu_lock, flags);
 362}
 363
 364int snd_ca0106_spi_write(struct snd_ca0106 * emu,
 365				   unsigned int data)
 366{
 367	unsigned int reset, set;
 368	unsigned int reg, tmp;
 369	int n, result;
 370	reg = SPI;
 371	if (data > 0xffff) /* Only 16bit values allowed */
 372		return 1;
 373	tmp = snd_ca0106_ptr_read(emu, reg, 0);
 374	reset = (tmp & ~0x3ffff) | 0x20000; /* Set xxx20000 */
 375	set = reset | 0x10000; /* Set xxx1xxxx */
 376	snd_ca0106_ptr_write(emu, reg, 0, reset | data);
 377	tmp = snd_ca0106_ptr_read(emu, reg, 0); /* write post */
 378	snd_ca0106_ptr_write(emu, reg, 0, set | data);
 379	result = 1;
 380	/* Wait for status bit to return to 0 */
 381	for (n = 0; n < 100; n++) {
 382		udelay(10);
 383		tmp = snd_ca0106_ptr_read(emu, reg, 0);
 384		if (!(tmp & 0x10000)) {
 385			result = 0;
 386			break;
 387		}
 388	}
 389	if (result) /* Timed out */
 390		return 1;
 391	snd_ca0106_ptr_write(emu, reg, 0, reset | data);
 392	tmp = snd_ca0106_ptr_read(emu, reg, 0); /* Write post */
 393	return 0;
 394}
 395
 396/* The ADC does not support i2c read, so only write is implemented */
 397int snd_ca0106_i2c_write(struct snd_ca0106 *emu,
 398				u32 reg,
 399				u32 value)
 400{
 401	u32 tmp;
 402	int timeout = 0;
 403	int status;
 404	int retry;
 405	if ((reg > 0x7f) || (value > 0x1ff)) {
 406		dev_err(emu->card->dev, "i2c_write: invalid values.\n");
 407		return -EINVAL;
 408	}
 409
 410	tmp = reg << 25 | value << 16;
 411	/*
 412	dev_dbg(emu->card->dev, "I2C-write:reg=0x%x, value=0x%x\n", reg, value);
 413	*/
 414	/* Not sure what this I2C channel controls. */
 415	/* snd_ca0106_ptr_write(emu, I2C_D0, 0, tmp); */
 416
 417	/* This controls the I2C connected to the WM8775 ADC Codec */
 418	snd_ca0106_ptr_write(emu, I2C_D1, 0, tmp);
 419
 420	for (retry = 0; retry < 10; retry++) {
 421		/* Send the data to i2c */
 422		//tmp = snd_ca0106_ptr_read(emu, I2C_A, 0);
 423		//tmp = tmp & ~(I2C_A_ADC_READ|I2C_A_ADC_LAST|I2C_A_ADC_START|I2C_A_ADC_ADD_MASK);
 424		tmp = 0;
 425		tmp = tmp | (I2C_A_ADC_LAST|I2C_A_ADC_START|I2C_A_ADC_ADD);
 426		snd_ca0106_ptr_write(emu, I2C_A, 0, tmp);
 427
 428		/* Wait till the transaction ends */
 429		while (1) {
 430			status = snd_ca0106_ptr_read(emu, I2C_A, 0);
 431			/*dev_dbg(emu->card->dev, "I2C:status=0x%x\n", status);*/
 432			timeout++;
 433			if ((status & I2C_A_ADC_START) == 0)
 434				break;
 435
 436			if (timeout > 1000)
 437				break;
 438		}
 439		//Read back and see if the transaction is successful
 440		if ((status & I2C_A_ADC_ABORT) == 0)
 441			break;
 442	}
 443
 444	if (retry == 10) {
 445		dev_err(emu->card->dev, "Writing to ADC failed!\n");
 446		return -EINVAL;
 447	}
 448    
 449    	return 0;
 450}
 451
 452
 453static void snd_ca0106_intr_enable(struct snd_ca0106 *emu, unsigned int intrenb)
 454{
 455	unsigned long flags;
 456	unsigned int intr_enable;
 457
 458	spin_lock_irqsave(&emu->emu_lock, flags);
 459	intr_enable = inl(emu->port + INTE) | intrenb;
 460	outl(intr_enable, emu->port + INTE);
 461	spin_unlock_irqrestore(&emu->emu_lock, flags);
 462}
 463
 464static void snd_ca0106_intr_disable(struct snd_ca0106 *emu, unsigned int intrenb)
 465{
 466	unsigned long flags;
 467	unsigned int intr_enable;
 468
 469	spin_lock_irqsave(&emu->emu_lock, flags);
 470	intr_enable = inl(emu->port + INTE) & ~intrenb;
 471	outl(intr_enable, emu->port + INTE);
 472	spin_unlock_irqrestore(&emu->emu_lock, flags);
 473}
 474
 475
 476static void snd_ca0106_pcm_free_substream(struct snd_pcm_runtime *runtime)
 477{
 478	kfree(runtime->private_data);
 479}
 480
 481static const int spi_dacd_reg[] = {
 482	SPI_DACD0_REG,
 483	SPI_DACD1_REG,
 484	SPI_DACD2_REG,
 485	0,
 486	SPI_DACD4_REG,
 487};
 488static const int spi_dacd_bit[] = {
 489	SPI_DACD0_BIT,
 490	SPI_DACD1_BIT,
 491	SPI_DACD2_BIT,
 492	0,
 493	SPI_DACD4_BIT,
 494};
 495
 496static void restore_spdif_bits(struct snd_ca0106 *chip, int idx)
 497{
 498	if (chip->spdif_str_bits[idx] != chip->spdif_bits[idx]) {
 499		chip->spdif_str_bits[idx] = chip->spdif_bits[idx];
 500		snd_ca0106_ptr_write(chip, SPCS0 + idx, 0,
 501				     chip->spdif_str_bits[idx]);
 502	}
 503}
 504
 505static int snd_ca0106_channel_dac(struct snd_ca0106 *chip,
 506				  const struct snd_ca0106_details *details,
 507				  int channel_id)
 508{
 509	switch (channel_id) {
 510	case PCM_FRONT_CHANNEL:
 511		return (details->spi_dac & 0xf000) >> (4 * 3);
 512	case PCM_REAR_CHANNEL:
 513		return (details->spi_dac & 0x0f00) >> (4 * 2);
 514	case PCM_CENTER_LFE_CHANNEL:
 515		return (details->spi_dac & 0x00f0) >> (4 * 1);
 516	case PCM_UNKNOWN_CHANNEL:
 517		return (details->spi_dac & 0x000f) >> (4 * 0);
 518	default:
 519		dev_dbg(chip->card->dev, "ca0106: unknown channel_id %d\n",
 520			   channel_id);
 521	}
 522	return 0;
 523}
 524
 525static int snd_ca0106_pcm_power_dac(struct snd_ca0106 *chip, int channel_id,
 526				    int power)
 527{
 528	if (chip->details->spi_dac) {
 529		const int dac = snd_ca0106_channel_dac(chip, chip->details,
 530						       channel_id);
 531		const int reg = spi_dacd_reg[dac];
 532		const int bit = spi_dacd_bit[dac];
 533
 534		if (power)
 535			/* Power up */
 536			chip->spi_dac_reg[reg] &= ~bit;
 537		else
 538			/* Power down */
 539			chip->spi_dac_reg[reg] |= bit;
 540		if (snd_ca0106_spi_write(chip, chip->spi_dac_reg[reg]) != 0)
 541			return -ENXIO;
 542	}
 543	return 0;
 544}
 545
 546/* open_playback callback */
 547static int snd_ca0106_pcm_open_playback_channel(struct snd_pcm_substream *substream,
 548						int channel_id)
 549{
 550	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 551        struct snd_ca0106_channel *channel = &(chip->playback_channels[channel_id]);
 552	struct snd_ca0106_pcm *epcm;
 553	struct snd_pcm_runtime *runtime = substream->runtime;
 554	int err;
 555
 556	epcm = kzalloc(sizeof(*epcm), GFP_KERNEL);
 557
 558	if (epcm == NULL)
 559		return -ENOMEM;
 560	epcm->emu = chip;
 561	epcm->substream = substream;
 562        epcm->channel_id=channel_id;
 563  
 564	runtime->private_data = epcm;
 565	runtime->private_free = snd_ca0106_pcm_free_substream;
 566  
 567	runtime->hw = snd_ca0106_playback_hw;
 568
 569        channel->emu = chip;
 570        channel->number = channel_id;
 571
 572	channel->use = 1;
 573	/*
 574	dev_dbg(chip->card->dev, "open:channel_id=%d, chip=%p, channel=%p\n",
 575	       channel_id, chip, channel);
 576	*/
 577        //channel->interrupt = snd_ca0106_pcm_channel_interrupt;
 578	channel->epcm = epcm;
 579	if ((err = snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS)) < 0)
 
 580                return err;
 581	if ((err = snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES, 64)) < 0)
 
 582                return err;
 583	snd_pcm_set_sync(substream);
 584
 585	/* Front channel dac should already be on */
 586	if (channel_id != PCM_FRONT_CHANNEL) {
 587		err = snd_ca0106_pcm_power_dac(chip, channel_id, 1);
 588		if (err < 0)
 589			return err;
 590	}
 591
 592	restore_spdif_bits(chip, channel_id);
 593
 594	return 0;
 595}
 596
 597/* close callback */
 598static int snd_ca0106_pcm_close_playback(struct snd_pcm_substream *substream)
 599{
 600	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 601	struct snd_pcm_runtime *runtime = substream->runtime;
 602        struct snd_ca0106_pcm *epcm = runtime->private_data;
 603	chip->playback_channels[epcm->channel_id].use = 0;
 604
 605	restore_spdif_bits(chip, epcm->channel_id);
 606
 607	/* Front channel dac should stay on */
 608	if (epcm->channel_id != PCM_FRONT_CHANNEL) {
 609		int err;
 610		err = snd_ca0106_pcm_power_dac(chip, epcm->channel_id, 0);
 611		if (err < 0)
 612			return err;
 613	}
 614
 615	/* FIXME: maybe zero others */
 616	return 0;
 617}
 618
 619static int snd_ca0106_pcm_open_playback_front(struct snd_pcm_substream *substream)
 620{
 621	return snd_ca0106_pcm_open_playback_channel(substream, PCM_FRONT_CHANNEL);
 622}
 623
 624static int snd_ca0106_pcm_open_playback_center_lfe(struct snd_pcm_substream *substream)
 625{
 626	return snd_ca0106_pcm_open_playback_channel(substream, PCM_CENTER_LFE_CHANNEL);
 627}
 628
 629static int snd_ca0106_pcm_open_playback_unknown(struct snd_pcm_substream *substream)
 630{
 631	return snd_ca0106_pcm_open_playback_channel(substream, PCM_UNKNOWN_CHANNEL);
 632}
 633
 634static int snd_ca0106_pcm_open_playback_rear(struct snd_pcm_substream *substream)
 635{
 636	return snd_ca0106_pcm_open_playback_channel(substream, PCM_REAR_CHANNEL);
 637}
 638
 639/* open_capture callback */
 640static int snd_ca0106_pcm_open_capture_channel(struct snd_pcm_substream *substream,
 641					       int channel_id)
 642{
 643	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 644        struct snd_ca0106_channel *channel = &(chip->capture_channels[channel_id]);
 645	struct snd_ca0106_pcm *epcm;
 646	struct snd_pcm_runtime *runtime = substream->runtime;
 647	int err;
 648
 649	epcm = kzalloc(sizeof(*epcm), GFP_KERNEL);
 650	if (!epcm)
 651		return -ENOMEM;
 652
 653	epcm->emu = chip;
 654	epcm->substream = substream;
 655        epcm->channel_id=channel_id;
 656  
 657	runtime->private_data = epcm;
 658	runtime->private_free = snd_ca0106_pcm_free_substream;
 659  
 660	runtime->hw = snd_ca0106_capture_hw;
 661
 662        channel->emu = chip;
 663        channel->number = channel_id;
 664
 665	channel->use = 1;
 666	/*
 667	dev_dbg(chip->card->dev, "open:channel_id=%d, chip=%p, channel=%p\n",
 668	       channel_id, chip, channel);
 669	*/
 670        //channel->interrupt = snd_ca0106_pcm_channel_interrupt;
 671        channel->epcm = epcm;
 672	if ((err = snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS)) < 0)
 
 673                return err;
 674	//snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_SIZE, &hw_constraints_capture_period_sizes);
 675	if ((err = snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES, 64)) < 0)
 
 676                return err;
 677	return 0;
 678}
 679
 680/* close callback */
 681static int snd_ca0106_pcm_close_capture(struct snd_pcm_substream *substream)
 682{
 683	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 684	struct snd_pcm_runtime *runtime = substream->runtime;
 685        struct snd_ca0106_pcm *epcm = runtime->private_data;
 686	chip->capture_channels[epcm->channel_id].use = 0;
 687	/* FIXME: maybe zero others */
 688	return 0;
 689}
 690
 691static int snd_ca0106_pcm_open_0_capture(struct snd_pcm_substream *substream)
 692{
 693	return snd_ca0106_pcm_open_capture_channel(substream, 0);
 694}
 695
 696static int snd_ca0106_pcm_open_1_capture(struct snd_pcm_substream *substream)
 697{
 698	return snd_ca0106_pcm_open_capture_channel(substream, 1);
 699}
 700
 701static int snd_ca0106_pcm_open_2_capture(struct snd_pcm_substream *substream)
 702{
 703	return snd_ca0106_pcm_open_capture_channel(substream, 2);
 704}
 705
 706static int snd_ca0106_pcm_open_3_capture(struct snd_pcm_substream *substream)
 707{
 708	return snd_ca0106_pcm_open_capture_channel(substream, 3);
 709}
 710
 711/* prepare playback callback */
 712static int snd_ca0106_pcm_prepare_playback(struct snd_pcm_substream *substream)
 713{
 714	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 715	struct snd_pcm_runtime *runtime = substream->runtime;
 716	struct snd_ca0106_pcm *epcm = runtime->private_data;
 717	int channel = epcm->channel_id;
 718	u32 *table_base = (u32 *)(emu->buffer.area+(8*16*channel));
 719	u32 period_size_bytes = frames_to_bytes(runtime, runtime->period_size);
 720	u32 hcfg_mask = HCFG_PLAYBACK_S32_LE;
 721	u32 hcfg_set = 0x00000000;
 722	u32 hcfg;
 723	u32 reg40_mask = 0x30000 << (channel<<1);
 724	u32 reg40_set = 0;
 725	u32 reg40;
 726	/* FIXME: Depending on mixer selection of SPDIF out or not, select the spdif rate or the DAC rate. */
 727	u32 reg71_mask = 0x03030000 ; /* Global. Set SPDIF rate. We only support 44100 to spdif, not to DAC. */
 728	u32 reg71_set = 0;
 729	u32 reg71;
 730	int i;
 731	
 732#if 0 /* debug */
 733	dev_dbg(emu->card->dev,
 734		   "prepare:channel_number=%d, rate=%d, format=0x%x, "
 735		   "channels=%d, buffer_size=%ld, period_size=%ld, "
 736		   "periods=%u, frames_to_bytes=%d\n",
 737		   channel, runtime->rate, runtime->format,
 738		   runtime->channels, runtime->buffer_size,
 739		   runtime->period_size, runtime->periods,
 740		   frames_to_bytes(runtime, 1));
 741	dev_dbg(emu->card->dev,
 742		"dma_addr=%x, dma_area=%p, table_base=%p\n",
 743		   runtime->dma_addr, runtime->dma_area, table_base);
 744	dev_dbg(emu->card->dev,
 745		"dma_addr=%x, dma_area=%p, dma_bytes(size)=%x\n",
 746		   emu->buffer.addr, emu->buffer.area, emu->buffer.bytes);
 747#endif /* debug */
 748	/* Rate can be set per channel. */
 749	/* reg40 control host to fifo */
 750	/* reg71 controls DAC rate. */
 751	switch (runtime->rate) {
 752	case 44100:
 753		reg40_set = 0x10000 << (channel<<1);
 754		reg71_set = 0x01010000; 
 755		break;
 756        case 48000:
 757		reg40_set = 0;
 758		reg71_set = 0; 
 759		break;
 760	case 96000:
 761		reg40_set = 0x20000 << (channel<<1);
 762		reg71_set = 0x02020000; 
 763		break;
 764	case 192000:
 765		reg40_set = 0x30000 << (channel<<1);
 766		reg71_set = 0x03030000; 
 767		break;
 768	default:
 769		reg40_set = 0;
 770		reg71_set = 0; 
 771		break;
 772	}
 773	/* Format is a global setting */
 774	/* FIXME: Only let the first channel accessed set this. */
 775	switch (runtime->format) {
 776	case SNDRV_PCM_FORMAT_S16_LE:
 777		hcfg_set = 0;
 778		break;
 779	case SNDRV_PCM_FORMAT_S32_LE:
 780		hcfg_set = HCFG_PLAYBACK_S32_LE;
 781		break;
 782	default:
 783		hcfg_set = 0;
 784		break;
 785	}
 786	hcfg = inl(emu->port + HCFG) ;
 787	hcfg = (hcfg & ~hcfg_mask) | hcfg_set;
 788	outl(hcfg, emu->port + HCFG);
 789	reg40 = snd_ca0106_ptr_read(emu, 0x40, 0);
 790	reg40 = (reg40 & ~reg40_mask) | reg40_set;
 791	snd_ca0106_ptr_write(emu, 0x40, 0, reg40);
 792	reg71 = snd_ca0106_ptr_read(emu, 0x71, 0);
 793	reg71 = (reg71 & ~reg71_mask) | reg71_set;
 794	snd_ca0106_ptr_write(emu, 0x71, 0, reg71);
 795
 796	/* FIXME: Check emu->buffer.size before actually writing to it. */
 797        for(i=0; i < runtime->periods; i++) {
 798		table_base[i*2] = runtime->dma_addr + (i * period_size_bytes);
 799		table_base[i*2+1] = period_size_bytes << 16;
 800	}
 801 
 802	snd_ca0106_ptr_write(emu, PLAYBACK_LIST_ADDR, channel, emu->buffer.addr+(8*16*channel));
 803	snd_ca0106_ptr_write(emu, PLAYBACK_LIST_SIZE, channel, (runtime->periods - 1) << 19);
 804	snd_ca0106_ptr_write(emu, PLAYBACK_LIST_PTR, channel, 0);
 805	snd_ca0106_ptr_write(emu, PLAYBACK_DMA_ADDR, channel, runtime->dma_addr);
 806	snd_ca0106_ptr_write(emu, PLAYBACK_PERIOD_SIZE, channel, frames_to_bytes(runtime, runtime->period_size)<<16); // buffer size in bytes
 807	/* FIXME  test what 0 bytes does. */
 808	snd_ca0106_ptr_write(emu, PLAYBACK_PERIOD_SIZE, channel, 0); // buffer size in bytes
 809	snd_ca0106_ptr_write(emu, PLAYBACK_POINTER, channel, 0);
 810	snd_ca0106_ptr_write(emu, 0x07, channel, 0x0);
 811	snd_ca0106_ptr_write(emu, 0x08, channel, 0);
 812        snd_ca0106_ptr_write(emu, PLAYBACK_MUTE, 0x0, 0x0); /* Unmute output */
 813#if 0
 814	snd_ca0106_ptr_write(emu, SPCS0, 0,
 815			       SPCS_CLKACCY_1000PPM | SPCS_SAMPLERATE_48 |
 816			       SPCS_CHANNELNUM_LEFT | SPCS_SOURCENUM_UNSPEC |
 817			       SPCS_GENERATIONSTATUS | 0x00001200 |
 818			       0x00000000 | SPCS_EMPHASIS_NONE | SPCS_COPYRIGHT );
 819#endif
 820
 821	return 0;
 822}
 823
 824/* prepare capture callback */
 825static int snd_ca0106_pcm_prepare_capture(struct snd_pcm_substream *substream)
 826{
 827	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 828	struct snd_pcm_runtime *runtime = substream->runtime;
 829	struct snd_ca0106_pcm *epcm = runtime->private_data;
 830	int channel = epcm->channel_id;
 831	u32 hcfg_mask = HCFG_CAPTURE_S32_LE;
 832	u32 hcfg_set = 0x00000000;
 833	u32 hcfg;
 834	u32 over_sampling=0x2;
 835	u32 reg71_mask = 0x0000c000 ; /* Global. Set ADC rate. */
 836	u32 reg71_set = 0;
 837	u32 reg71;
 838	
 839#if 0 /* debug */
 840	dev_dbg(emu->card->dev,
 841		   "prepare:channel_number=%d, rate=%d, format=0x%x, "
 842		   "channels=%d, buffer_size=%ld, period_size=%ld, "
 843		   "periods=%u, frames_to_bytes=%d\n",
 844		   channel, runtime->rate, runtime->format,
 845		   runtime->channels, runtime->buffer_size,
 846		   runtime->period_size, runtime->periods,
 847		   frames_to_bytes(runtime, 1));
 848	dev_dbg(emu->card->dev,
 849		"dma_addr=%x, dma_area=%p, table_base=%p\n",
 850		   runtime->dma_addr, runtime->dma_area, table_base);
 851	dev_dbg(emu->card->dev,
 852		"dma_addr=%x, dma_area=%p, dma_bytes(size)=%x\n",
 853		   emu->buffer.addr, emu->buffer.area, emu->buffer.bytes);
 854#endif /* debug */
 855	/* reg71 controls ADC rate. */
 856	switch (runtime->rate) {
 857	case 44100:
 858		reg71_set = 0x00004000;
 859		break;
 860        case 48000:
 861		reg71_set = 0; 
 862		break;
 863	case 96000:
 864		reg71_set = 0x00008000;
 865		over_sampling=0xa;
 866		break;
 867	case 192000:
 868		reg71_set = 0x0000c000; 
 869		over_sampling=0xa;
 870		break;
 871	default:
 872		reg71_set = 0; 
 873		break;
 874	}
 875	/* Format is a global setting */
 876	/* FIXME: Only let the first channel accessed set this. */
 877	switch (runtime->format) {
 878	case SNDRV_PCM_FORMAT_S16_LE:
 879		hcfg_set = 0;
 880		break;
 881	case SNDRV_PCM_FORMAT_S32_LE:
 882		hcfg_set = HCFG_CAPTURE_S32_LE;
 883		break;
 884	default:
 885		hcfg_set = 0;
 886		break;
 887	}
 888	hcfg = inl(emu->port + HCFG) ;
 889	hcfg = (hcfg & ~hcfg_mask) | hcfg_set;
 890	outl(hcfg, emu->port + HCFG);
 891	reg71 = snd_ca0106_ptr_read(emu, 0x71, 0);
 892	reg71 = (reg71 & ~reg71_mask) | reg71_set;
 893	snd_ca0106_ptr_write(emu, 0x71, 0, reg71);
 894        if (emu->details->i2c_adc == 1) { /* The SB0410 and SB0413 use I2C to control ADC. */
 895	        snd_ca0106_i2c_write(emu, ADC_MASTER, over_sampling); /* Adjust the over sampler to better suit the capture rate. */
 896	}
 897
 898
 899	/*
 900	dev_dbg(emu->card->dev,
 901	       "prepare:channel_number=%d, rate=%d, format=0x%x, channels=%d, "
 902	       "buffer_size=%ld, period_size=%ld, frames_to_bytes=%d\n",
 903	       channel, runtime->rate, runtime->format, runtime->channels,
 904	       runtime->buffer_size, runtime->period_size,
 905	       frames_to_bytes(runtime, 1));
 906	*/
 907	snd_ca0106_ptr_write(emu, 0x13, channel, 0);
 908	snd_ca0106_ptr_write(emu, CAPTURE_DMA_ADDR, channel, runtime->dma_addr);
 909	snd_ca0106_ptr_write(emu, CAPTURE_BUFFER_SIZE, channel, frames_to_bytes(runtime, runtime->buffer_size)<<16); // buffer size in bytes
 910	snd_ca0106_ptr_write(emu, CAPTURE_POINTER, channel, 0);
 911
 912	return 0;
 913}
 914
 915/* trigger_playback callback */
 916static int snd_ca0106_pcm_trigger_playback(struct snd_pcm_substream *substream,
 917				    int cmd)
 918{
 919	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 920	struct snd_pcm_runtime *runtime;
 921	struct snd_ca0106_pcm *epcm;
 922	int channel;
 923	int result = 0;
 924        struct snd_pcm_substream *s;
 925	u32 basic = 0;
 926	u32 extended = 0;
 927	u32 bits;
 928	int running = 0;
 929
 930	switch (cmd) {
 931	case SNDRV_PCM_TRIGGER_START:
 932	case SNDRV_PCM_TRIGGER_RESUME:
 933		running = 1;
 934		break;
 935	case SNDRV_PCM_TRIGGER_STOP:
 936	case SNDRV_PCM_TRIGGER_SUSPEND:
 937	default:
 938		running = 0;
 939		break;
 940	}
 941        snd_pcm_group_for_each_entry(s, substream) {
 942		if (snd_pcm_substream_chip(s) != emu ||
 943		    s->stream != SNDRV_PCM_STREAM_PLAYBACK)
 944			continue;
 945		runtime = s->runtime;
 946		epcm = runtime->private_data;
 947		channel = epcm->channel_id;
 948		/* dev_dbg(emu->card->dev, "channel=%d\n", channel); */
 949		epcm->running = running;
 950		basic |= (0x1 << channel);
 951		extended |= (0x10 << channel);
 952                snd_pcm_trigger_done(s, substream);
 953        }
 954	/* dev_dbg(emu->card->dev, "basic=0x%x, extended=0x%x\n",basic, extended); */
 955
 956	switch (cmd) {
 957	case SNDRV_PCM_TRIGGER_START:
 958	case SNDRV_PCM_TRIGGER_RESUME:
 959		bits = snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0);
 960		bits |= extended;
 961		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, bits);
 962		bits = snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0);
 963		bits |= basic;
 964		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, bits);
 965		break;
 966	case SNDRV_PCM_TRIGGER_STOP:
 967	case SNDRV_PCM_TRIGGER_SUSPEND:
 968		bits = snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0);
 969		bits &= ~basic;
 970		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, bits);
 971		bits = snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0);
 972		bits &= ~extended;
 973		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, bits);
 974		break;
 975	default:
 976		result = -EINVAL;
 977		break;
 978	}
 979	return result;
 980}
 981
 982/* trigger_capture callback */
 983static int snd_ca0106_pcm_trigger_capture(struct snd_pcm_substream *substream,
 984				    int cmd)
 985{
 986	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 987	struct snd_pcm_runtime *runtime = substream->runtime;
 988	struct snd_ca0106_pcm *epcm = runtime->private_data;
 989	int channel = epcm->channel_id;
 990	int result = 0;
 991
 992	switch (cmd) {
 993	case SNDRV_PCM_TRIGGER_START:
 994		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0) | (0x110000<<channel));
 995		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0)|(0x100<<channel));
 996		epcm->running = 1;
 997		break;
 998	case SNDRV_PCM_TRIGGER_STOP:
 999		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0) & ~(0x100<<channel));
1000		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0) & ~(0x110000<<channel));
1001		epcm->running = 0;
1002		break;
1003	default:
1004		result = -EINVAL;
1005		break;
1006	}
1007	return result;
1008}
1009
1010/* pointer_playback callback */
1011static snd_pcm_uframes_t
1012snd_ca0106_pcm_pointer_playback(struct snd_pcm_substream *substream)
1013{
1014	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
1015	struct snd_pcm_runtime *runtime = substream->runtime;
1016	struct snd_ca0106_pcm *epcm = runtime->private_data;
1017	unsigned int ptr, prev_ptr;
1018	int channel = epcm->channel_id;
1019	int timeout = 10;
1020
1021	if (!epcm->running)
1022		return 0;
1023
1024	prev_ptr = -1;
1025	do {
1026		ptr = snd_ca0106_ptr_read(emu, PLAYBACK_LIST_PTR, channel);
1027		ptr = (ptr >> 3) * runtime->period_size;
1028		ptr += bytes_to_frames(runtime,
1029			snd_ca0106_ptr_read(emu, PLAYBACK_POINTER, channel));
1030		if (ptr >= runtime->buffer_size)
1031			ptr -= runtime->buffer_size;
1032		if (prev_ptr == ptr)
1033			return ptr;
1034		prev_ptr = ptr;
1035	} while (--timeout);
1036	dev_warn(emu->card->dev, "ca0106: unstable DMA pointer!\n");
1037	return 0;
1038}
1039
1040/* pointer_capture callback */
1041static snd_pcm_uframes_t
1042snd_ca0106_pcm_pointer_capture(struct snd_pcm_substream *substream)
1043{
1044	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
1045	struct snd_pcm_runtime *runtime = substream->runtime;
1046	struct snd_ca0106_pcm *epcm = runtime->private_data;
1047	snd_pcm_uframes_t ptr, ptr1, ptr2 = 0;
1048	int channel = epcm->channel_id;
1049
1050	if (!epcm->running)
1051		return 0;
1052
1053	ptr1 = snd_ca0106_ptr_read(emu, CAPTURE_POINTER, channel);
1054	ptr2 = bytes_to_frames(runtime, ptr1);
1055	ptr=ptr2;
1056        if (ptr >= runtime->buffer_size)
1057		ptr -= runtime->buffer_size;
1058	/*
1059	dev_dbg(emu->card->dev, "ptr1 = 0x%lx, ptr2=0x%lx, ptr=0x%lx, "
1060	       "buffer_size = 0x%x, period_size = 0x%x, bits=%d, rate=%d\n",
1061	       ptr1, ptr2, ptr, (int)runtime->buffer_size,
1062	       (int)runtime->period_size, (int)runtime->frame_bits,
1063	       (int)runtime->rate);
1064	*/
1065	return ptr;
1066}
1067
1068/* operators */
1069static const struct snd_pcm_ops snd_ca0106_playback_front_ops = {
1070	.open =        snd_ca0106_pcm_open_playback_front,
1071	.close =       snd_ca0106_pcm_close_playback,
1072	.prepare =     snd_ca0106_pcm_prepare_playback,
1073	.trigger =     snd_ca0106_pcm_trigger_playback,
1074	.pointer =     snd_ca0106_pcm_pointer_playback,
1075};
1076
1077static const struct snd_pcm_ops snd_ca0106_capture_0_ops = {
1078	.open =        snd_ca0106_pcm_open_0_capture,
1079	.close =       snd_ca0106_pcm_close_capture,
1080	.prepare =     snd_ca0106_pcm_prepare_capture,
1081	.trigger =     snd_ca0106_pcm_trigger_capture,
1082	.pointer =     snd_ca0106_pcm_pointer_capture,
1083};
1084
1085static const struct snd_pcm_ops snd_ca0106_capture_1_ops = {
1086	.open =        snd_ca0106_pcm_open_1_capture,
1087	.close =       snd_ca0106_pcm_close_capture,
1088	.prepare =     snd_ca0106_pcm_prepare_capture,
1089	.trigger =     snd_ca0106_pcm_trigger_capture,
1090	.pointer =     snd_ca0106_pcm_pointer_capture,
1091};
1092
1093static const struct snd_pcm_ops snd_ca0106_capture_2_ops = {
1094	.open =        snd_ca0106_pcm_open_2_capture,
1095	.close =       snd_ca0106_pcm_close_capture,
1096	.prepare =     snd_ca0106_pcm_prepare_capture,
1097	.trigger =     snd_ca0106_pcm_trigger_capture,
1098	.pointer =     snd_ca0106_pcm_pointer_capture,
1099};
1100
1101static const struct snd_pcm_ops snd_ca0106_capture_3_ops = {
1102	.open =        snd_ca0106_pcm_open_3_capture,
1103	.close =       snd_ca0106_pcm_close_capture,
1104	.prepare =     snd_ca0106_pcm_prepare_capture,
1105	.trigger =     snd_ca0106_pcm_trigger_capture,
1106	.pointer =     snd_ca0106_pcm_pointer_capture,
1107};
1108
1109static const struct snd_pcm_ops snd_ca0106_playback_center_lfe_ops = {
1110        .open =         snd_ca0106_pcm_open_playback_center_lfe,
1111        .close =        snd_ca0106_pcm_close_playback,
1112        .prepare =      snd_ca0106_pcm_prepare_playback,     
1113        .trigger =      snd_ca0106_pcm_trigger_playback,  
1114        .pointer =      snd_ca0106_pcm_pointer_playback, 
1115};
1116
1117static const struct snd_pcm_ops snd_ca0106_playback_unknown_ops = {
1118        .open =         snd_ca0106_pcm_open_playback_unknown,
1119        .close =        snd_ca0106_pcm_close_playback,
1120        .prepare =      snd_ca0106_pcm_prepare_playback,     
1121        .trigger =      snd_ca0106_pcm_trigger_playback,  
1122        .pointer =      snd_ca0106_pcm_pointer_playback, 
1123};
1124
1125static const struct snd_pcm_ops snd_ca0106_playback_rear_ops = {
1126        .open =         snd_ca0106_pcm_open_playback_rear,
1127        .close =        snd_ca0106_pcm_close_playback,
1128        .prepare =      snd_ca0106_pcm_prepare_playback,     
1129        .trigger =      snd_ca0106_pcm_trigger_playback,  
1130        .pointer =      snd_ca0106_pcm_pointer_playback, 
1131};
1132
1133
1134static unsigned short snd_ca0106_ac97_read(struct snd_ac97 *ac97,
1135					     unsigned short reg)
1136{
1137	struct snd_ca0106 *emu = ac97->private_data;
1138	unsigned long flags;
1139	unsigned short val;
1140
1141	spin_lock_irqsave(&emu->emu_lock, flags);
1142	outb(reg, emu->port + AC97ADDRESS);
1143	val = inw(emu->port + AC97DATA);
1144	spin_unlock_irqrestore(&emu->emu_lock, flags);
1145	return val;
1146}
1147
1148static void snd_ca0106_ac97_write(struct snd_ac97 *ac97,
1149				    unsigned short reg, unsigned short val)
1150{
1151	struct snd_ca0106 *emu = ac97->private_data;
1152	unsigned long flags;
1153  
1154	spin_lock_irqsave(&emu->emu_lock, flags);
1155	outb(reg, emu->port + AC97ADDRESS);
1156	outw(val, emu->port + AC97DATA);
1157	spin_unlock_irqrestore(&emu->emu_lock, flags);
1158}
1159
1160static int snd_ca0106_ac97(struct snd_ca0106 *chip)
1161{
1162	struct snd_ac97_bus *pbus;
1163	struct snd_ac97_template ac97;
1164	int err;
1165	static const struct snd_ac97_bus_ops ops = {
1166		.write = snd_ca0106_ac97_write,
1167		.read = snd_ca0106_ac97_read,
1168	};
1169  
1170	if ((err = snd_ac97_bus(chip->card, 0, &ops, NULL, &pbus)) < 0)
 
1171		return err;
1172	pbus->no_vra = 1; /* we don't need VRA */
1173
1174	memset(&ac97, 0, sizeof(ac97));
1175	ac97.private_data = chip;
1176	ac97.scaps = AC97_SCAP_NO_SPDIF;
1177	return snd_ac97_mixer(pbus, &ac97, &chip->ac97);
1178}
1179
1180static void ca0106_stop_chip(struct snd_ca0106 *chip);
1181
1182static int snd_ca0106_free(struct snd_ca0106 *chip)
1183{
1184	if (chip->res_port != NULL) {
1185		/* avoid access to already used hardware */
1186		ca0106_stop_chip(chip);
1187	}
1188	if (chip->irq >= 0)
1189		free_irq(chip->irq, chip);
1190	// release the data
1191#if 1
1192	if (chip->buffer.area)
1193		snd_dma_free_pages(&chip->buffer);
1194#endif
1195
1196	// release the i/o port
1197	release_and_free_resource(chip->res_port);
1198
1199	pci_disable_device(chip->pci);
1200	kfree(chip);
1201	return 0;
1202}
1203
1204static int snd_ca0106_dev_free(struct snd_device *device)
1205{
1206	struct snd_ca0106 *chip = device->device_data;
1207	return snd_ca0106_free(chip);
1208}
1209
1210static irqreturn_t snd_ca0106_interrupt(int irq, void *dev_id)
1211{
1212	unsigned int status;
1213
1214	struct snd_ca0106 *chip = dev_id;
1215	int i;
1216	int mask;
1217        unsigned int stat76;
1218	struct snd_ca0106_channel *pchannel;
1219
1220	status = inl(chip->port + IPR);
1221	if (! status)
1222		return IRQ_NONE;
1223
1224        stat76 = snd_ca0106_ptr_read(chip, EXTENDED_INT, 0);
1225	/*
1226	dev_dbg(emu->card->dev, "interrupt status = 0x%08x, stat76=0x%08x\n",
1227		   status, stat76);
1228	dev_dbg(emu->card->dev, "ptr=0x%08x\n",
1229		   snd_ca0106_ptr_read(chip, PLAYBACK_POINTER, 0));
1230	*/
1231        mask = 0x11; /* 0x1 for one half, 0x10 for the other half period. */
1232	for(i = 0; i < 4; i++) {
1233		pchannel = &(chip->playback_channels[i]);
1234		if (stat76 & mask) {
1235/* FIXME: Select the correct substream for period elapsed */
1236			if(pchannel->use) {
1237				snd_pcm_period_elapsed(pchannel->epcm->substream);
1238				/* dev_dbg(emu->card->dev, "interrupt [%d] used\n", i); */
1239                        }
1240		}
1241		/*
1242		dev_dbg(emu->card->dev, "channel=%p\n", pchannel);
1243		dev_dbg(emu->card->dev, "interrupt stat76[%d] = %08x, use=%d, channel=%d\n", i, stat76, pchannel->use, pchannel->number);
1244		*/
1245		mask <<= 1;
1246	}
1247        mask = 0x110000; /* 0x1 for one half, 0x10 for the other half period. */
1248	for(i = 0; i < 4; i++) {
1249		pchannel = &(chip->capture_channels[i]);
1250		if (stat76 & mask) {
1251/* FIXME: Select the correct substream for period elapsed */
1252			if(pchannel->use) {
1253				snd_pcm_period_elapsed(pchannel->epcm->substream);
1254				/* dev_dbg(emu->card->dev, "interrupt [%d] used\n", i); */
1255                        }
1256		}
1257		/*
1258		dev_dbg(emu->card->dev, "channel=%p\n", pchannel);
1259		dev_dbg(emu->card->dev, "interrupt stat76[%d] = %08x, use=%d, channel=%d\n", i, stat76, pchannel->use, pchannel->number);
1260		*/
1261		mask <<= 1;
1262	}
1263
1264        snd_ca0106_ptr_write(chip, EXTENDED_INT, 0, stat76);
1265
1266	if (chip->midi.dev_id &&
1267	    (status & (chip->midi.ipr_tx|chip->midi.ipr_rx))) {
1268		if (chip->midi.interrupt)
1269			chip->midi.interrupt(&chip->midi, status);
1270		else
1271			chip->midi.interrupt_disable(&chip->midi, chip->midi.tx_enable | chip->midi.rx_enable);
1272	}
1273
1274	// acknowledge the interrupt if necessary
1275	outl(status, chip->port+IPR);
1276
1277	return IRQ_HANDLED;
1278}
1279
1280static const struct snd_pcm_chmap_elem surround_map[] = {
1281	{ .channels = 2,
1282	  .map = { SNDRV_CHMAP_RL, SNDRV_CHMAP_RR } },
1283	{ }
1284};
1285
1286static const struct snd_pcm_chmap_elem clfe_map[] = {
1287	{ .channels = 2,
1288	  .map = { SNDRV_CHMAP_FC, SNDRV_CHMAP_LFE } },
1289	{ }
1290};
1291
1292static const struct snd_pcm_chmap_elem side_map[] = {
1293	{ .channels = 2,
1294	  .map = { SNDRV_CHMAP_SL, SNDRV_CHMAP_SR } },
1295	{ }
1296};
1297
1298static int snd_ca0106_pcm(struct snd_ca0106 *emu, int device)
1299{
1300	struct snd_pcm *pcm;
1301	struct snd_pcm_substream *substream;
1302	const struct snd_pcm_chmap_elem *map = NULL;
1303	int err;
1304  
1305	err = snd_pcm_new(emu->card, "ca0106", device, 1, 1, &pcm);
1306	if (err < 0)
1307		return err;
1308  
1309	pcm->private_data = emu;
1310
1311	switch (device) {
1312	case 0:
1313	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_front_ops);
1314	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_0_ops);
1315	  map = snd_pcm_std_chmaps;
1316          break;
1317	case 1:
1318	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_rear_ops);
1319	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_1_ops);
1320	  map = surround_map;
1321          break;
1322	case 2:
1323	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_center_lfe_ops);
1324	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_2_ops);
1325	  map = clfe_map;
1326          break;
1327	case 3:
1328	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_unknown_ops);
1329	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_3_ops);
1330	  map = side_map;
1331          break;
1332        }
1333
1334	pcm->info_flags = 0;
1335	strcpy(pcm->name, "CA0106");
1336
1337	for(substream = pcm->streams[SNDRV_PCM_STREAM_PLAYBACK].substream; 
1338	    substream; 
1339	    substream = substream->next) {
1340		snd_pcm_set_managed_buffer(substream, SNDRV_DMA_TYPE_DEV,
1341					   &emu->pci->dev,
1342					   64*1024, 64*1024);
1343	}
1344
1345	for (substream = pcm->streams[SNDRV_PCM_STREAM_CAPTURE].substream; 
1346	      substream; 
1347	      substream = substream->next) {
1348		snd_pcm_set_managed_buffer(substream, SNDRV_DMA_TYPE_DEV,
1349					   &emu->pci->dev,
1350					   64*1024, 64*1024);
1351	}
1352  
1353	err = snd_pcm_add_chmap_ctls(pcm, SNDRV_PCM_STREAM_PLAYBACK, map, 2,
1354				     1 << 2, NULL);
1355	if (err < 0)
1356		return err;
1357
1358	emu->pcm[device] = pcm;
1359  
1360	return 0;
1361}
1362
1363#define SPI_REG(reg, value)	(((reg) << SPI_REG_SHIFT) | (value))
1364static const unsigned int spi_dac_init[] = {
1365	SPI_REG(SPI_LDA1_REG,	SPI_DA_BIT_0dB), /* 0dB dig. attenuation */
1366	SPI_REG(SPI_RDA1_REG,	SPI_DA_BIT_0dB),
1367	SPI_REG(SPI_PL_REG,	SPI_PL_BIT_L_L | SPI_PL_BIT_R_R | SPI_IZD_BIT),
1368	SPI_REG(SPI_FMT_REG,	SPI_FMT_BIT_I2S | SPI_IWL_BIT_24),
1369	SPI_REG(SPI_LDA2_REG,	SPI_DA_BIT_0dB),
1370	SPI_REG(SPI_RDA2_REG,	SPI_DA_BIT_0dB),
1371	SPI_REG(SPI_LDA3_REG,	SPI_DA_BIT_0dB),
1372	SPI_REG(SPI_RDA3_REG,	SPI_DA_BIT_0dB),
1373	SPI_REG(SPI_MASTDA_REG,	SPI_DA_BIT_0dB),
1374	SPI_REG(9,		0x00),
1375	SPI_REG(SPI_MS_REG,	SPI_DACD0_BIT | SPI_DACD1_BIT | SPI_DACD2_BIT),
1376	SPI_REG(12,		0x00),
1377	SPI_REG(SPI_LDA4_REG,	SPI_DA_BIT_0dB),
1378	SPI_REG(SPI_RDA4_REG,	SPI_DA_BIT_0dB | SPI_DA_BIT_UPDATE),
1379	SPI_REG(SPI_DACD4_REG,	SPI_DACD4_BIT),
1380};
1381
1382static const unsigned int i2c_adc_init[][2] = {
1383	{ 0x17, 0x00 }, /* Reset */
1384	{ 0x07, 0x00 }, /* Timeout */
1385	{ 0x0b, 0x22 },  /* Interface control */
1386	{ 0x0c, 0x22 },  /* Master mode control */
1387	{ 0x0d, 0x08 },  /* Powerdown control */
1388	{ 0x0e, 0xcf },  /* Attenuation Left  0x01 = -103dB, 0xff = 24dB */
1389	{ 0x0f, 0xcf },  /* Attenuation Right 0.5dB steps */
1390	{ 0x10, 0x7b },  /* ALC Control 1 */
1391	{ 0x11, 0x00 },  /* ALC Control 2 */
1392	{ 0x12, 0x32 },  /* ALC Control 3 */
1393	{ 0x13, 0x00 },  /* Noise gate control */
1394	{ 0x14, 0xa6 },  /* Limiter control */
1395	{ 0x15, ADC_MUX_LINEIN },  /* ADC Mixer control */
1396};
1397
1398static void ca0106_init_chip(struct snd_ca0106 *chip, int resume)
1399{
1400	int ch;
1401	unsigned int def_bits;
1402
1403	outl(0, chip->port + INTE);
1404
1405	/*
1406	 *  Init to 0x02109204 :
1407	 *  Clock accuracy    = 0     (1000ppm)
1408	 *  Sample Rate       = 2     (48kHz)
1409	 *  Audio Channel     = 1     (Left of 2)
1410	 *  Source Number     = 0     (Unspecified)
1411	 *  Generation Status = 1     (Original for Cat Code 12)
1412	 *  Cat Code          = 12    (Digital Signal Mixer)
1413	 *  Mode              = 0     (Mode 0)
1414	 *  Emphasis          = 0     (None)
1415	 *  CP                = 1     (Copyright unasserted)
1416	 *  AN                = 0     (Audio data)
1417	 *  P                 = 0     (Consumer)
1418	 */
1419	def_bits =
1420		SPCS_CLKACCY_1000PPM | SPCS_SAMPLERATE_48 |
1421		SPCS_CHANNELNUM_LEFT | SPCS_SOURCENUM_UNSPEC |
1422		SPCS_GENERATIONSTATUS | 0x00001200 |
1423		0x00000000 | SPCS_EMPHASIS_NONE | SPCS_COPYRIGHT;
1424	if (!resume) {
1425		chip->spdif_str_bits[0] = chip->spdif_bits[0] = def_bits;
1426		chip->spdif_str_bits[1] = chip->spdif_bits[1] = def_bits;
1427		chip->spdif_str_bits[2] = chip->spdif_bits[2] = def_bits;
1428		chip->spdif_str_bits[3] = chip->spdif_bits[3] = def_bits;
1429	}
1430	/* Only SPCS1 has been tested */
1431	snd_ca0106_ptr_write(chip, SPCS1, 0, chip->spdif_str_bits[1]);
1432	snd_ca0106_ptr_write(chip, SPCS0, 0, chip->spdif_str_bits[0]);
1433	snd_ca0106_ptr_write(chip, SPCS2, 0, chip->spdif_str_bits[2]);
1434	snd_ca0106_ptr_write(chip, SPCS3, 0, chip->spdif_str_bits[3]);
1435
1436        snd_ca0106_ptr_write(chip, PLAYBACK_MUTE, 0, 0x00fc0000);
1437        snd_ca0106_ptr_write(chip, CAPTURE_MUTE, 0, 0x00fc0000);
1438
1439        /* Write 0x8000 to AC97_REC_GAIN to mute it. */
1440        outb(AC97_REC_GAIN, chip->port + AC97ADDRESS);
1441        outw(0x8000, chip->port + AC97DATA);
1442#if 0 /* FIXME: what are these? */
1443	snd_ca0106_ptr_write(chip, SPCS0, 0, 0x2108006);
1444	snd_ca0106_ptr_write(chip, 0x42, 0, 0x2108006);
1445	snd_ca0106_ptr_write(chip, 0x43, 0, 0x2108006);
1446	snd_ca0106_ptr_write(chip, 0x44, 0, 0x2108006);
1447#endif
1448
1449	/* OSS drivers set this. */
1450	/* snd_ca0106_ptr_write(chip, SPDIF_SELECT2, 0, 0xf0f003f); */
1451
1452	/* Analog or Digital output */
1453	snd_ca0106_ptr_write(chip, SPDIF_SELECT1, 0, 0xf);
1454	/* 0x0b000000 for digital, 0x000b0000 for analog, from win2000 drivers.
1455	 * Use 0x000f0000 for surround71
1456	 */
1457	snd_ca0106_ptr_write(chip, SPDIF_SELECT2, 0, 0x000f0000);
1458
1459	chip->spdif_enable = 0; /* Set digital SPDIF output off */
1460	/*snd_ca0106_ptr_write(chip, 0x45, 0, 0);*/ /* Analogue out */
1461	/*snd_ca0106_ptr_write(chip, 0x45, 0, 0xf00);*/ /* Digital out */
1462
1463	/* goes to 0x40c80000 when doing SPDIF IN/OUT */
1464	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 0, 0x40c81000);
1465	/* (Mute) CAPTURE feedback into PLAYBACK volume.
1466	 * Only lower 16 bits matter.
1467	 */
1468	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 1, 0xffffffff);
1469	/* SPDIF IN Volume */
1470	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 2, 0x30300000);
1471	/* SPDIF IN Volume, 0x70 = (vol & 0x3f) | 0x40 */
1472	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 3, 0x00700000);
1473
1474	snd_ca0106_ptr_write(chip, PLAYBACK_ROUTING1, 0, 0x32765410);
1475	snd_ca0106_ptr_write(chip, PLAYBACK_ROUTING2, 0, 0x76767676);
1476	snd_ca0106_ptr_write(chip, CAPTURE_ROUTING1, 0, 0x32765410);
1477	snd_ca0106_ptr_write(chip, CAPTURE_ROUTING2, 0, 0x76767676);
1478
1479	for (ch = 0; ch < 4; ch++) {
1480		/* Only high 16 bits matter */
1481		snd_ca0106_ptr_write(chip, CAPTURE_VOLUME1, ch, 0x30303030);
1482		snd_ca0106_ptr_write(chip, CAPTURE_VOLUME2, ch, 0x30303030);
1483#if 0 /* Mute */
1484		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME1, ch, 0x40404040);
1485		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME2, ch, 0x40404040);
1486		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME1, ch, 0xffffffff);
1487		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME2, ch, 0xffffffff);
1488#endif
1489	}
1490	if (chip->details->i2c_adc == 1) {
1491	        /* Select MIC, Line in, TAD in, AUX in */
1492	        snd_ca0106_ptr_write(chip, CAPTURE_SOURCE, 0x0, 0x333300e4);
1493		/* Default to CAPTURE_SOURCE to i2s in */
1494		if (!resume)
1495			chip->capture_source = 3;
1496	} else if (chip->details->ac97 == 1) {
1497	        /* Default to AC97 in */
1498	        snd_ca0106_ptr_write(chip, CAPTURE_SOURCE, 0x0, 0x444400e4);
1499		/* Default to CAPTURE_SOURCE to AC97 in */
1500		if (!resume)
1501			chip->capture_source = 4;
1502	} else {
1503	        /* Select MIC, Line in, TAD in, AUX in */
1504	        snd_ca0106_ptr_write(chip, CAPTURE_SOURCE, 0x0, 0x333300e4);
1505		/* Default to Set CAPTURE_SOURCE to i2s in */
1506		if (!resume)
1507			chip->capture_source = 3;
1508	}
1509
1510	if (chip->details->gpio_type == 2) {
1511		/* The SB0438 use GPIO differently. */
1512		/* FIXME: Still need to find out what the other GPIO bits do.
1513		 * E.g. For digital spdif out.
1514		 */
1515		outl(0x0, chip->port+GPIO);
1516		/* outl(0x00f0e000, chip->port+GPIO); */ /* Analog */
1517		outl(0x005f5301, chip->port+GPIO); /* Analog */
1518	} else if (chip->details->gpio_type == 1) {
1519		/* The SB0410 and SB0413 use GPIO differently. */
1520		/* FIXME: Still need to find out what the other GPIO bits do.
1521		 * E.g. For digital spdif out.
1522		 */
1523		outl(0x0, chip->port+GPIO);
1524		/* outl(0x00f0e000, chip->port+GPIO); */ /* Analog */
1525		outl(0x005f5301, chip->port+GPIO); /* Analog */
1526	} else {
1527		outl(0x0, chip->port+GPIO);
1528		outl(0x005f03a3, chip->port+GPIO); /* Analog */
1529		/* outl(0x005f02a2, chip->port+GPIO); */ /* SPDIF */
1530	}
1531	snd_ca0106_intr_enable(chip, 0x105); /* Win2000 uses 0x1e0 */
1532
1533	/* outl(HCFG_LOCKSOUNDCACHE|HCFG_AUDIOENABLE, chip->port+HCFG); */
1534	/* 0x1000 causes AC3 to fails. Maybe it effects 24 bit output. */
1535	/* outl(0x00001409, chip->port+HCFG); */
1536	/* outl(0x00000009, chip->port+HCFG); */
1537	/* AC97 2.0, Enable outputs. */
1538	outl(HCFG_AC97 | HCFG_AUDIOENABLE, chip->port+HCFG);
1539
1540	if (chip->details->i2c_adc == 1) {
1541		/* The SB0410 and SB0413 use I2C to control ADC. */
1542		int size, n;
1543
1544		size = ARRAY_SIZE(i2c_adc_init);
1545		/* dev_dbg(emu->card->dev, "I2C:array size=0x%x\n", size); */
1546		for (n = 0; n < size; n++)
1547			snd_ca0106_i2c_write(chip, i2c_adc_init[n][0],
1548					     i2c_adc_init[n][1]);
1549		for (n = 0; n < 4; n++) {
1550			chip->i2c_capture_volume[n][0] = 0xcf;
1551			chip->i2c_capture_volume[n][1] = 0xcf;
1552		}
1553		chip->i2c_capture_source = 2; /* Line in */
1554		/* Enable Line-in capture. MIC in currently untested. */
1555		/* snd_ca0106_i2c_write(chip, ADC_MUX, ADC_MUX_LINEIN); */
1556	}
1557
1558	if (chip->details->spi_dac) {
1559		/* The SB0570 use SPI to control DAC. */
1560		int size, n;
1561
1562		size = ARRAY_SIZE(spi_dac_init);
1563		for (n = 0; n < size; n++) {
1564			int reg = spi_dac_init[n] >> SPI_REG_SHIFT;
1565
1566			snd_ca0106_spi_write(chip, spi_dac_init[n]);
1567			if (reg < ARRAY_SIZE(chip->spi_dac_reg))
1568				chip->spi_dac_reg[reg] = spi_dac_init[n];
1569		}
1570
1571		/* Enable front dac only */
1572		snd_ca0106_pcm_power_dac(chip, PCM_FRONT_CHANNEL, 1);
1573	}
1574}
1575
1576static void ca0106_stop_chip(struct snd_ca0106 *chip)
1577{
1578	/* disable interrupts */
1579	snd_ca0106_ptr_write(chip, BASIC_INTERRUPT, 0, 0);
1580	outl(0, chip->port + INTE);
1581	snd_ca0106_ptr_write(chip, EXTENDED_INT_MASK, 0, 0);
1582	udelay(1000);
1583	/* disable audio */
1584	/* outl(HCFG_LOCKSOUNDCACHE, chip->port + HCFG); */
1585	outl(0, chip->port + HCFG);
1586	/* FIXME: We need to stop and DMA transfers here.
1587	 *        But as I am not sure how yet, we cannot from the dma pages.
1588	 * So we can fix: snd-malloc: Memory leak?  pages not freed = 8
1589	 */
1590}
1591
1592static int snd_ca0106_create(int dev, struct snd_card *card,
1593					 struct pci_dev *pci,
1594					 struct snd_ca0106 **rchip)
1595{
1596	struct snd_ca0106 *chip;
1597	const struct snd_ca0106_details *c;
1598	int err;
1599	static const struct snd_device_ops ops = {
1600		.dev_free = snd_ca0106_dev_free,
1601	};
1602
1603	*rchip = NULL;
1604
1605	err = pci_enable_device(pci);
1606	if (err < 0)
1607		return err;
1608	if (dma_set_mask(&pci->dev, DMA_BIT_MASK(32)) < 0 ||
1609	    dma_set_coherent_mask(&pci->dev, DMA_BIT_MASK(32)) < 0) {
1610		dev_err(card->dev, "error to set 32bit mask DMA\n");
1611		pci_disable_device(pci);
1612		return -ENXIO;
1613	}
1614
1615	chip = kzalloc(sizeof(*chip), GFP_KERNEL);
1616	if (chip == NULL) {
1617		pci_disable_device(pci);
1618		return -ENOMEM;
1619	}
1620
1621	chip->card = card;
1622	chip->pci = pci;
1623	chip->irq = -1;
1624
1625	spin_lock_init(&chip->emu_lock);
1626
 
 
 
1627	chip->port = pci_resource_start(pci, 0);
1628	chip->res_port = request_region(chip->port, 0x20, "snd_ca0106");
1629	if (!chip->res_port) {
1630		snd_ca0106_free(chip);
1631		dev_err(card->dev, "cannot allocate the port\n");
1632		return -EBUSY;
1633	}
1634
1635	if (request_irq(pci->irq, snd_ca0106_interrupt,
1636			IRQF_SHARED, KBUILD_MODNAME, chip)) {
1637		snd_ca0106_free(chip);
1638		dev_err(card->dev, "cannot grab irq\n");
1639		return -EBUSY;
1640	}
1641	chip->irq = pci->irq;
1642	card->sync_irq = chip->irq;
1643
1644	/* This stores the periods table. */
1645	if (snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV, &pci->dev,
1646				1024, &chip->buffer) < 0) {
1647		snd_ca0106_free(chip);
1648		return -ENOMEM;
1649	}
1650
1651	pci_set_master(pci);
1652	/* read serial */
1653	pci_read_config_dword(pci, PCI_SUBSYSTEM_VENDOR_ID, &chip->serial);
1654	pci_read_config_word(pci, PCI_SUBSYSTEM_ID, &chip->model);
1655	dev_info(card->dev, "Model %04x Rev %08x Serial %08x\n",
1656	       chip->model, pci->revision, chip->serial);
1657	strcpy(card->driver, "CA0106");
1658	strcpy(card->shortname, "CA0106");
1659
1660	for (c = ca0106_chip_details; c->serial; c++) {
1661		if (subsystem[dev]) {
1662			if (c->serial == subsystem[dev])
1663				break;
1664		} else if (c->serial == chip->serial)
1665			break;
1666	}
1667	chip->details = c;
1668	if (subsystem[dev]) {
1669		dev_info(card->dev, "Sound card name=%s, "
1670		       "subsystem=0x%x. Forced to subsystem=0x%x\n",
1671		       c->name, chip->serial, subsystem[dev]);
1672	}
1673
1674	sprintf(card->longname, "%s at 0x%lx irq %i",
1675		c->name, chip->port, chip->irq);
1676
1677	ca0106_init_chip(chip, 0);
1678
1679	err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops);
1680	if (err < 0) {
1681		snd_ca0106_free(chip);
1682		return err;
1683	}
1684	*rchip = chip;
1685	return 0;
1686}
1687
1688
1689static void ca0106_midi_interrupt_enable(struct snd_ca_midi *midi, int intr)
1690{
1691	snd_ca0106_intr_enable((struct snd_ca0106 *)(midi->dev_id), intr);
1692}
1693
1694static void ca0106_midi_interrupt_disable(struct snd_ca_midi *midi, int intr)
1695{
1696	snd_ca0106_intr_disable((struct snd_ca0106 *)(midi->dev_id), intr);
1697}
1698
1699static unsigned char ca0106_midi_read(struct snd_ca_midi *midi, int idx)
1700{
1701	return (unsigned char)snd_ca0106_ptr_read((struct snd_ca0106 *)(midi->dev_id),
1702						  midi->port + idx, 0);
1703}
1704
1705static void ca0106_midi_write(struct snd_ca_midi *midi, int data, int idx)
1706{
1707	snd_ca0106_ptr_write((struct snd_ca0106 *)(midi->dev_id), midi->port + idx, 0, data);
1708}
1709
1710static struct snd_card *ca0106_dev_id_card(void *dev_id)
1711{
1712	return ((struct snd_ca0106 *)dev_id)->card;
1713}
1714
1715static int ca0106_dev_id_port(void *dev_id)
1716{
1717	return ((struct snd_ca0106 *)dev_id)->port;
1718}
1719
1720static int snd_ca0106_midi(struct snd_ca0106 *chip, unsigned int channel)
1721{
1722	struct snd_ca_midi *midi;
1723	char *name;
1724	int err;
1725
1726	if (channel == CA0106_MIDI_CHAN_B) {
1727		name = "CA0106 MPU-401 (UART) B";
1728		midi =  &chip->midi2;
1729		midi->tx_enable = INTE_MIDI_TX_B;
1730		midi->rx_enable = INTE_MIDI_RX_B;
1731		midi->ipr_tx = IPR_MIDI_TX_B;
1732		midi->ipr_rx = IPR_MIDI_RX_B;
1733		midi->port = MIDI_UART_B_DATA;
1734	} else {
1735		name = "CA0106 MPU-401 (UART)";
1736		midi =  &chip->midi;
1737		midi->tx_enable = INTE_MIDI_TX_A;
1738		midi->rx_enable = INTE_MIDI_TX_B;
1739		midi->ipr_tx = IPR_MIDI_TX_A;
1740		midi->ipr_rx = IPR_MIDI_RX_A;
1741		midi->port = MIDI_UART_A_DATA;
1742	}
1743
1744	midi->reset = CA0106_MPU401_RESET;
1745	midi->enter_uart = CA0106_MPU401_ENTER_UART;
1746	midi->ack = CA0106_MPU401_ACK;
1747
1748	midi->input_avail = CA0106_MIDI_INPUT_AVAIL;
1749	midi->output_ready = CA0106_MIDI_OUTPUT_READY;
1750
1751	midi->channel = channel;
1752
1753	midi->interrupt_enable = ca0106_midi_interrupt_enable;
1754	midi->interrupt_disable = ca0106_midi_interrupt_disable;
1755
1756	midi->read = ca0106_midi_read;
1757	midi->write = ca0106_midi_write;
1758
1759	midi->get_dev_id_card = ca0106_dev_id_card;
1760	midi->get_dev_id_port = ca0106_dev_id_port;
1761
1762	midi->dev_id = chip;
1763	
1764	if ((err = ca_midi_init(chip, midi, 0, name)) < 0)
 
1765		return err;
1766
1767	return 0;
1768}
1769
1770
1771static int snd_ca0106_probe(struct pci_dev *pci,
1772					const struct pci_device_id *pci_id)
1773{
1774	static int dev;
1775	struct snd_card *card;
1776	struct snd_ca0106 *chip;
1777	int i, err;
1778
1779	if (dev >= SNDRV_CARDS)
1780		return -ENODEV;
1781	if (!enable[dev]) {
1782		dev++;
1783		return -ENOENT;
1784	}
1785
1786	err = snd_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
1787			   0, &card);
1788	if (err < 0)
1789		return err;
 
1790
1791	err = snd_ca0106_create(dev, card, pci, &chip);
1792	if (err < 0)
1793		goto error;
1794	card->private_data = chip;
1795
1796	for (i = 0; i < 4; i++) {
1797		err = snd_ca0106_pcm(chip, i);
1798		if (err < 0)
1799			goto error;
1800	}
1801
1802	if (chip->details->ac97 == 1) {
1803		/* The SB0410 and SB0413 do not have an AC97 chip. */
1804		err = snd_ca0106_ac97(chip);
1805		if (err < 0)
1806			goto error;
1807	}
1808	err = snd_ca0106_mixer(chip);
1809	if (err < 0)
1810		goto error;
1811
1812	dev_dbg(card->dev, "probe for MIDI channel A ...");
1813	err = snd_ca0106_midi(chip, CA0106_MIDI_CHAN_A);
1814	if (err < 0)
1815		goto error;
1816	dev_dbg(card->dev, " done.\n");
1817
1818#ifdef CONFIG_SND_PROC_FS
1819	snd_ca0106_proc_init(chip);
1820#endif
1821
1822	err = snd_card_register(card);
1823	if (err < 0)
1824		goto error;
1825
1826	pci_set_drvdata(pci, card);
1827	dev++;
1828	return 0;
1829
1830 error:
1831	snd_card_free(card);
1832	return err;
1833}
1834
1835static void snd_ca0106_remove(struct pci_dev *pci)
 
1836{
1837	snd_card_free(pci_get_drvdata(pci));
1838}
1839
1840#ifdef CONFIG_PM_SLEEP
1841static int snd_ca0106_suspend(struct device *dev)
1842{
1843	struct snd_card *card = dev_get_drvdata(dev);
1844	struct snd_ca0106 *chip = card->private_data;
1845
1846	snd_power_change_state(card, SNDRV_CTL_POWER_D3hot);
1847	if (chip->details->ac97)
1848		snd_ac97_suspend(chip->ac97);
1849	snd_ca0106_mixer_suspend(chip);
1850
1851	ca0106_stop_chip(chip);
1852	return 0;
1853}
1854
1855static int snd_ca0106_resume(struct device *dev)
1856{
1857	struct snd_card *card = dev_get_drvdata(dev);
1858	struct snd_ca0106 *chip = card->private_data;
1859	int i;
1860
1861	ca0106_init_chip(chip, 1);
1862
1863	if (chip->details->ac97)
1864		snd_ac97_resume(chip->ac97);
1865	snd_ca0106_mixer_resume(chip);
1866	if (chip->details->spi_dac) {
1867		for (i = 0; i < ARRAY_SIZE(chip->spi_dac_reg); i++)
1868			snd_ca0106_spi_write(chip, chip->spi_dac_reg[i]);
1869	}
1870
1871	snd_power_change_state(card, SNDRV_CTL_POWER_D0);
1872	return 0;
1873}
1874
1875static SIMPLE_DEV_PM_OPS(snd_ca0106_pm, snd_ca0106_suspend, snd_ca0106_resume);
1876#define SND_CA0106_PM_OPS	&snd_ca0106_pm
1877#else
1878#define SND_CA0106_PM_OPS	NULL
1879#endif
1880
1881// PCI IDs
1882static const struct pci_device_id snd_ca0106_ids[] = {
1883	{ PCI_VDEVICE(CREATIVE, 0x0007), 0 },	/* Audigy LS or Live 24bit */
1884	{ 0, }
1885};
1886MODULE_DEVICE_TABLE(pci, snd_ca0106_ids);
1887
1888// pci_driver definition
1889static struct pci_driver ca0106_driver = {
1890	.name = KBUILD_MODNAME,
1891	.id_table = snd_ca0106_ids,
1892	.probe = snd_ca0106_probe,
1893	.remove = snd_ca0106_remove,
1894	.driver = {
1895		.pm = SND_CA0106_PM_OPS,
1896	},
1897};
1898
1899module_pci_driver(ca0106_driver);
v6.2
   1// SPDX-License-Identifier: GPL-2.0-or-later
   2/*
   3 *  Copyright (c) 2004 James Courtier-Dutton <James@superbug.demon.co.uk>
   4 *  Driver CA0106 chips. e.g. Sound Blaster Audigy LS and Live 24bit
   5 *  Version: 0.0.25
   6 *
   7 *  FEATURES currently supported:
   8 *    Front, Rear and Center/LFE.
   9 *    Surround40 and Surround51.
  10 *    Capture from MIC an LINE IN input.
  11 *    SPDIF digital playback of PCM stereo and AC3/DTS works.
  12 *    (One can use a standard mono mini-jack to one RCA plugs cable.
  13 *     or one can use a standard stereo mini-jack to two RCA plugs cable.
  14 *     Plug one of the RCA plugs into the Coax input of the external decoder/receiver.)
  15 *    ( In theory one could output 3 different AC3 streams at once, to 3 different SPDIF outputs. )
  16 *    Notes on how to capture sound:
  17 *      The AC97 is used in the PLAYBACK direction.
  18 *      The output from the AC97 chip, instead of reaching the speakers, is fed into the Philips 1361T ADC.
  19 *      So, to record from the MIC, set the MIC Playback volume to max,
  20 *      unmute the MIC and turn up the MASTER Playback volume.
  21 *      So, to prevent feedback when capturing, minimise the "Capture feedback into Playback" volume.
  22 *   
  23 *    The only playback controls that currently do anything are: -
  24 *    Analog Front
  25 *    Analog Rear
  26 *    Analog Center/LFE
  27 *    SPDIF Front
  28 *    SPDIF Rear
  29 *    SPDIF Center/LFE
  30 *   
  31 *    For capture from Mic in or Line in.
  32 *    Digital/Analog ( switch must be in Analog mode for CAPTURE. )
  33 * 
  34 *    CAPTURE feedback into PLAYBACK
  35 * 
  36 *  Changelog:
  37 *    Support interrupts per period.
  38 *    Removed noise from Center/LFE channel when in Analog mode.
  39 *    Rename and remove mixer controls.
  40 *  0.0.6
  41 *    Use separate card based DMA buffer for periods table list.
  42 *  0.0.7
  43 *    Change remove and rename ctrls into lists.
  44 *  0.0.8
  45 *    Try to fix capture sources.
  46 *  0.0.9
  47 *    Fix AC3 output.
  48 *    Enable S32_LE format support.
  49 *  0.0.10
  50 *    Enable playback 48000 and 96000 rates. (Rates other that these do not work, even with "plug:front".)
  51 *  0.0.11
  52 *    Add Model name recognition.
  53 *  0.0.12
  54 *    Correct interrupt timing. interrupt at end of period, instead of in the middle of a playback period.
  55 *    Remove redundent "voice" handling.
  56 *  0.0.13
  57 *    Single trigger call for multi channels.
  58 *  0.0.14
  59 *    Set limits based on what the sound card hardware can do.
  60 *    playback periods_min=2, periods_max=8
  61 *    capture hw constraints require period_size = n * 64 bytes.
  62 *    playback hw constraints require period_size = n * 64 bytes.
  63 *  0.0.15
  64 *    Minor updates.
  65 *  0.0.16
  66 *    Implement 192000 sample rate.
  67 *  0.0.17
  68 *    Add support for SB0410 and SB0413.
  69 *  0.0.18
  70 *    Modified Copyright message.
  71 *  0.0.19
  72 *    Finally fix support for SB Live 24 bit. SB0410 and SB0413.
  73 *    The output codec needs resetting, otherwise all output is muted.
  74 *  0.0.20
  75 *    Merge "pci_disable_device(pci);" fixes.
  76 *  0.0.21
  77 *    Add 4 capture channels. (SPDIF only comes in on channel 0. )
  78 *    Add SPDIF capture using optional digital I/O module for SB Live 24bit. (Analog capture does not yet work.)
  79 *  0.0.22
  80 *    Add support for MSI K8N Diamond Motherboard with onboard SB Live 24bit without AC97. From kiksen, bug #901
  81 *  0.0.23
  82 *    Implement support for Line-in capture on SB Live 24bit.
  83 *  0.0.24
  84 *    Add support for mute control on SB Live 24bit (cards w/ SPI DAC)
  85 *  0.0.25
  86 *    Powerdown SPI DAC channels when not in use
  87 *
  88 *  BUGS:
  89 *    Some stability problems when unloading the snd-ca0106 kernel module.
  90 *    --
  91 *
  92 *  TODO:
  93 *    4 Capture channels, only one implemented so far.
  94 *    Other capture rates apart from 48khz not implemented.
  95 *    MIDI
  96 *    --
  97 *  GENERAL INFO:
  98 *    Model: SB0310
  99 *    P17 Chip: CA0106-DAT
 100 *    AC97 Codec: STAC 9721
 101 *    ADC: Philips 1361T (Stereo 24bit)
 102 *    DAC: WM8746EDS (6-channel, 24bit, 192Khz)
 103 *
 104 *  GENERAL INFO:
 105 *    Model: SB0410
 106 *    P17 Chip: CA0106-DAT
 107 *    AC97 Codec: None
 108 *    ADC: WM8775EDS (4 Channel)
 109 *    DAC: CS4382 (114 dB, 24-Bit, 192 kHz, 8-Channel D/A Converter with DSD Support)
 110 *    SPDIF Out control switches between Mic in and SPDIF out.
 111 *    No sound out or mic input working yet.
 112 * 
 113 *  GENERAL INFO:
 114 *    Model: SB0413
 115 *    P17 Chip: CA0106-DAT
 116 *    AC97 Codec: None.
 117 *    ADC: Unknown
 118 *    DAC: Unknown
 119 *    Trying to handle it like the SB0410.
 120 *
 121 *  This code was initially based on code from ALSA's emu10k1x.c which is:
 122 *  Copyright (c) by Francisco Moraes <fmoraes@nc.rr.com>
 123 */
 124#include <linux/delay.h>
 125#include <linux/init.h>
 126#include <linux/interrupt.h>
 127#include <linux/pci.h>
 128#include <linux/slab.h>
 129#include <linux/module.h>
 130#include <linux/dma-mapping.h>
 131#include <sound/core.h>
 132#include <sound/initval.h>
 133#include <sound/pcm.h>
 134#include <sound/ac97_codec.h>
 135#include <sound/info.h>
 136
 137MODULE_AUTHOR("James Courtier-Dutton <James@superbug.demon.co.uk>");
 138MODULE_DESCRIPTION("CA0106");
 139MODULE_LICENSE("GPL");
 
 140
 141// module parameters (see "Module Parameters")
 142static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
 143static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR;
 144static bool enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP;
 145static uint subsystem[SNDRV_CARDS]; /* Force card subsystem model */
 146
 147module_param_array(index, int, NULL, 0444);
 148MODULE_PARM_DESC(index, "Index value for the CA0106 soundcard.");
 149module_param_array(id, charp, NULL, 0444);
 150MODULE_PARM_DESC(id, "ID string for the CA0106 soundcard.");
 151module_param_array(enable, bool, NULL, 0444);
 152MODULE_PARM_DESC(enable, "Enable the CA0106 soundcard.");
 153module_param_array(subsystem, uint, NULL, 0444);
 154MODULE_PARM_DESC(subsystem, "Force card subsystem model.");
 155
 156#include "ca0106.h"
 157
 158static const struct snd_ca0106_details ca0106_chip_details[] = {
 159	 /* Sound Blaster X-Fi Extreme Audio. This does not have an AC97. 53SB079000000 */
 160	 /* It is really just a normal SB Live 24bit. */
 161	 /* Tested:
 162	  * See ALSA bug#3251
 163	  */
 164	 { .serial = 0x10131102,
 165	   .name   = "X-Fi Extreme Audio [SBxxxx]",
 166	   .gpio_type = 1,
 167	   .i2c_adc = 1 } ,
 168	 /* Sound Blaster X-Fi Extreme Audio. This does not have an AC97. 53SB079000000 */
 169	 /* It is really just a normal SB Live 24bit. */
 170	 /*
 171 	  * CTRL:CA0111-WTLF
 172	  * ADC: WM8775SEDS
 173	  * DAC: CS4382-KQZ
 174	  */
 175	 /* Tested:
 176	  * Playback on front, rear, center/lfe speakers
 177	  * Capture from Mic in.
 178	  * Not-Tested:
 179	  * Capture from Line in.
 180	  * Playback to digital out.
 181	  */
 182	 { .serial = 0x10121102,
 183	   .name   = "X-Fi Extreme Audio [SB0790]",
 184	   .gpio_type = 1,
 185	   .i2c_adc = 1 } ,
 186	 /* New Dell Sound Blaster Live! 7.1 24bit. This does not have an AC97.  */
 187	 /* AudigyLS[SB0310] */
 188	 { .serial = 0x10021102,
 189	   .name   = "AudigyLS [SB0310]",
 190	   .ac97   = 1 } , 
 191	 /* Unknown AudigyLS that also says SB0310 on it */
 192	 { .serial = 0x10051102,
 193	   .name   = "AudigyLS [SB0310b]",
 194	   .ac97   = 1 } ,
 195	 /* New Sound Blaster Live! 7.1 24bit. This does not have an AC97. 53SB041000001 */
 196	 { .serial = 0x10061102,
 197	   .name   = "Live! 7.1 24bit [SB0410]",
 198	   .gpio_type = 1,
 199	   .i2c_adc = 1 } ,
 200	 /* New Dell Sound Blaster Live! 7.1 24bit. This does not have an AC97.  */
 201	 { .serial = 0x10071102,
 202	   .name   = "Live! 7.1 24bit [SB0413]",
 203	   .gpio_type = 1,
 204	   .i2c_adc = 1 } ,
 205	 /* New Audigy SE. Has a different DAC. */
 206	 /* SB0570:
 207	  * CTRL:CA0106-DAT
 208	  * ADC: WM8775EDS
 209	  * DAC: WM8768GEDS
 210	  */
 211	 { .serial = 0x100a1102,
 212	   .name   = "Audigy SE [SB0570]",
 213	   .gpio_type = 1,
 214	   .i2c_adc = 1,
 215	   .spi_dac = 0x4021 } ,
 216	 /* New Audigy LS. Has a different DAC. */
 217	 /* SB0570:
 218	  * CTRL:CA0106-DAT
 219	  * ADC: WM8775EDS
 220	  * DAC: WM8768GEDS
 221	  */
 222	 { .serial = 0x10111102,
 223	   .name   = "Audigy SE OEM [SB0570a]",
 224	   .gpio_type = 1,
 225	   .i2c_adc = 1,
 226	   .spi_dac = 0x4021 } ,
 227	/* Sound Blaster 5.1vx
 228	 * Tested: Playback on front, rear, center/lfe speakers
 229	 * Not-Tested: Capture
 230	 */
 231	{ .serial = 0x10041102,
 232	  .name   = "Sound Blaster 5.1vx [SB1070]",
 233	  .gpio_type = 1,
 234	  .i2c_adc = 0,
 235	  .spi_dac = 0x0124
 236	 } ,
 237	 /* MSI K8N Diamond Motherboard with onboard SB Live 24bit without AC97 */
 238	 /* SB0438
 239	  * CTRL:CA0106-DAT
 240	  * ADC: WM8775SEDS
 241	  * DAC: CS4382-KQZ
 242	  */
 243	 { .serial = 0x10091462,
 244	   .name   = "MSI K8N Diamond MB [SB0438]",
 245	   .gpio_type = 2,
 246	   .i2c_adc = 1 } ,
 247	 /* MSI K8N Diamond PLUS MB */
 248	 { .serial = 0x10091102,
 249	   .name   = "MSI K8N Diamond MB",
 250	   .gpio_type = 2,
 251	   .i2c_adc = 1,
 252	   .spi_dac = 0x4021 } ,
 253	/* Giga-byte GA-G1975X mobo
 254	 * Novell bnc#395807
 255	 */
 256	/* FIXME: the GPIO and I2C setting aren't tested well */
 257	{ .serial = 0x1458a006,
 258	  .name = "Giga-byte GA-G1975X",
 259	  .gpio_type = 1,
 260	  .i2c_adc = 1 },
 261	 /* Shuttle XPC SD31P which has an onboard Creative Labs
 262	  * Sound Blaster Live! 24-bit EAX
 263	  * high-definition 7.1 audio processor".
 264	  * Added using info from andrewvegan in alsa bug #1298
 265	  */
 266	 { .serial = 0x30381297,
 267	   .name   = "Shuttle XPC SD31P [SD31P]",
 268	   .gpio_type = 1,
 269	   .i2c_adc = 1 } ,
 270	/* Shuttle XPC SD11G5 which has an onboard Creative Labs
 271	 * Sound Blaster Live! 24-bit EAX
 272	 * high-definition 7.1 audio processor".
 273	 * Fixes ALSA bug#1600
 274         */
 275	{ .serial = 0x30411297,
 276	  .name = "Shuttle XPC SD11G5 [SD11G5]",
 277	  .gpio_type = 1,
 278	  .i2c_adc = 1 } ,
 279	 { .serial = 0,
 280	   .name   = "AudigyLS [Unknown]" }
 281};
 282
 283/* hardware definition */
 284static const struct snd_pcm_hardware snd_ca0106_playback_hw = {
 285	.info =			SNDRV_PCM_INFO_MMAP | 
 286				SNDRV_PCM_INFO_INTERLEAVED |
 287				SNDRV_PCM_INFO_BLOCK_TRANSFER |
 288				SNDRV_PCM_INFO_MMAP_VALID |
 289				SNDRV_PCM_INFO_SYNC_START,
 290	.formats =		SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S32_LE,
 291	.rates =		(SNDRV_PCM_RATE_48000 | SNDRV_PCM_RATE_96000 |
 292				 SNDRV_PCM_RATE_192000),
 293	.rate_min =		48000,
 294	.rate_max =		192000,
 295	.channels_min =		2,  //1,
 296	.channels_max =		2,  //6,
 297	.buffer_bytes_max =	((65536 - 64) * 8),
 298	.period_bytes_min =	64,
 299	.period_bytes_max =	(65536 - 64),
 300	.periods_min =		2,
 301	.periods_max =		8,
 302	.fifo_size =		0,
 303};
 304
 305static const struct snd_pcm_hardware snd_ca0106_capture_hw = {
 306	.info =			(SNDRV_PCM_INFO_MMAP | 
 307				 SNDRV_PCM_INFO_INTERLEAVED |
 308				 SNDRV_PCM_INFO_BLOCK_TRANSFER |
 309				 SNDRV_PCM_INFO_MMAP_VALID),
 310	.formats =		SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S32_LE,
 311#if 0 /* FIXME: looks like 44.1kHz capture causes noisy output on 48kHz */
 312	.rates =		(SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_48000 |
 313				 SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_192000),
 314	.rate_min =		44100,
 315#else
 316	.rates =		(SNDRV_PCM_RATE_48000 |
 317				 SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_192000),
 318	.rate_min =		48000,
 319#endif /* FIXME */
 320	.rate_max =		192000,
 321	.channels_min =		2,
 322	.channels_max =		2,
 323	.buffer_bytes_max =	65536 - 128,
 324	.period_bytes_min =	64,
 325	.period_bytes_max =	32768 - 64,
 326	.periods_min =		2,
 327	.periods_max =		2,
 328	.fifo_size =		0,
 329};
 330
 331unsigned int snd_ca0106_ptr_read(struct snd_ca0106 * emu, 
 332					  unsigned int reg, 
 333					  unsigned int chn)
 334{
 335	unsigned long flags;
 336	unsigned int regptr, val;
 337  
 338	regptr = (reg << 16) | chn;
 339
 340	spin_lock_irqsave(&emu->emu_lock, flags);
 341	outl(regptr, emu->port + CA0106_PTR);
 342	val = inl(emu->port + CA0106_DATA);
 343	spin_unlock_irqrestore(&emu->emu_lock, flags);
 344	return val;
 345}
 346
 347void snd_ca0106_ptr_write(struct snd_ca0106 *emu, 
 348				   unsigned int reg, 
 349				   unsigned int chn, 
 350				   unsigned int data)
 351{
 352	unsigned int regptr;
 353	unsigned long flags;
 354
 355	regptr = (reg << 16) | chn;
 356
 357	spin_lock_irqsave(&emu->emu_lock, flags);
 358	outl(regptr, emu->port + CA0106_PTR);
 359	outl(data, emu->port + CA0106_DATA);
 360	spin_unlock_irqrestore(&emu->emu_lock, flags);
 361}
 362
 363int snd_ca0106_spi_write(struct snd_ca0106 * emu,
 364				   unsigned int data)
 365{
 366	unsigned int reset, set;
 367	unsigned int reg, tmp;
 368	int n, result;
 369	reg = SPI;
 370	if (data > 0xffff) /* Only 16bit values allowed */
 371		return 1;
 372	tmp = snd_ca0106_ptr_read(emu, reg, 0);
 373	reset = (tmp & ~0x3ffff) | 0x20000; /* Set xxx20000 */
 374	set = reset | 0x10000; /* Set xxx1xxxx */
 375	snd_ca0106_ptr_write(emu, reg, 0, reset | data);
 376	tmp = snd_ca0106_ptr_read(emu, reg, 0); /* write post */
 377	snd_ca0106_ptr_write(emu, reg, 0, set | data);
 378	result = 1;
 379	/* Wait for status bit to return to 0 */
 380	for (n = 0; n < 100; n++) {
 381		udelay(10);
 382		tmp = snd_ca0106_ptr_read(emu, reg, 0);
 383		if (!(tmp & 0x10000)) {
 384			result = 0;
 385			break;
 386		}
 387	}
 388	if (result) /* Timed out */
 389		return 1;
 390	snd_ca0106_ptr_write(emu, reg, 0, reset | data);
 391	tmp = snd_ca0106_ptr_read(emu, reg, 0); /* Write post */
 392	return 0;
 393}
 394
 395/* The ADC does not support i2c read, so only write is implemented */
 396int snd_ca0106_i2c_write(struct snd_ca0106 *emu,
 397				u32 reg,
 398				u32 value)
 399{
 400	u32 tmp;
 401	int timeout = 0;
 402	int status;
 403	int retry;
 404	if ((reg > 0x7f) || (value > 0x1ff)) {
 405		dev_err(emu->card->dev, "i2c_write: invalid values.\n");
 406		return -EINVAL;
 407	}
 408
 409	tmp = reg << 25 | value << 16;
 410	/*
 411	dev_dbg(emu->card->dev, "I2C-write:reg=0x%x, value=0x%x\n", reg, value);
 412	*/
 413	/* Not sure what this I2C channel controls. */
 414	/* snd_ca0106_ptr_write(emu, I2C_D0, 0, tmp); */
 415
 416	/* This controls the I2C connected to the WM8775 ADC Codec */
 417	snd_ca0106_ptr_write(emu, I2C_D1, 0, tmp);
 418
 419	for (retry = 0; retry < 10; retry++) {
 420		/* Send the data to i2c */
 421		//tmp = snd_ca0106_ptr_read(emu, I2C_A, 0);
 422		//tmp = tmp & ~(I2C_A_ADC_READ|I2C_A_ADC_LAST|I2C_A_ADC_START|I2C_A_ADC_ADD_MASK);
 423		tmp = 0;
 424		tmp = tmp | (I2C_A_ADC_LAST|I2C_A_ADC_START|I2C_A_ADC_ADD);
 425		snd_ca0106_ptr_write(emu, I2C_A, 0, tmp);
 426
 427		/* Wait till the transaction ends */
 428		while (1) {
 429			status = snd_ca0106_ptr_read(emu, I2C_A, 0);
 430			/*dev_dbg(emu->card->dev, "I2C:status=0x%x\n", status);*/
 431			timeout++;
 432			if ((status & I2C_A_ADC_START) == 0)
 433				break;
 434
 435			if (timeout > 1000)
 436				break;
 437		}
 438		//Read back and see if the transaction is successful
 439		if ((status & I2C_A_ADC_ABORT) == 0)
 440			break;
 441	}
 442
 443	if (retry == 10) {
 444		dev_err(emu->card->dev, "Writing to ADC failed!\n");
 445		return -EINVAL;
 446	}
 447    
 448    	return 0;
 449}
 450
 451
 452static void snd_ca0106_intr_enable(struct snd_ca0106 *emu, unsigned int intrenb)
 453{
 454	unsigned long flags;
 455	unsigned int intr_enable;
 456
 457	spin_lock_irqsave(&emu->emu_lock, flags);
 458	intr_enable = inl(emu->port + CA0106_INTE) | intrenb;
 459	outl(intr_enable, emu->port + CA0106_INTE);
 460	spin_unlock_irqrestore(&emu->emu_lock, flags);
 461}
 462
 463static void snd_ca0106_intr_disable(struct snd_ca0106 *emu, unsigned int intrenb)
 464{
 465	unsigned long flags;
 466	unsigned int intr_enable;
 467
 468	spin_lock_irqsave(&emu->emu_lock, flags);
 469	intr_enable = inl(emu->port + CA0106_INTE) & ~intrenb;
 470	outl(intr_enable, emu->port + CA0106_INTE);
 471	spin_unlock_irqrestore(&emu->emu_lock, flags);
 472}
 473
 474
 475static void snd_ca0106_pcm_free_substream(struct snd_pcm_runtime *runtime)
 476{
 477	kfree(runtime->private_data);
 478}
 479
 480static const int spi_dacd_reg[] = {
 481	SPI_DACD0_REG,
 482	SPI_DACD1_REG,
 483	SPI_DACD2_REG,
 484	0,
 485	SPI_DACD4_REG,
 486};
 487static const int spi_dacd_bit[] = {
 488	SPI_DACD0_BIT,
 489	SPI_DACD1_BIT,
 490	SPI_DACD2_BIT,
 491	0,
 492	SPI_DACD4_BIT,
 493};
 494
 495static void restore_spdif_bits(struct snd_ca0106 *chip, int idx)
 496{
 497	if (chip->spdif_str_bits[idx] != chip->spdif_bits[idx]) {
 498		chip->spdif_str_bits[idx] = chip->spdif_bits[idx];
 499		snd_ca0106_ptr_write(chip, SPCS0 + idx, 0,
 500				     chip->spdif_str_bits[idx]);
 501	}
 502}
 503
 504static int snd_ca0106_channel_dac(struct snd_ca0106 *chip,
 505				  const struct snd_ca0106_details *details,
 506				  int channel_id)
 507{
 508	switch (channel_id) {
 509	case PCM_FRONT_CHANNEL:
 510		return (details->spi_dac & 0xf000) >> (4 * 3);
 511	case PCM_REAR_CHANNEL:
 512		return (details->spi_dac & 0x0f00) >> (4 * 2);
 513	case PCM_CENTER_LFE_CHANNEL:
 514		return (details->spi_dac & 0x00f0) >> (4 * 1);
 515	case PCM_UNKNOWN_CHANNEL:
 516		return (details->spi_dac & 0x000f) >> (4 * 0);
 517	default:
 518		dev_dbg(chip->card->dev, "ca0106: unknown channel_id %d\n",
 519			   channel_id);
 520	}
 521	return 0;
 522}
 523
 524static int snd_ca0106_pcm_power_dac(struct snd_ca0106 *chip, int channel_id,
 525				    int power)
 526{
 527	if (chip->details->spi_dac) {
 528		const int dac = snd_ca0106_channel_dac(chip, chip->details,
 529						       channel_id);
 530		const int reg = spi_dacd_reg[dac];
 531		const int bit = spi_dacd_bit[dac];
 532
 533		if (power)
 534			/* Power up */
 535			chip->spi_dac_reg[reg] &= ~bit;
 536		else
 537			/* Power down */
 538			chip->spi_dac_reg[reg] |= bit;
 539		if (snd_ca0106_spi_write(chip, chip->spi_dac_reg[reg]) != 0)
 540			return -ENXIO;
 541	}
 542	return 0;
 543}
 544
 545/* open_playback callback */
 546static int snd_ca0106_pcm_open_playback_channel(struct snd_pcm_substream *substream,
 547						int channel_id)
 548{
 549	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 550        struct snd_ca0106_channel *channel = &(chip->playback_channels[channel_id]);
 551	struct snd_ca0106_pcm *epcm;
 552	struct snd_pcm_runtime *runtime = substream->runtime;
 553	int err;
 554
 555	epcm = kzalloc(sizeof(*epcm), GFP_KERNEL);
 556
 557	if (epcm == NULL)
 558		return -ENOMEM;
 559	epcm->emu = chip;
 560	epcm->substream = substream;
 561        epcm->channel_id=channel_id;
 562  
 563	runtime->private_data = epcm;
 564	runtime->private_free = snd_ca0106_pcm_free_substream;
 565  
 566	runtime->hw = snd_ca0106_playback_hw;
 567
 568        channel->emu = chip;
 569        channel->number = channel_id;
 570
 571	channel->use = 1;
 572	/*
 573	dev_dbg(chip->card->dev, "open:channel_id=%d, chip=%p, channel=%p\n",
 574	       channel_id, chip, channel);
 575	*/
 576        //channel->interrupt = snd_ca0106_pcm_channel_interrupt;
 577	channel->epcm = epcm;
 578	err = snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS);
 579	if (err < 0)
 580                return err;
 581	err = snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES, 64);
 582	if (err < 0)
 583                return err;
 584	snd_pcm_set_sync(substream);
 585
 586	/* Front channel dac should already be on */
 587	if (channel_id != PCM_FRONT_CHANNEL) {
 588		err = snd_ca0106_pcm_power_dac(chip, channel_id, 1);
 589		if (err < 0)
 590			return err;
 591	}
 592
 593	restore_spdif_bits(chip, channel_id);
 594
 595	return 0;
 596}
 597
 598/* close callback */
 599static int snd_ca0106_pcm_close_playback(struct snd_pcm_substream *substream)
 600{
 601	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 602	struct snd_pcm_runtime *runtime = substream->runtime;
 603        struct snd_ca0106_pcm *epcm = runtime->private_data;
 604	chip->playback_channels[epcm->channel_id].use = 0;
 605
 606	restore_spdif_bits(chip, epcm->channel_id);
 607
 608	/* Front channel dac should stay on */
 609	if (epcm->channel_id != PCM_FRONT_CHANNEL) {
 610		int err;
 611		err = snd_ca0106_pcm_power_dac(chip, epcm->channel_id, 0);
 612		if (err < 0)
 613			return err;
 614	}
 615
 616	/* FIXME: maybe zero others */
 617	return 0;
 618}
 619
 620static int snd_ca0106_pcm_open_playback_front(struct snd_pcm_substream *substream)
 621{
 622	return snd_ca0106_pcm_open_playback_channel(substream, PCM_FRONT_CHANNEL);
 623}
 624
 625static int snd_ca0106_pcm_open_playback_center_lfe(struct snd_pcm_substream *substream)
 626{
 627	return snd_ca0106_pcm_open_playback_channel(substream, PCM_CENTER_LFE_CHANNEL);
 628}
 629
 630static int snd_ca0106_pcm_open_playback_unknown(struct snd_pcm_substream *substream)
 631{
 632	return snd_ca0106_pcm_open_playback_channel(substream, PCM_UNKNOWN_CHANNEL);
 633}
 634
 635static int snd_ca0106_pcm_open_playback_rear(struct snd_pcm_substream *substream)
 636{
 637	return snd_ca0106_pcm_open_playback_channel(substream, PCM_REAR_CHANNEL);
 638}
 639
 640/* open_capture callback */
 641static int snd_ca0106_pcm_open_capture_channel(struct snd_pcm_substream *substream,
 642					       int channel_id)
 643{
 644	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 645        struct snd_ca0106_channel *channel = &(chip->capture_channels[channel_id]);
 646	struct snd_ca0106_pcm *epcm;
 647	struct snd_pcm_runtime *runtime = substream->runtime;
 648	int err;
 649
 650	epcm = kzalloc(sizeof(*epcm), GFP_KERNEL);
 651	if (!epcm)
 652		return -ENOMEM;
 653
 654	epcm->emu = chip;
 655	epcm->substream = substream;
 656        epcm->channel_id=channel_id;
 657  
 658	runtime->private_data = epcm;
 659	runtime->private_free = snd_ca0106_pcm_free_substream;
 660  
 661	runtime->hw = snd_ca0106_capture_hw;
 662
 663        channel->emu = chip;
 664        channel->number = channel_id;
 665
 666	channel->use = 1;
 667	/*
 668	dev_dbg(chip->card->dev, "open:channel_id=%d, chip=%p, channel=%p\n",
 669	       channel_id, chip, channel);
 670	*/
 671        //channel->interrupt = snd_ca0106_pcm_channel_interrupt;
 672        channel->epcm = epcm;
 673	err = snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS);
 674	if (err < 0)
 675                return err;
 676	//snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_SIZE, &hw_constraints_capture_period_sizes);
 677	err = snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES, 64);
 678	if (err < 0)
 679                return err;
 680	return 0;
 681}
 682
 683/* close callback */
 684static int snd_ca0106_pcm_close_capture(struct snd_pcm_substream *substream)
 685{
 686	struct snd_ca0106 *chip = snd_pcm_substream_chip(substream);
 687	struct snd_pcm_runtime *runtime = substream->runtime;
 688        struct snd_ca0106_pcm *epcm = runtime->private_data;
 689	chip->capture_channels[epcm->channel_id].use = 0;
 690	/* FIXME: maybe zero others */
 691	return 0;
 692}
 693
 694static int snd_ca0106_pcm_open_0_capture(struct snd_pcm_substream *substream)
 695{
 696	return snd_ca0106_pcm_open_capture_channel(substream, 0);
 697}
 698
 699static int snd_ca0106_pcm_open_1_capture(struct snd_pcm_substream *substream)
 700{
 701	return snd_ca0106_pcm_open_capture_channel(substream, 1);
 702}
 703
 704static int snd_ca0106_pcm_open_2_capture(struct snd_pcm_substream *substream)
 705{
 706	return snd_ca0106_pcm_open_capture_channel(substream, 2);
 707}
 708
 709static int snd_ca0106_pcm_open_3_capture(struct snd_pcm_substream *substream)
 710{
 711	return snd_ca0106_pcm_open_capture_channel(substream, 3);
 712}
 713
 714/* prepare playback callback */
 715static int snd_ca0106_pcm_prepare_playback(struct snd_pcm_substream *substream)
 716{
 717	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 718	struct snd_pcm_runtime *runtime = substream->runtime;
 719	struct snd_ca0106_pcm *epcm = runtime->private_data;
 720	int channel = epcm->channel_id;
 721	u32 *table_base = (u32 *)(emu->buffer->area+(8*16*channel));
 722	u32 period_size_bytes = frames_to_bytes(runtime, runtime->period_size);
 723	u32 hcfg_mask = HCFG_PLAYBACK_S32_LE;
 724	u32 hcfg_set = 0x00000000;
 725	u32 hcfg;
 726	u32 reg40_mask = 0x30000 << (channel<<1);
 727	u32 reg40_set = 0;
 728	u32 reg40;
 729	/* FIXME: Depending on mixer selection of SPDIF out or not, select the spdif rate or the DAC rate. */
 730	u32 reg71_mask = 0x03030000 ; /* Global. Set SPDIF rate. We only support 44100 to spdif, not to DAC. */
 731	u32 reg71_set = 0;
 732	u32 reg71;
 733	int i;
 734	
 735#if 0 /* debug */
 736	dev_dbg(emu->card->dev,
 737		   "prepare:channel_number=%d, rate=%d, format=0x%x, "
 738		   "channels=%d, buffer_size=%ld, period_size=%ld, "
 739		   "periods=%u, frames_to_bytes=%d\n",
 740		   channel, runtime->rate, runtime->format,
 741		   runtime->channels, runtime->buffer_size,
 742		   runtime->period_size, runtime->periods,
 743		   frames_to_bytes(runtime, 1));
 744	dev_dbg(emu->card->dev,
 745		"dma_addr=%x, dma_area=%p, table_base=%p\n",
 746		   runtime->dma_addr, runtime->dma_area, table_base);
 747	dev_dbg(emu->card->dev,
 748		"dma_addr=%x, dma_area=%p, dma_bytes(size)=%x\n",
 749		   emu->buffer->addr, emu->buffer->area, emu->buffer->bytes);
 750#endif /* debug */
 751	/* Rate can be set per channel. */
 752	/* reg40 control host to fifo */
 753	/* reg71 controls DAC rate. */
 754	switch (runtime->rate) {
 755	case 44100:
 756		reg40_set = 0x10000 << (channel<<1);
 757		reg71_set = 0x01010000; 
 758		break;
 759        case 48000:
 760		reg40_set = 0;
 761		reg71_set = 0; 
 762		break;
 763	case 96000:
 764		reg40_set = 0x20000 << (channel<<1);
 765		reg71_set = 0x02020000; 
 766		break;
 767	case 192000:
 768		reg40_set = 0x30000 << (channel<<1);
 769		reg71_set = 0x03030000; 
 770		break;
 771	default:
 772		reg40_set = 0;
 773		reg71_set = 0; 
 774		break;
 775	}
 776	/* Format is a global setting */
 777	/* FIXME: Only let the first channel accessed set this. */
 778	switch (runtime->format) {
 779	case SNDRV_PCM_FORMAT_S16_LE:
 780		hcfg_set = 0;
 781		break;
 782	case SNDRV_PCM_FORMAT_S32_LE:
 783		hcfg_set = HCFG_PLAYBACK_S32_LE;
 784		break;
 785	default:
 786		hcfg_set = 0;
 787		break;
 788	}
 789	hcfg = inl(emu->port + CA0106_HCFG) ;
 790	hcfg = (hcfg & ~hcfg_mask) | hcfg_set;
 791	outl(hcfg, emu->port + CA0106_HCFG);
 792	reg40 = snd_ca0106_ptr_read(emu, 0x40, 0);
 793	reg40 = (reg40 & ~reg40_mask) | reg40_set;
 794	snd_ca0106_ptr_write(emu, 0x40, 0, reg40);
 795	reg71 = snd_ca0106_ptr_read(emu, 0x71, 0);
 796	reg71 = (reg71 & ~reg71_mask) | reg71_set;
 797	snd_ca0106_ptr_write(emu, 0x71, 0, reg71);
 798
 799	/* FIXME: Check emu->buffer->size before actually writing to it. */
 800        for(i=0; i < runtime->periods; i++) {
 801		table_base[i*2] = runtime->dma_addr + (i * period_size_bytes);
 802		table_base[i*2+1] = period_size_bytes << 16;
 803	}
 804 
 805	snd_ca0106_ptr_write(emu, PLAYBACK_LIST_ADDR, channel, emu->buffer->addr+(8*16*channel));
 806	snd_ca0106_ptr_write(emu, PLAYBACK_LIST_SIZE, channel, (runtime->periods - 1) << 19);
 807	snd_ca0106_ptr_write(emu, PLAYBACK_LIST_PTR, channel, 0);
 808	snd_ca0106_ptr_write(emu, PLAYBACK_DMA_ADDR, channel, runtime->dma_addr);
 809	snd_ca0106_ptr_write(emu, PLAYBACK_PERIOD_SIZE, channel, frames_to_bytes(runtime, runtime->period_size)<<16); // buffer size in bytes
 810	/* FIXME  test what 0 bytes does. */
 811	snd_ca0106_ptr_write(emu, PLAYBACK_PERIOD_SIZE, channel, 0); // buffer size in bytes
 812	snd_ca0106_ptr_write(emu, PLAYBACK_POINTER, channel, 0);
 813	snd_ca0106_ptr_write(emu, 0x07, channel, 0x0);
 814	snd_ca0106_ptr_write(emu, 0x08, channel, 0);
 815        snd_ca0106_ptr_write(emu, PLAYBACK_MUTE, 0x0, 0x0); /* Unmute output */
 816#if 0
 817	snd_ca0106_ptr_write(emu, SPCS0, 0,
 818			       SPCS_CLKACCY_1000PPM | SPCS_SAMPLERATE_48 |
 819			       SPCS_CHANNELNUM_LEFT | SPCS_SOURCENUM_UNSPEC |
 820			       SPCS_GENERATIONSTATUS | 0x00001200 |
 821			       0x00000000 | SPCS_EMPHASIS_NONE | SPCS_COPYRIGHT );
 822#endif
 823
 824	return 0;
 825}
 826
 827/* prepare capture callback */
 828static int snd_ca0106_pcm_prepare_capture(struct snd_pcm_substream *substream)
 829{
 830	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 831	struct snd_pcm_runtime *runtime = substream->runtime;
 832	struct snd_ca0106_pcm *epcm = runtime->private_data;
 833	int channel = epcm->channel_id;
 834	u32 hcfg_mask = HCFG_CAPTURE_S32_LE;
 835	u32 hcfg_set = 0x00000000;
 836	u32 hcfg;
 837	u32 over_sampling=0x2;
 838	u32 reg71_mask = 0x0000c000 ; /* Global. Set ADC rate. */
 839	u32 reg71_set = 0;
 840	u32 reg71;
 841	
 842#if 0 /* debug */
 843	dev_dbg(emu->card->dev,
 844		   "prepare:channel_number=%d, rate=%d, format=0x%x, "
 845		   "channels=%d, buffer_size=%ld, period_size=%ld, "
 846		   "periods=%u, frames_to_bytes=%d\n",
 847		   channel, runtime->rate, runtime->format,
 848		   runtime->channels, runtime->buffer_size,
 849		   runtime->period_size, runtime->periods,
 850		   frames_to_bytes(runtime, 1));
 851	dev_dbg(emu->card->dev,
 852		"dma_addr=%x, dma_area=%p, table_base=%p\n",
 853		   runtime->dma_addr, runtime->dma_area, table_base);
 854	dev_dbg(emu->card->dev,
 855		"dma_addr=%x, dma_area=%p, dma_bytes(size)=%x\n",
 856		   emu->buffer->addr, emu->buffer->area, emu->buffer->bytes);
 857#endif /* debug */
 858	/* reg71 controls ADC rate. */
 859	switch (runtime->rate) {
 860	case 44100:
 861		reg71_set = 0x00004000;
 862		break;
 863        case 48000:
 864		reg71_set = 0; 
 865		break;
 866	case 96000:
 867		reg71_set = 0x00008000;
 868		over_sampling=0xa;
 869		break;
 870	case 192000:
 871		reg71_set = 0x0000c000; 
 872		over_sampling=0xa;
 873		break;
 874	default:
 875		reg71_set = 0; 
 876		break;
 877	}
 878	/* Format is a global setting */
 879	/* FIXME: Only let the first channel accessed set this. */
 880	switch (runtime->format) {
 881	case SNDRV_PCM_FORMAT_S16_LE:
 882		hcfg_set = 0;
 883		break;
 884	case SNDRV_PCM_FORMAT_S32_LE:
 885		hcfg_set = HCFG_CAPTURE_S32_LE;
 886		break;
 887	default:
 888		hcfg_set = 0;
 889		break;
 890	}
 891	hcfg = inl(emu->port + CA0106_HCFG) ;
 892	hcfg = (hcfg & ~hcfg_mask) | hcfg_set;
 893	outl(hcfg, emu->port + CA0106_HCFG);
 894	reg71 = snd_ca0106_ptr_read(emu, 0x71, 0);
 895	reg71 = (reg71 & ~reg71_mask) | reg71_set;
 896	snd_ca0106_ptr_write(emu, 0x71, 0, reg71);
 897        if (emu->details->i2c_adc == 1) { /* The SB0410 and SB0413 use I2C to control ADC. */
 898	        snd_ca0106_i2c_write(emu, ADC_MASTER, over_sampling); /* Adjust the over sampler to better suit the capture rate. */
 899	}
 900
 901
 902	/*
 903	dev_dbg(emu->card->dev,
 904	       "prepare:channel_number=%d, rate=%d, format=0x%x, channels=%d, "
 905	       "buffer_size=%ld, period_size=%ld, frames_to_bytes=%d\n",
 906	       channel, runtime->rate, runtime->format, runtime->channels,
 907	       runtime->buffer_size, runtime->period_size,
 908	       frames_to_bytes(runtime, 1));
 909	*/
 910	snd_ca0106_ptr_write(emu, 0x13, channel, 0);
 911	snd_ca0106_ptr_write(emu, CAPTURE_DMA_ADDR, channel, runtime->dma_addr);
 912	snd_ca0106_ptr_write(emu, CAPTURE_BUFFER_SIZE, channel, frames_to_bytes(runtime, runtime->buffer_size)<<16); // buffer size in bytes
 913	snd_ca0106_ptr_write(emu, CAPTURE_POINTER, channel, 0);
 914
 915	return 0;
 916}
 917
 918/* trigger_playback callback */
 919static int snd_ca0106_pcm_trigger_playback(struct snd_pcm_substream *substream,
 920				    int cmd)
 921{
 922	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 923	struct snd_pcm_runtime *runtime;
 924	struct snd_ca0106_pcm *epcm;
 925	int channel;
 926	int result = 0;
 927        struct snd_pcm_substream *s;
 928	u32 basic = 0;
 929	u32 extended = 0;
 930	u32 bits;
 931	int running = 0;
 932
 933	switch (cmd) {
 934	case SNDRV_PCM_TRIGGER_START:
 935	case SNDRV_PCM_TRIGGER_RESUME:
 936		running = 1;
 937		break;
 938	case SNDRV_PCM_TRIGGER_STOP:
 939	case SNDRV_PCM_TRIGGER_SUSPEND:
 940	default:
 941		running = 0;
 942		break;
 943	}
 944        snd_pcm_group_for_each_entry(s, substream) {
 945		if (snd_pcm_substream_chip(s) != emu ||
 946		    s->stream != SNDRV_PCM_STREAM_PLAYBACK)
 947			continue;
 948		runtime = s->runtime;
 949		epcm = runtime->private_data;
 950		channel = epcm->channel_id;
 951		/* dev_dbg(emu->card->dev, "channel=%d\n", channel); */
 952		epcm->running = running;
 953		basic |= (0x1 << channel);
 954		extended |= (0x10 << channel);
 955                snd_pcm_trigger_done(s, substream);
 956        }
 957	/* dev_dbg(emu->card->dev, "basic=0x%x, extended=0x%x\n",basic, extended); */
 958
 959	switch (cmd) {
 960	case SNDRV_PCM_TRIGGER_START:
 961	case SNDRV_PCM_TRIGGER_RESUME:
 962		bits = snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0);
 963		bits |= extended;
 964		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, bits);
 965		bits = snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0);
 966		bits |= basic;
 967		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, bits);
 968		break;
 969	case SNDRV_PCM_TRIGGER_STOP:
 970	case SNDRV_PCM_TRIGGER_SUSPEND:
 971		bits = snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0);
 972		bits &= ~basic;
 973		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, bits);
 974		bits = snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0);
 975		bits &= ~extended;
 976		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, bits);
 977		break;
 978	default:
 979		result = -EINVAL;
 980		break;
 981	}
 982	return result;
 983}
 984
 985/* trigger_capture callback */
 986static int snd_ca0106_pcm_trigger_capture(struct snd_pcm_substream *substream,
 987				    int cmd)
 988{
 989	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
 990	struct snd_pcm_runtime *runtime = substream->runtime;
 991	struct snd_ca0106_pcm *epcm = runtime->private_data;
 992	int channel = epcm->channel_id;
 993	int result = 0;
 994
 995	switch (cmd) {
 996	case SNDRV_PCM_TRIGGER_START:
 997		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0) | (0x110000<<channel));
 998		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0)|(0x100<<channel));
 999		epcm->running = 1;
1000		break;
1001	case SNDRV_PCM_TRIGGER_STOP:
1002		snd_ca0106_ptr_write(emu, BASIC_INTERRUPT, 0, snd_ca0106_ptr_read(emu, BASIC_INTERRUPT, 0) & ~(0x100<<channel));
1003		snd_ca0106_ptr_write(emu, EXTENDED_INT_MASK, 0, snd_ca0106_ptr_read(emu, EXTENDED_INT_MASK, 0) & ~(0x110000<<channel));
1004		epcm->running = 0;
1005		break;
1006	default:
1007		result = -EINVAL;
1008		break;
1009	}
1010	return result;
1011}
1012
1013/* pointer_playback callback */
1014static snd_pcm_uframes_t
1015snd_ca0106_pcm_pointer_playback(struct snd_pcm_substream *substream)
1016{
1017	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
1018	struct snd_pcm_runtime *runtime = substream->runtime;
1019	struct snd_ca0106_pcm *epcm = runtime->private_data;
1020	unsigned int ptr, prev_ptr;
1021	int channel = epcm->channel_id;
1022	int timeout = 10;
1023
1024	if (!epcm->running)
1025		return 0;
1026
1027	prev_ptr = -1;
1028	do {
1029		ptr = snd_ca0106_ptr_read(emu, PLAYBACK_LIST_PTR, channel);
1030		ptr = (ptr >> 3) * runtime->period_size;
1031		ptr += bytes_to_frames(runtime,
1032			snd_ca0106_ptr_read(emu, PLAYBACK_POINTER, channel));
1033		if (ptr >= runtime->buffer_size)
1034			ptr -= runtime->buffer_size;
1035		if (prev_ptr == ptr)
1036			return ptr;
1037		prev_ptr = ptr;
1038	} while (--timeout);
1039	dev_warn(emu->card->dev, "ca0106: unstable DMA pointer!\n");
1040	return 0;
1041}
1042
1043/* pointer_capture callback */
1044static snd_pcm_uframes_t
1045snd_ca0106_pcm_pointer_capture(struct snd_pcm_substream *substream)
1046{
1047	struct snd_ca0106 *emu = snd_pcm_substream_chip(substream);
1048	struct snd_pcm_runtime *runtime = substream->runtime;
1049	struct snd_ca0106_pcm *epcm = runtime->private_data;
1050	snd_pcm_uframes_t ptr, ptr1, ptr2 = 0;
1051	int channel = epcm->channel_id;
1052
1053	if (!epcm->running)
1054		return 0;
1055
1056	ptr1 = snd_ca0106_ptr_read(emu, CAPTURE_POINTER, channel);
1057	ptr2 = bytes_to_frames(runtime, ptr1);
1058	ptr=ptr2;
1059        if (ptr >= runtime->buffer_size)
1060		ptr -= runtime->buffer_size;
1061	/*
1062	dev_dbg(emu->card->dev, "ptr1 = 0x%lx, ptr2=0x%lx, ptr=0x%lx, "
1063	       "buffer_size = 0x%x, period_size = 0x%x, bits=%d, rate=%d\n",
1064	       ptr1, ptr2, ptr, (int)runtime->buffer_size,
1065	       (int)runtime->period_size, (int)runtime->frame_bits,
1066	       (int)runtime->rate);
1067	*/
1068	return ptr;
1069}
1070
1071/* operators */
1072static const struct snd_pcm_ops snd_ca0106_playback_front_ops = {
1073	.open =        snd_ca0106_pcm_open_playback_front,
1074	.close =       snd_ca0106_pcm_close_playback,
1075	.prepare =     snd_ca0106_pcm_prepare_playback,
1076	.trigger =     snd_ca0106_pcm_trigger_playback,
1077	.pointer =     snd_ca0106_pcm_pointer_playback,
1078};
1079
1080static const struct snd_pcm_ops snd_ca0106_capture_0_ops = {
1081	.open =        snd_ca0106_pcm_open_0_capture,
1082	.close =       snd_ca0106_pcm_close_capture,
1083	.prepare =     snd_ca0106_pcm_prepare_capture,
1084	.trigger =     snd_ca0106_pcm_trigger_capture,
1085	.pointer =     snd_ca0106_pcm_pointer_capture,
1086};
1087
1088static const struct snd_pcm_ops snd_ca0106_capture_1_ops = {
1089	.open =        snd_ca0106_pcm_open_1_capture,
1090	.close =       snd_ca0106_pcm_close_capture,
1091	.prepare =     snd_ca0106_pcm_prepare_capture,
1092	.trigger =     snd_ca0106_pcm_trigger_capture,
1093	.pointer =     snd_ca0106_pcm_pointer_capture,
1094};
1095
1096static const struct snd_pcm_ops snd_ca0106_capture_2_ops = {
1097	.open =        snd_ca0106_pcm_open_2_capture,
1098	.close =       snd_ca0106_pcm_close_capture,
1099	.prepare =     snd_ca0106_pcm_prepare_capture,
1100	.trigger =     snd_ca0106_pcm_trigger_capture,
1101	.pointer =     snd_ca0106_pcm_pointer_capture,
1102};
1103
1104static const struct snd_pcm_ops snd_ca0106_capture_3_ops = {
1105	.open =        snd_ca0106_pcm_open_3_capture,
1106	.close =       snd_ca0106_pcm_close_capture,
1107	.prepare =     snd_ca0106_pcm_prepare_capture,
1108	.trigger =     snd_ca0106_pcm_trigger_capture,
1109	.pointer =     snd_ca0106_pcm_pointer_capture,
1110};
1111
1112static const struct snd_pcm_ops snd_ca0106_playback_center_lfe_ops = {
1113        .open =         snd_ca0106_pcm_open_playback_center_lfe,
1114        .close =        snd_ca0106_pcm_close_playback,
1115        .prepare =      snd_ca0106_pcm_prepare_playback,     
1116        .trigger =      snd_ca0106_pcm_trigger_playback,  
1117        .pointer =      snd_ca0106_pcm_pointer_playback, 
1118};
1119
1120static const struct snd_pcm_ops snd_ca0106_playback_unknown_ops = {
1121        .open =         snd_ca0106_pcm_open_playback_unknown,
1122        .close =        snd_ca0106_pcm_close_playback,
1123        .prepare =      snd_ca0106_pcm_prepare_playback,     
1124        .trigger =      snd_ca0106_pcm_trigger_playback,  
1125        .pointer =      snd_ca0106_pcm_pointer_playback, 
1126};
1127
1128static const struct snd_pcm_ops snd_ca0106_playback_rear_ops = {
1129        .open =         snd_ca0106_pcm_open_playback_rear,
1130        .close =        snd_ca0106_pcm_close_playback,
1131        .prepare =      snd_ca0106_pcm_prepare_playback,     
1132        .trigger =      snd_ca0106_pcm_trigger_playback,  
1133        .pointer =      snd_ca0106_pcm_pointer_playback, 
1134};
1135
1136
1137static unsigned short snd_ca0106_ac97_read(struct snd_ac97 *ac97,
1138					     unsigned short reg)
1139{
1140	struct snd_ca0106 *emu = ac97->private_data;
1141	unsigned long flags;
1142	unsigned short val;
1143
1144	spin_lock_irqsave(&emu->emu_lock, flags);
1145	outb(reg, emu->port + CA0106_AC97ADDRESS);
1146	val = inw(emu->port + CA0106_AC97DATA);
1147	spin_unlock_irqrestore(&emu->emu_lock, flags);
1148	return val;
1149}
1150
1151static void snd_ca0106_ac97_write(struct snd_ac97 *ac97,
1152				    unsigned short reg, unsigned short val)
1153{
1154	struct snd_ca0106 *emu = ac97->private_data;
1155	unsigned long flags;
1156  
1157	spin_lock_irqsave(&emu->emu_lock, flags);
1158	outb(reg, emu->port + CA0106_AC97ADDRESS);
1159	outw(val, emu->port + CA0106_AC97DATA);
1160	spin_unlock_irqrestore(&emu->emu_lock, flags);
1161}
1162
1163static int snd_ca0106_ac97(struct snd_ca0106 *chip)
1164{
1165	struct snd_ac97_bus *pbus;
1166	struct snd_ac97_template ac97;
1167	int err;
1168	static const struct snd_ac97_bus_ops ops = {
1169		.write = snd_ca0106_ac97_write,
1170		.read = snd_ca0106_ac97_read,
1171	};
1172  
1173	err = snd_ac97_bus(chip->card, 0, &ops, NULL, &pbus);
1174	if (err < 0)
1175		return err;
1176	pbus->no_vra = 1; /* we don't need VRA */
1177
1178	memset(&ac97, 0, sizeof(ac97));
1179	ac97.private_data = chip;
1180	ac97.scaps = AC97_SCAP_NO_SPDIF;
1181	return snd_ac97_mixer(pbus, &ac97, &chip->ac97);
1182}
1183
1184static void ca0106_stop_chip(struct snd_ca0106 *chip);
1185
1186static void snd_ca0106_free(struct snd_card *card)
1187{
1188	struct snd_ca0106 *chip = card->private_data;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1189
1190	ca0106_stop_chip(chip);
 
 
 
1191}
1192
1193static irqreturn_t snd_ca0106_interrupt(int irq, void *dev_id)
1194{
1195	unsigned int status;
1196
1197	struct snd_ca0106 *chip = dev_id;
1198	int i;
1199	int mask;
1200        unsigned int stat76;
1201	struct snd_ca0106_channel *pchannel;
1202
1203	status = inl(chip->port + CA0106_IPR);
1204	if (! status)
1205		return IRQ_NONE;
1206
1207        stat76 = snd_ca0106_ptr_read(chip, EXTENDED_INT, 0);
1208	/*
1209	dev_dbg(emu->card->dev, "interrupt status = 0x%08x, stat76=0x%08x\n",
1210		   status, stat76);
1211	dev_dbg(emu->card->dev, "ptr=0x%08x\n",
1212		   snd_ca0106_ptr_read(chip, PLAYBACK_POINTER, 0));
1213	*/
1214        mask = 0x11; /* 0x1 for one half, 0x10 for the other half period. */
1215	for(i = 0; i < 4; i++) {
1216		pchannel = &(chip->playback_channels[i]);
1217		if (stat76 & mask) {
1218/* FIXME: Select the correct substream for period elapsed */
1219			if(pchannel->use) {
1220				snd_pcm_period_elapsed(pchannel->epcm->substream);
1221				/* dev_dbg(emu->card->dev, "interrupt [%d] used\n", i); */
1222                        }
1223		}
1224		/*
1225		dev_dbg(emu->card->dev, "channel=%p\n", pchannel);
1226		dev_dbg(emu->card->dev, "interrupt stat76[%d] = %08x, use=%d, channel=%d\n", i, stat76, pchannel->use, pchannel->number);
1227		*/
1228		mask <<= 1;
1229	}
1230        mask = 0x110000; /* 0x1 for one half, 0x10 for the other half period. */
1231	for(i = 0; i < 4; i++) {
1232		pchannel = &(chip->capture_channels[i]);
1233		if (stat76 & mask) {
1234/* FIXME: Select the correct substream for period elapsed */
1235			if(pchannel->use) {
1236				snd_pcm_period_elapsed(pchannel->epcm->substream);
1237				/* dev_dbg(emu->card->dev, "interrupt [%d] used\n", i); */
1238                        }
1239		}
1240		/*
1241		dev_dbg(emu->card->dev, "channel=%p\n", pchannel);
1242		dev_dbg(emu->card->dev, "interrupt stat76[%d] = %08x, use=%d, channel=%d\n", i, stat76, pchannel->use, pchannel->number);
1243		*/
1244		mask <<= 1;
1245	}
1246
1247        snd_ca0106_ptr_write(chip, EXTENDED_INT, 0, stat76);
1248
1249	if (chip->midi.dev_id &&
1250	    (status & (chip->midi.ipr_tx|chip->midi.ipr_rx))) {
1251		if (chip->midi.interrupt)
1252			chip->midi.interrupt(&chip->midi, status);
1253		else
1254			chip->midi.interrupt_disable(&chip->midi, chip->midi.tx_enable | chip->midi.rx_enable);
1255	}
1256
1257	// acknowledge the interrupt if necessary
1258	outl(status, chip->port + CA0106_IPR);
1259
1260	return IRQ_HANDLED;
1261}
1262
1263static const struct snd_pcm_chmap_elem surround_map[] = {
1264	{ .channels = 2,
1265	  .map = { SNDRV_CHMAP_RL, SNDRV_CHMAP_RR } },
1266	{ }
1267};
1268
1269static const struct snd_pcm_chmap_elem clfe_map[] = {
1270	{ .channels = 2,
1271	  .map = { SNDRV_CHMAP_FC, SNDRV_CHMAP_LFE } },
1272	{ }
1273};
1274
1275static const struct snd_pcm_chmap_elem side_map[] = {
1276	{ .channels = 2,
1277	  .map = { SNDRV_CHMAP_SL, SNDRV_CHMAP_SR } },
1278	{ }
1279};
1280
1281static int snd_ca0106_pcm(struct snd_ca0106 *emu, int device)
1282{
1283	struct snd_pcm *pcm;
1284	struct snd_pcm_substream *substream;
1285	const struct snd_pcm_chmap_elem *map = NULL;
1286	int err;
1287  
1288	err = snd_pcm_new(emu->card, "ca0106", device, 1, 1, &pcm);
1289	if (err < 0)
1290		return err;
1291  
1292	pcm->private_data = emu;
1293
1294	switch (device) {
1295	case 0:
1296	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_front_ops);
1297	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_0_ops);
1298	  map = snd_pcm_std_chmaps;
1299          break;
1300	case 1:
1301	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_rear_ops);
1302	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_1_ops);
1303	  map = surround_map;
1304          break;
1305	case 2:
1306	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_center_lfe_ops);
1307	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_2_ops);
1308	  map = clfe_map;
1309          break;
1310	case 3:
1311	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_ca0106_playback_unknown_ops);
1312	  snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_ca0106_capture_3_ops);
1313	  map = side_map;
1314          break;
1315        }
1316
1317	pcm->info_flags = 0;
1318	strcpy(pcm->name, "CA0106");
1319
1320	for(substream = pcm->streams[SNDRV_PCM_STREAM_PLAYBACK].substream; 
1321	    substream; 
1322	    substream = substream->next) {
1323		snd_pcm_set_managed_buffer(substream, SNDRV_DMA_TYPE_DEV,
1324					   &emu->pci->dev,
1325					   64*1024, 64*1024);
1326	}
1327
1328	for (substream = pcm->streams[SNDRV_PCM_STREAM_CAPTURE].substream; 
1329	      substream; 
1330	      substream = substream->next) {
1331		snd_pcm_set_managed_buffer(substream, SNDRV_DMA_TYPE_DEV,
1332					   &emu->pci->dev,
1333					   64*1024, 64*1024);
1334	}
1335  
1336	err = snd_pcm_add_chmap_ctls(pcm, SNDRV_PCM_STREAM_PLAYBACK, map, 2,
1337				     1 << 2, NULL);
1338	if (err < 0)
1339		return err;
1340
1341	emu->pcm[device] = pcm;
1342  
1343	return 0;
1344}
1345
1346#define SPI_REG(reg, value)	(((reg) << SPI_REG_SHIFT) | (value))
1347static const unsigned int spi_dac_init[] = {
1348	SPI_REG(SPI_LDA1_REG,	SPI_DA_BIT_0dB), /* 0dB dig. attenuation */
1349	SPI_REG(SPI_RDA1_REG,	SPI_DA_BIT_0dB),
1350	SPI_REG(SPI_PL_REG,	SPI_PL_BIT_L_L | SPI_PL_BIT_R_R | SPI_IZD_BIT),
1351	SPI_REG(SPI_FMT_REG,	SPI_FMT_BIT_I2S | SPI_IWL_BIT_24),
1352	SPI_REG(SPI_LDA2_REG,	SPI_DA_BIT_0dB),
1353	SPI_REG(SPI_RDA2_REG,	SPI_DA_BIT_0dB),
1354	SPI_REG(SPI_LDA3_REG,	SPI_DA_BIT_0dB),
1355	SPI_REG(SPI_RDA3_REG,	SPI_DA_BIT_0dB),
1356	SPI_REG(SPI_MASTDA_REG,	SPI_DA_BIT_0dB),
1357	SPI_REG(9,		0x00),
1358	SPI_REG(SPI_MS_REG,	SPI_DACD0_BIT | SPI_DACD1_BIT | SPI_DACD2_BIT),
1359	SPI_REG(12,		0x00),
1360	SPI_REG(SPI_LDA4_REG,	SPI_DA_BIT_0dB),
1361	SPI_REG(SPI_RDA4_REG,	SPI_DA_BIT_0dB | SPI_DA_BIT_UPDATE),
1362	SPI_REG(SPI_DACD4_REG,	SPI_DACD4_BIT),
1363};
1364
1365static const unsigned int i2c_adc_init[][2] = {
1366	{ 0x17, 0x00 }, /* Reset */
1367	{ 0x07, 0x00 }, /* Timeout */
1368	{ 0x0b, 0x22 },  /* Interface control */
1369	{ 0x0c, 0x22 },  /* Master mode control */
1370	{ 0x0d, 0x08 },  /* Powerdown control */
1371	{ 0x0e, 0xcf },  /* Attenuation Left  0x01 = -103dB, 0xff = 24dB */
1372	{ 0x0f, 0xcf },  /* Attenuation Right 0.5dB steps */
1373	{ 0x10, 0x7b },  /* ALC Control 1 */
1374	{ 0x11, 0x00 },  /* ALC Control 2 */
1375	{ 0x12, 0x32 },  /* ALC Control 3 */
1376	{ 0x13, 0x00 },  /* Noise gate control */
1377	{ 0x14, 0xa6 },  /* Limiter control */
1378	{ 0x15, ADC_MUX_LINEIN },  /* ADC Mixer control */
1379};
1380
1381static void ca0106_init_chip(struct snd_ca0106 *chip, int resume)
1382{
1383	int ch;
1384	unsigned int def_bits;
1385
1386	outl(0, chip->port + CA0106_INTE);
1387
1388	/*
1389	 *  Init to 0x02109204 :
1390	 *  Clock accuracy    = 0     (1000ppm)
1391	 *  Sample Rate       = 2     (48kHz)
1392	 *  Audio Channel     = 1     (Left of 2)
1393	 *  Source Number     = 0     (Unspecified)
1394	 *  Generation Status = 1     (Original for Cat Code 12)
1395	 *  Cat Code          = 12    (Digital Signal Mixer)
1396	 *  Mode              = 0     (Mode 0)
1397	 *  Emphasis          = 0     (None)
1398	 *  CP                = 1     (Copyright unasserted)
1399	 *  AN                = 0     (Audio data)
1400	 *  P                 = 0     (Consumer)
1401	 */
1402	def_bits =
1403		SPCS_CLKACCY_1000PPM | SPCS_SAMPLERATE_48 |
1404		SPCS_CHANNELNUM_LEFT | SPCS_SOURCENUM_UNSPEC |
1405		SPCS_GENERATIONSTATUS | 0x00001200 |
1406		0x00000000 | SPCS_EMPHASIS_NONE | SPCS_COPYRIGHT;
1407	if (!resume) {
1408		chip->spdif_str_bits[0] = chip->spdif_bits[0] = def_bits;
1409		chip->spdif_str_bits[1] = chip->spdif_bits[1] = def_bits;
1410		chip->spdif_str_bits[2] = chip->spdif_bits[2] = def_bits;
1411		chip->spdif_str_bits[3] = chip->spdif_bits[3] = def_bits;
1412	}
1413	/* Only SPCS1 has been tested */
1414	snd_ca0106_ptr_write(chip, SPCS1, 0, chip->spdif_str_bits[1]);
1415	snd_ca0106_ptr_write(chip, SPCS0, 0, chip->spdif_str_bits[0]);
1416	snd_ca0106_ptr_write(chip, SPCS2, 0, chip->spdif_str_bits[2]);
1417	snd_ca0106_ptr_write(chip, SPCS3, 0, chip->spdif_str_bits[3]);
1418
1419        snd_ca0106_ptr_write(chip, PLAYBACK_MUTE, 0, 0x00fc0000);
1420        snd_ca0106_ptr_write(chip, CAPTURE_MUTE, 0, 0x00fc0000);
1421
1422        /* Write 0x8000 to AC97_REC_GAIN to mute it. */
1423        outb(AC97_REC_GAIN, chip->port + CA0106_AC97ADDRESS);
1424        outw(0x8000, chip->port + CA0106_AC97DATA);
1425#if 0 /* FIXME: what are these? */
1426	snd_ca0106_ptr_write(chip, SPCS0, 0, 0x2108006);
1427	snd_ca0106_ptr_write(chip, 0x42, 0, 0x2108006);
1428	snd_ca0106_ptr_write(chip, 0x43, 0, 0x2108006);
1429	snd_ca0106_ptr_write(chip, 0x44, 0, 0x2108006);
1430#endif
1431
1432	/* OSS drivers set this. */
1433	/* snd_ca0106_ptr_write(chip, SPDIF_SELECT2, 0, 0xf0f003f); */
1434
1435	/* Analog or Digital output */
1436	snd_ca0106_ptr_write(chip, SPDIF_SELECT1, 0, 0xf);
1437	/* 0x0b000000 for digital, 0x000b0000 for analog, from win2000 drivers.
1438	 * Use 0x000f0000 for surround71
1439	 */
1440	snd_ca0106_ptr_write(chip, SPDIF_SELECT2, 0, 0x000f0000);
1441
1442	chip->spdif_enable = 0; /* Set digital SPDIF output off */
1443	/*snd_ca0106_ptr_write(chip, 0x45, 0, 0);*/ /* Analogue out */
1444	/*snd_ca0106_ptr_write(chip, 0x45, 0, 0xf00);*/ /* Digital out */
1445
1446	/* goes to 0x40c80000 when doing SPDIF IN/OUT */
1447	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 0, 0x40c81000);
1448	/* (Mute) CAPTURE feedback into PLAYBACK volume.
1449	 * Only lower 16 bits matter.
1450	 */
1451	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 1, 0xffffffff);
1452	/* SPDIF IN Volume */
1453	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 2, 0x30300000);
1454	/* SPDIF IN Volume, 0x70 = (vol & 0x3f) | 0x40 */
1455	snd_ca0106_ptr_write(chip, CAPTURE_CONTROL, 3, 0x00700000);
1456
1457	snd_ca0106_ptr_write(chip, PLAYBACK_ROUTING1, 0, 0x32765410);
1458	snd_ca0106_ptr_write(chip, PLAYBACK_ROUTING2, 0, 0x76767676);
1459	snd_ca0106_ptr_write(chip, CAPTURE_ROUTING1, 0, 0x32765410);
1460	snd_ca0106_ptr_write(chip, CAPTURE_ROUTING2, 0, 0x76767676);
1461
1462	for (ch = 0; ch < 4; ch++) {
1463		/* Only high 16 bits matter */
1464		snd_ca0106_ptr_write(chip, CAPTURE_VOLUME1, ch, 0x30303030);
1465		snd_ca0106_ptr_write(chip, CAPTURE_VOLUME2, ch, 0x30303030);
1466#if 0 /* Mute */
1467		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME1, ch, 0x40404040);
1468		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME2, ch, 0x40404040);
1469		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME1, ch, 0xffffffff);
1470		snd_ca0106_ptr_write(chip, PLAYBACK_VOLUME2, ch, 0xffffffff);
1471#endif
1472	}
1473	if (chip->details->i2c_adc == 1) {
1474	        /* Select MIC, Line in, TAD in, AUX in */
1475	        snd_ca0106_ptr_write(chip, CAPTURE_SOURCE, 0x0, 0x333300e4);
1476		/* Default to CAPTURE_SOURCE to i2s in */
1477		if (!resume)
1478			chip->capture_source = 3;
1479	} else if (chip->details->ac97 == 1) {
1480	        /* Default to AC97 in */
1481	        snd_ca0106_ptr_write(chip, CAPTURE_SOURCE, 0x0, 0x444400e4);
1482		/* Default to CAPTURE_SOURCE to AC97 in */
1483		if (!resume)
1484			chip->capture_source = 4;
1485	} else {
1486	        /* Select MIC, Line in, TAD in, AUX in */
1487	        snd_ca0106_ptr_write(chip, CAPTURE_SOURCE, 0x0, 0x333300e4);
1488		/* Default to Set CAPTURE_SOURCE to i2s in */
1489		if (!resume)
1490			chip->capture_source = 3;
1491	}
1492
1493	if (chip->details->gpio_type == 2) {
1494		/* The SB0438 use GPIO differently. */
1495		/* FIXME: Still need to find out what the other GPIO bits do.
1496		 * E.g. For digital spdif out.
1497		 */
1498		outl(0x0, chip->port + CA0106_GPIO);
1499		/* outl(0x00f0e000, chip->port + CA0106_GPIO); */ /* Analog */
1500		outl(0x005f5301, chip->port + CA0106_GPIO); /* Analog */
1501	} else if (chip->details->gpio_type == 1) {
1502		/* The SB0410 and SB0413 use GPIO differently. */
1503		/* FIXME: Still need to find out what the other GPIO bits do.
1504		 * E.g. For digital spdif out.
1505		 */
1506		outl(0x0, chip->port + CA0106_GPIO);
1507		/* outl(0x00f0e000, chip->port + CA0106_GPIO); */ /* Analog */
1508		outl(0x005f5301, chip->port + CA0106_GPIO); /* Analog */
1509	} else {
1510		outl(0x0, chip->port + CA0106_GPIO);
1511		outl(0x005f03a3, chip->port + CA0106_GPIO); /* Analog */
1512		/* outl(0x005f02a2, chip->port + CA0106_GPIO); */ /* SPDIF */
1513	}
1514	snd_ca0106_intr_enable(chip, 0x105); /* Win2000 uses 0x1e0 */
1515
1516	/* outl(HCFG_LOCKSOUNDCACHE|HCFG_AUDIOENABLE, chip->port+HCFG); */
1517	/* 0x1000 causes AC3 to fails. Maybe it effects 24 bit output. */
1518	/* outl(0x00001409, chip->port + CA0106_HCFG); */
1519	/* outl(0x00000009, chip->port + CA0106_HCFG); */
1520	/* AC97 2.0, Enable outputs. */
1521	outl(HCFG_AC97 | HCFG_AUDIOENABLE, chip->port + CA0106_HCFG);
1522
1523	if (chip->details->i2c_adc == 1) {
1524		/* The SB0410 and SB0413 use I2C to control ADC. */
1525		int size, n;
1526
1527		size = ARRAY_SIZE(i2c_adc_init);
1528		/* dev_dbg(emu->card->dev, "I2C:array size=0x%x\n", size); */
1529		for (n = 0; n < size; n++)
1530			snd_ca0106_i2c_write(chip, i2c_adc_init[n][0],
1531					     i2c_adc_init[n][1]);
1532		for (n = 0; n < 4; n++) {
1533			chip->i2c_capture_volume[n][0] = 0xcf;
1534			chip->i2c_capture_volume[n][1] = 0xcf;
1535		}
1536		chip->i2c_capture_source = 2; /* Line in */
1537		/* Enable Line-in capture. MIC in currently untested. */
1538		/* snd_ca0106_i2c_write(chip, ADC_MUX, ADC_MUX_LINEIN); */
1539	}
1540
1541	if (chip->details->spi_dac) {
1542		/* The SB0570 use SPI to control DAC. */
1543		int size, n;
1544
1545		size = ARRAY_SIZE(spi_dac_init);
1546		for (n = 0; n < size; n++) {
1547			int reg = spi_dac_init[n] >> SPI_REG_SHIFT;
1548
1549			snd_ca0106_spi_write(chip, spi_dac_init[n]);
1550			if (reg < ARRAY_SIZE(chip->spi_dac_reg))
1551				chip->spi_dac_reg[reg] = spi_dac_init[n];
1552		}
1553
1554		/* Enable front dac only */
1555		snd_ca0106_pcm_power_dac(chip, PCM_FRONT_CHANNEL, 1);
1556	}
1557}
1558
1559static void ca0106_stop_chip(struct snd_ca0106 *chip)
1560{
1561	/* disable interrupts */
1562	snd_ca0106_ptr_write(chip, BASIC_INTERRUPT, 0, 0);
1563	outl(0, chip->port + CA0106_INTE);
1564	snd_ca0106_ptr_write(chip, EXTENDED_INT_MASK, 0, 0);
1565	udelay(1000);
1566	/* disable audio */
1567	/* outl(HCFG_LOCKSOUNDCACHE, chip->port + HCFG); */
1568	outl(0, chip->port + CA0106_HCFG);
1569	/* FIXME: We need to stop and DMA transfers here.
1570	 *        But as I am not sure how yet, we cannot from the dma pages.
1571	 * So we can fix: snd-malloc: Memory leak?  pages not freed = 8
1572	 */
1573}
1574
1575static int snd_ca0106_create(int dev, struct snd_card *card,
1576			     struct pci_dev *pci)
 
1577{
1578	struct snd_ca0106 *chip = card->private_data;
1579	const struct snd_ca0106_details *c;
1580	int err;
 
 
 
 
 
1581
1582	err = pcim_enable_device(pci);
1583	if (err < 0)
1584		return err;
1585	if (dma_set_mask_and_coherent(&pci->dev, DMA_BIT_MASK(32))) {
 
1586		dev_err(card->dev, "error to set 32bit mask DMA\n");
 
1587		return -ENXIO;
1588	}
1589
 
 
 
 
 
 
1590	chip->card = card;
1591	chip->pci = pci;
1592	chip->irq = -1;
1593
1594	spin_lock_init(&chip->emu_lock);
1595
1596	err = pci_request_regions(pci, "snd_ca0106");
1597	if (err < 0)
1598		return err;
1599	chip->port = pci_resource_start(pci, 0);
 
 
 
 
 
 
1600
1601	if (devm_request_irq(&pci->dev, pci->irq, snd_ca0106_interrupt,
1602			     IRQF_SHARED, KBUILD_MODNAME, chip)) {
 
1603		dev_err(card->dev, "cannot grab irq\n");
1604		return -EBUSY;
1605	}
1606	chip->irq = pci->irq;
1607	card->sync_irq = chip->irq;
1608
1609	/* This stores the periods table. */
1610	chip->buffer = snd_devm_alloc_pages(&pci->dev, SNDRV_DMA_TYPE_DEV, 1024);
1611	if (!chip->buffer)
 
1612		return -ENOMEM;
 
1613
1614	pci_set_master(pci);
1615	/* read serial */
1616	pci_read_config_dword(pci, PCI_SUBSYSTEM_VENDOR_ID, &chip->serial);
1617	pci_read_config_word(pci, PCI_SUBSYSTEM_ID, &chip->model);
1618	dev_info(card->dev, "Model %04x Rev %08x Serial %08x\n",
1619	       chip->model, pci->revision, chip->serial);
1620	strcpy(card->driver, "CA0106");
1621	strcpy(card->shortname, "CA0106");
1622
1623	for (c = ca0106_chip_details; c->serial; c++) {
1624		if (subsystem[dev]) {
1625			if (c->serial == subsystem[dev])
1626				break;
1627		} else if (c->serial == chip->serial)
1628			break;
1629	}
1630	chip->details = c;
1631	if (subsystem[dev]) {
1632		dev_info(card->dev, "Sound card name=%s, "
1633		       "subsystem=0x%x. Forced to subsystem=0x%x\n",
1634		       c->name, chip->serial, subsystem[dev]);
1635	}
1636
1637	sprintf(card->longname, "%s at 0x%lx irq %i",
1638		c->name, chip->port, chip->irq);
1639
1640	ca0106_init_chip(chip, 0);
 
 
 
 
 
 
 
1641	return 0;
1642}
1643
1644
1645static void ca0106_midi_interrupt_enable(struct snd_ca_midi *midi, int intr)
1646{
1647	snd_ca0106_intr_enable((struct snd_ca0106 *)(midi->dev_id), intr);
1648}
1649
1650static void ca0106_midi_interrupt_disable(struct snd_ca_midi *midi, int intr)
1651{
1652	snd_ca0106_intr_disable((struct snd_ca0106 *)(midi->dev_id), intr);
1653}
1654
1655static unsigned char ca0106_midi_read(struct snd_ca_midi *midi, int idx)
1656{
1657	return (unsigned char)snd_ca0106_ptr_read((struct snd_ca0106 *)(midi->dev_id),
1658						  midi->port + idx, 0);
1659}
1660
1661static void ca0106_midi_write(struct snd_ca_midi *midi, int data, int idx)
1662{
1663	snd_ca0106_ptr_write((struct snd_ca0106 *)(midi->dev_id), midi->port + idx, 0, data);
1664}
1665
1666static struct snd_card *ca0106_dev_id_card(void *dev_id)
1667{
1668	return ((struct snd_ca0106 *)dev_id)->card;
1669}
1670
1671static int ca0106_dev_id_port(void *dev_id)
1672{
1673	return ((struct snd_ca0106 *)dev_id)->port;
1674}
1675
1676static int snd_ca0106_midi(struct snd_ca0106 *chip, unsigned int channel)
1677{
1678	struct snd_ca_midi *midi;
1679	char *name;
1680	int err;
1681
1682	if (channel == CA0106_MIDI_CHAN_B) {
1683		name = "CA0106 MPU-401 (UART) B";
1684		midi =  &chip->midi2;
1685		midi->tx_enable = INTE_MIDI_TX_B;
1686		midi->rx_enable = INTE_MIDI_RX_B;
1687		midi->ipr_tx = IPR_MIDI_TX_B;
1688		midi->ipr_rx = IPR_MIDI_RX_B;
1689		midi->port = MIDI_UART_B_DATA;
1690	} else {
1691		name = "CA0106 MPU-401 (UART)";
1692		midi =  &chip->midi;
1693		midi->tx_enable = INTE_MIDI_TX_A;
1694		midi->rx_enable = INTE_MIDI_TX_B;
1695		midi->ipr_tx = IPR_MIDI_TX_A;
1696		midi->ipr_rx = IPR_MIDI_RX_A;
1697		midi->port = MIDI_UART_A_DATA;
1698	}
1699
1700	midi->reset = CA0106_MPU401_RESET;
1701	midi->enter_uart = CA0106_MPU401_ENTER_UART;
1702	midi->ack = CA0106_MPU401_ACK;
1703
1704	midi->input_avail = CA0106_MIDI_INPUT_AVAIL;
1705	midi->output_ready = CA0106_MIDI_OUTPUT_READY;
1706
1707	midi->channel = channel;
1708
1709	midi->interrupt_enable = ca0106_midi_interrupt_enable;
1710	midi->interrupt_disable = ca0106_midi_interrupt_disable;
1711
1712	midi->read = ca0106_midi_read;
1713	midi->write = ca0106_midi_write;
1714
1715	midi->get_dev_id_card = ca0106_dev_id_card;
1716	midi->get_dev_id_port = ca0106_dev_id_port;
1717
1718	midi->dev_id = chip;
1719	
1720	err = ca_midi_init(chip, midi, 0, name);
1721	if (err < 0)
1722		return err;
1723
1724	return 0;
1725}
1726
1727
1728static int __snd_ca0106_probe(struct pci_dev *pci,
1729			      const struct pci_device_id *pci_id)
1730{
1731	static int dev;
1732	struct snd_card *card;
1733	struct snd_ca0106 *chip;
1734	int i, err;
1735
1736	if (dev >= SNDRV_CARDS)
1737		return -ENODEV;
1738	if (!enable[dev]) {
1739		dev++;
1740		return -ENOENT;
1741	}
1742
1743	err = snd_devm_card_new(&pci->dev, index[dev], id[dev], THIS_MODULE,
1744				sizeof(*chip), &card);
1745	if (err < 0)
1746		return err;
1747	chip = card->private_data;
1748
1749	err = snd_ca0106_create(dev, card, pci);
1750	if (err < 0)
1751		return err;
1752	card->private_free = snd_ca0106_free;
1753
1754	for (i = 0; i < 4; i++) {
1755		err = snd_ca0106_pcm(chip, i);
1756		if (err < 0)
1757			return err;
1758	}
1759
1760	if (chip->details->ac97 == 1) {
1761		/* The SB0410 and SB0413 do not have an AC97 chip. */
1762		err = snd_ca0106_ac97(chip);
1763		if (err < 0)
1764			return err;
1765	}
1766	err = snd_ca0106_mixer(chip);
1767	if (err < 0)
1768		return err;
1769
1770	dev_dbg(card->dev, "probe for MIDI channel A ...");
1771	err = snd_ca0106_midi(chip, CA0106_MIDI_CHAN_A);
1772	if (err < 0)
1773		return err;
1774	dev_dbg(card->dev, " done.\n");
1775
1776#ifdef CONFIG_SND_PROC_FS
1777	snd_ca0106_proc_init(chip);
1778#endif
1779
1780	err = snd_card_register(card);
1781	if (err < 0)
1782		return err;
1783
1784	pci_set_drvdata(pci, card);
1785	dev++;
1786	return 0;
 
 
 
 
1787}
1788
1789static int snd_ca0106_probe(struct pci_dev *pci,
1790			    const struct pci_device_id *pci_id)
1791{
1792	return snd_card_free_on_error(&pci->dev, __snd_ca0106_probe(pci, pci_id));
1793}
1794
1795#ifdef CONFIG_PM_SLEEP
1796static int snd_ca0106_suspend(struct device *dev)
1797{
1798	struct snd_card *card = dev_get_drvdata(dev);
1799	struct snd_ca0106 *chip = card->private_data;
1800
1801	snd_power_change_state(card, SNDRV_CTL_POWER_D3hot);
1802	if (chip->details->ac97)
1803		snd_ac97_suspend(chip->ac97);
1804	snd_ca0106_mixer_suspend(chip);
1805
1806	ca0106_stop_chip(chip);
1807	return 0;
1808}
1809
1810static int snd_ca0106_resume(struct device *dev)
1811{
1812	struct snd_card *card = dev_get_drvdata(dev);
1813	struct snd_ca0106 *chip = card->private_data;
1814	int i;
1815
1816	ca0106_init_chip(chip, 1);
1817
1818	if (chip->details->ac97)
1819		snd_ac97_resume(chip->ac97);
1820	snd_ca0106_mixer_resume(chip);
1821	if (chip->details->spi_dac) {
1822		for (i = 0; i < ARRAY_SIZE(chip->spi_dac_reg); i++)
1823			snd_ca0106_spi_write(chip, chip->spi_dac_reg[i]);
1824	}
1825
1826	snd_power_change_state(card, SNDRV_CTL_POWER_D0);
1827	return 0;
1828}
1829
1830static SIMPLE_DEV_PM_OPS(snd_ca0106_pm, snd_ca0106_suspend, snd_ca0106_resume);
1831#define SND_CA0106_PM_OPS	&snd_ca0106_pm
1832#else
1833#define SND_CA0106_PM_OPS	NULL
1834#endif
1835
1836// PCI IDs
1837static const struct pci_device_id snd_ca0106_ids[] = {
1838	{ PCI_VDEVICE(CREATIVE, 0x0007), 0 },	/* Audigy LS or Live 24bit */
1839	{ 0, }
1840};
1841MODULE_DEVICE_TABLE(pci, snd_ca0106_ids);
1842
1843// pci_driver definition
1844static struct pci_driver ca0106_driver = {
1845	.name = KBUILD_MODNAME,
1846	.id_table = snd_ca0106_ids,
1847	.probe = snd_ca0106_probe,
 
1848	.driver = {
1849		.pm = SND_CA0106_PM_OPS,
1850	},
1851};
1852
1853module_pci_driver(ca0106_driver);