3 * hda_intel.c - Implementation of primary alsa driver code base
6 * Copyright(c) 2004 Intel Corporation. All rights reserved.
8 * Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
9 * PeiSen Hou <pshou@realtek.com.tw>
11 * This program is free software; you can redistribute it and/or modify it
12 * under the terms of the GNU General Public License as published by the Free
13 * Software Foundation; either version 2 of the License, or (at your option)
16 * This program is distributed in the hope that it will be useful, but WITHOUT
17 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
21 * You should have received a copy of the GNU General Public License along with
22 * this program; if not, write to the Free Software Foundation, Inc., 59
23 * Temple Place - Suite 330, Boston, MA 02111-1307, USA.
27 * Matt Jared matt.jared@intel.com
28 * Andy Kopp andy.kopp@intel.com
29 * Dan Kogan dan.d.kogan@intel.com
33 * 2004.12.01 Major rewrite by tiwai, merged the work of pshou
37 #include <linux/delay.h>
38 #include <linux/interrupt.h>
39 #include <linux/kernel.h>
40 #include <linux/module.h>
41 #include <linux/dma-mapping.h>
42 #include <linux/moduleparam.h>
43 #include <linux/init.h>
44 #include <linux/slab.h>
45 #include <linux/pci.h>
46 #include <linux/mutex.h>
47 #include <linux/reboot.h>
49 #include <linux/pm_runtime.h>
50 #include <linux/clocksource.h>
51 #include <linux/time.h>
52 #include <linux/completion.h>
55 /* for snoop control */
56 #include <asm/pgtable.h>
57 #include <asm/cacheflush.h>
59 #include <sound/core.h>
60 #include <sound/initval.h>
61 #include <linux/vgaarb.h>
62 #include <linux/vga_switcheroo.h>
63 #include <linux/firmware.h>
64 #include "hda_codec.h"
68 static int index
[SNDRV_CARDS
] = SNDRV_DEFAULT_IDX
;
69 static char *id
[SNDRV_CARDS
] = SNDRV_DEFAULT_STR
;
70 static bool enable
[SNDRV_CARDS
] = SNDRV_DEFAULT_ENABLE_PNP
;
71 static char *model
[SNDRV_CARDS
];
72 static int position_fix
[SNDRV_CARDS
] = {[0 ... (SNDRV_CARDS
-1)] = -1};
73 static int bdl_pos_adj
[SNDRV_CARDS
] = {[0 ... (SNDRV_CARDS
-1)] = -1};
74 static int probe_mask
[SNDRV_CARDS
] = {[0 ... (SNDRV_CARDS
-1)] = -1};
75 static int probe_only
[SNDRV_CARDS
];
76 static int jackpoll_ms
[SNDRV_CARDS
];
77 static bool single_cmd
;
78 static int enable_msi
= -1;
79 #ifdef CONFIG_SND_HDA_PATCH_LOADER
80 static char *patch
[SNDRV_CARDS
];
82 #ifdef CONFIG_SND_HDA_INPUT_BEEP
83 static bool beep_mode
[SNDRV_CARDS
] = {[0 ... (SNDRV_CARDS
-1)] =
84 CONFIG_SND_HDA_INPUT_BEEP_MODE
};
87 module_param_array(index
, int, NULL
, 0444);
88 MODULE_PARM_DESC(index
, "Index value for Intel HD audio interface.");
89 module_param_array(id
, charp
, NULL
, 0444);
90 MODULE_PARM_DESC(id
, "ID string for Intel HD audio interface.");
91 module_param_array(enable
, bool, NULL
, 0444);
92 MODULE_PARM_DESC(enable
, "Enable Intel HD audio interface.");
93 module_param_array(model
, charp
, NULL
, 0444);
94 MODULE_PARM_DESC(model
, "Use the given board model.");
95 module_param_array(position_fix
, int, NULL
, 0444);
96 MODULE_PARM_DESC(position_fix
, "DMA pointer read method."
97 "(-1 = system default, 0 = auto, 1 = LPIB, 2 = POSBUF, 3 = VIACOMBO, 4 = COMBO).");
98 module_param_array(bdl_pos_adj
, int, NULL
, 0644);
99 MODULE_PARM_DESC(bdl_pos_adj
, "BDL position adjustment offset.");
100 module_param_array(probe_mask
, int, NULL
, 0444);
101 MODULE_PARM_DESC(probe_mask
, "Bitmask to probe codecs (default = -1).");
102 module_param_array(probe_only
, int, NULL
, 0444);
103 MODULE_PARM_DESC(probe_only
, "Only probing and no codec initialization.");
104 module_param_array(jackpoll_ms
, int, NULL
, 0444);
105 MODULE_PARM_DESC(jackpoll_ms
, "Ms between polling for jack events (default = 0, using unsol events only)");
106 module_param(single_cmd
, bool, 0444);
107 MODULE_PARM_DESC(single_cmd
, "Use single command to communicate with codecs "
108 "(for debugging only).");
109 module_param(enable_msi
, bint
, 0444);
110 MODULE_PARM_DESC(enable_msi
, "Enable Message Signaled Interrupt (MSI)");
111 #ifdef CONFIG_SND_HDA_PATCH_LOADER
112 module_param_array(patch
, charp
, NULL
, 0444);
113 MODULE_PARM_DESC(patch
, "Patch file for Intel HD audio interface.");
115 #ifdef CONFIG_SND_HDA_INPUT_BEEP
116 module_param_array(beep_mode
, bool, NULL
, 0444);
117 MODULE_PARM_DESC(beep_mode
, "Select HDA Beep registration mode "
118 "(0=off, 1=on) (default=1).");
122 static int param_set_xint(const char *val
, const struct kernel_param
*kp
);
123 static struct kernel_param_ops param_ops_xint
= {
124 .set
= param_set_xint
,
125 .get
= param_get_int
,
127 #define param_check_xint param_check_int
129 static int power_save
= CONFIG_SND_HDA_POWER_SAVE_DEFAULT
;
130 module_param(power_save
, xint
, 0644);
131 MODULE_PARM_DESC(power_save
, "Automatic power-saving timeout "
132 "(in second, 0 = disable).");
134 /* reset the HD-audio controller in power save mode.
135 * this may give more power-saving, but will take longer time to
138 static bool power_save_controller
= 1;
139 module_param(power_save_controller
, bool, 0644);
140 MODULE_PARM_DESC(power_save_controller
, "Reset controller in power save mode.");
141 #endif /* CONFIG_PM */
143 static int align_buffer_size
= -1;
144 module_param(align_buffer_size
, bint
, 0644);
145 MODULE_PARM_DESC(align_buffer_size
,
146 "Force buffer and period sizes to be multiple of 128 bytes.");
149 static bool hda_snoop
= true;
150 module_param_named(snoop
, hda_snoop
, bool, 0444);
151 MODULE_PARM_DESC(snoop
, "Enable/disable snooping");
152 #define azx_snoop(chip) (chip)->snoop
154 #define hda_snoop true
155 #define azx_snoop(chip) true
159 MODULE_LICENSE("GPL");
160 MODULE_SUPPORTED_DEVICE("{{Intel, ICH6},"
192 MODULE_DESCRIPTION("Intel HDA driver");
194 #ifdef CONFIG_SND_VERBOSE_PRINTK
195 #define SFX /* nop */
197 #define SFX "hda-intel "
200 #if defined(CONFIG_PM) && defined(CONFIG_VGA_SWITCHEROO)
201 #if IS_ENABLED(CONFIG_SND_HDA_CODEC_HDMI)
202 #define SUPPORT_VGA_SWITCHEROO
210 #define ICH6_REG_GCAP 0x00
211 #define ICH6_GCAP_64OK (1 << 0) /* 64bit address support */
212 #define ICH6_GCAP_NSDO (3 << 1) /* # of serial data out signals */
213 #define ICH6_GCAP_BSS (31 << 3) /* # of bidirectional streams */
214 #define ICH6_GCAP_ISS (15 << 8) /* # of input streams */
215 #define ICH6_GCAP_OSS (15 << 12) /* # of output streams */
216 #define ICH6_REG_VMIN 0x02
217 #define ICH6_REG_VMAJ 0x03
218 #define ICH6_REG_OUTPAY 0x04
219 #define ICH6_REG_INPAY 0x06
220 #define ICH6_REG_GCTL 0x08
221 #define ICH6_GCTL_RESET (1 << 0) /* controller reset */
222 #define ICH6_GCTL_FCNTRL (1 << 1) /* flush control */
223 #define ICH6_GCTL_UNSOL (1 << 8) /* accept unsol. response enable */
224 #define ICH6_REG_WAKEEN 0x0c
225 #define ICH6_REG_STATESTS 0x0e
226 #define ICH6_REG_GSTS 0x10
227 #define ICH6_GSTS_FSTS (1 << 1) /* flush status */
228 #define ICH6_REG_INTCTL 0x20
229 #define ICH6_REG_INTSTS 0x24
230 #define ICH6_REG_WALLCLK 0x30 /* 24Mhz source */
231 #define ICH6_REG_OLD_SSYNC 0x34 /* SSYNC for old ICH */
232 #define ICH6_REG_SSYNC 0x38
233 #define ICH6_REG_CORBLBASE 0x40
234 #define ICH6_REG_CORBUBASE 0x44
235 #define ICH6_REG_CORBWP 0x48
236 #define ICH6_REG_CORBRP 0x4a
237 #define ICH6_CORBRP_RST (1 << 15) /* read pointer reset */
238 #define ICH6_REG_CORBCTL 0x4c
239 #define ICH6_CORBCTL_RUN (1 << 1) /* enable DMA */
240 #define ICH6_CORBCTL_CMEIE (1 << 0) /* enable memory error irq */
241 #define ICH6_REG_CORBSTS 0x4d
242 #define ICH6_CORBSTS_CMEI (1 << 0) /* memory error indication */
243 #define ICH6_REG_CORBSIZE 0x4e
245 #define ICH6_REG_RIRBLBASE 0x50
246 #define ICH6_REG_RIRBUBASE 0x54
247 #define ICH6_REG_RIRBWP 0x58
248 #define ICH6_RIRBWP_RST (1 << 15) /* write pointer reset */
249 #define ICH6_REG_RINTCNT 0x5a
250 #define ICH6_REG_RIRBCTL 0x5c
251 #define ICH6_RBCTL_IRQ_EN (1 << 0) /* enable IRQ */
252 #define ICH6_RBCTL_DMA_EN (1 << 1) /* enable DMA */
253 #define ICH6_RBCTL_OVERRUN_EN (1 << 2) /* enable overrun irq */
254 #define ICH6_REG_RIRBSTS 0x5d
255 #define ICH6_RBSTS_IRQ (1 << 0) /* response irq */
256 #define ICH6_RBSTS_OVERRUN (1 << 2) /* overrun irq */
257 #define ICH6_REG_RIRBSIZE 0x5e
259 #define ICH6_REG_IC 0x60
260 #define ICH6_REG_IR 0x64
261 #define ICH6_REG_IRS 0x68
262 #define ICH6_IRS_VALID (1<<1)
263 #define ICH6_IRS_BUSY (1<<0)
265 #define ICH6_REG_DPLBASE 0x70
266 #define ICH6_REG_DPUBASE 0x74
267 #define ICH6_DPLBASE_ENABLE 0x1 /* Enable position buffer */
269 /* SD offset: SDI0=0x80, SDI1=0xa0, ... SDO3=0x160 */
270 enum { SDI0
, SDI1
, SDI2
, SDI3
, SDO0
, SDO1
, SDO2
, SDO3
};
272 /* stream register offsets from stream base */
273 #define ICH6_REG_SD_CTL 0x00
274 #define ICH6_REG_SD_STS 0x03
275 #define ICH6_REG_SD_LPIB 0x04
276 #define ICH6_REG_SD_CBL 0x08
277 #define ICH6_REG_SD_LVI 0x0c
278 #define ICH6_REG_SD_FIFOW 0x0e
279 #define ICH6_REG_SD_FIFOSIZE 0x10
280 #define ICH6_REG_SD_FORMAT 0x12
281 #define ICH6_REG_SD_BDLPL 0x18
282 #define ICH6_REG_SD_BDLPU 0x1c
285 #define ICH6_PCIREG_TCSEL 0x44
291 /* max number of SDs */
292 /* ICH, ATI and VIA have 4 playback and 4 capture */
293 #define ICH6_NUM_CAPTURE 4
294 #define ICH6_NUM_PLAYBACK 4
296 /* ULI has 6 playback and 5 capture */
297 #define ULI_NUM_CAPTURE 5
298 #define ULI_NUM_PLAYBACK 6
300 /* ATI HDMI may have up to 8 playbacks and 0 capture */
301 #define ATIHDMI_NUM_CAPTURE 0
302 #define ATIHDMI_NUM_PLAYBACK 8
304 /* TERA has 4 playback and 3 capture */
305 #define TERA_NUM_CAPTURE 3
306 #define TERA_NUM_PLAYBACK 4
308 /* this number is statically defined for simplicity */
309 #define MAX_AZX_DEV 16
311 /* max number of fragments - we may use more if allocating more pages for BDL */
312 #define BDL_SIZE 4096
313 #define AZX_MAX_BDL_ENTRIES (BDL_SIZE / 16)
314 #define AZX_MAX_FRAG 32
315 /* max buffer size - no h/w limit, you can increase as you like */
316 #define AZX_MAX_BUF_SIZE (1024*1024*1024)
318 /* RIRB int mask: overrun[2], response[0] */
319 #define RIRB_INT_RESPONSE 0x01
320 #define RIRB_INT_OVERRUN 0x04
321 #define RIRB_INT_MASK 0x05
323 /* STATESTS int mask: S3,SD2,SD1,SD0 */
324 #define AZX_MAX_CODECS 8
325 #define AZX_DEFAULT_CODECS 4
326 #define STATESTS_INT_MASK ((1 << AZX_MAX_CODECS) - 1)
329 #define SD_CTL_STREAM_RESET 0x01 /* stream reset bit */
330 #define SD_CTL_DMA_START 0x02 /* stream DMA start bit */
331 #define SD_CTL_STRIPE (3 << 16) /* stripe control */
332 #define SD_CTL_TRAFFIC_PRIO (1 << 18) /* traffic priority */
333 #define SD_CTL_DIR (1 << 19) /* bi-directional stream */
334 #define SD_CTL_STREAM_TAG_MASK (0xf << 20)
335 #define SD_CTL_STREAM_TAG_SHIFT 20
337 /* SD_CTL and SD_STS */
338 #define SD_INT_DESC_ERR 0x10 /* descriptor error interrupt */
339 #define SD_INT_FIFO_ERR 0x08 /* FIFO error interrupt */
340 #define SD_INT_COMPLETE 0x04 /* completion interrupt */
341 #define SD_INT_MASK (SD_INT_DESC_ERR|SD_INT_FIFO_ERR|\
345 #define SD_STS_FIFO_READY 0x20 /* FIFO ready */
347 /* INTCTL and INTSTS */
348 #define ICH6_INT_ALL_STREAM 0xff /* all stream interrupts */
349 #define ICH6_INT_CTRL_EN 0x40000000 /* controller interrupt enable bit */
350 #define ICH6_INT_GLOBAL_EN 0x80000000 /* global interrupt enable bit */
352 /* below are so far hardcoded - should read registers in future */
353 #define ICH6_MAX_CORB_ENTRIES 256
354 #define ICH6_MAX_RIRB_ENTRIES 256
356 /* position fix mode */
365 /* Defines for ATI HD Audio support in SB450 south bridge */
366 #define ATI_SB450_HDAUDIO_MISC_CNTR2_ADDR 0x42
367 #define ATI_SB450_HDAUDIO_ENABLE_SNOOP 0x02
369 /* Defines for Nvidia HDA support */
370 #define NVIDIA_HDA_TRANSREG_ADDR 0x4e
371 #define NVIDIA_HDA_ENABLE_COHBITS 0x0f
372 #define NVIDIA_HDA_ISTRM_COH 0x4d
373 #define NVIDIA_HDA_OSTRM_COH 0x4c
374 #define NVIDIA_HDA_ENABLE_COHBIT 0x01
376 /* Defines for Intel SCH HDA snoop control */
377 #define INTEL_SCH_HDA_DEVC 0x78
378 #define INTEL_SCH_HDA_DEVC_NOSNOOP (0x1<<11)
380 /* Define IN stream 0 FIFO size offset in VIA controller */
381 #define VIA_IN_STREAM0_FIFO_SIZE_OFFSET 0x90
382 /* Define VIA HD Audio Device ID*/
383 #define VIA_HDAC_DEVICE_ID 0x3288
385 /* HD Audio class code */
386 #define PCI_CLASS_MULTIMEDIA_HD_AUDIO 0x0403
392 struct snd_dma_buffer bdl
; /* BDL buffer */
393 u32
*posbuf
; /* position buffer pointer */
395 unsigned int bufsize
; /* size of the play buffer in bytes */
396 unsigned int period_bytes
; /* size of the period in bytes */
397 unsigned int frags
; /* number for period in the play buffer */
398 unsigned int fifo_size
; /* FIFO size */
399 unsigned long start_wallclk
; /* start + minimum wallclk */
400 unsigned long period_wallclk
; /* wallclk for period */
402 void __iomem
*sd_addr
; /* stream descriptor pointer */
404 u32 sd_int_sta_mask
; /* stream int status mask */
407 struct snd_pcm_substream
*substream
; /* assigned substream,
410 unsigned int format_val
; /* format value to be set in the
411 * controller and the codec
413 unsigned char stream_tag
; /* assigned stream */
414 unsigned char index
; /* stream index */
415 int assigned_key
; /* last device# key assigned to */
417 unsigned int opened
:1;
418 unsigned int running
:1;
419 unsigned int irq_pending
:1;
420 unsigned int prepared
:1;
421 unsigned int locked
:1;
424 * A flag to ensure DMA position is 0
425 * when link position is not greater than FIFO size
427 unsigned int insufficient
:1;
428 unsigned int wc_marked
:1;
429 unsigned int no_period_wakeup
:1;
431 struct timecounter azx_tc
;
432 struct cyclecounter azx_cc
;
434 int delay_negative_threshold
;
436 #ifdef CONFIG_SND_HDA_DSP_LOADER
437 struct mutex dsp_mutex
;
441 /* DSP lock helpers */
442 #ifdef CONFIG_SND_HDA_DSP_LOADER
443 #define dsp_lock_init(dev) mutex_init(&(dev)->dsp_mutex)
444 #define dsp_lock(dev) mutex_lock(&(dev)->dsp_mutex)
445 #define dsp_unlock(dev) mutex_unlock(&(dev)->dsp_mutex)
446 #define dsp_is_locked(dev) ((dev)->locked)
448 #define dsp_lock_init(dev) do {} while (0)
449 #define dsp_lock(dev) do {} while (0)
450 #define dsp_unlock(dev) do {} while (0)
451 #define dsp_is_locked(dev) 0
456 u32
*buf
; /* CORB/RIRB buffer
457 * Each CORB entry is 4byte, RIRB is 8byte
459 dma_addr_t addr
; /* physical address of CORB/RIRB buffer */
461 unsigned short rp
, wp
; /* read/write pointers */
462 int cmds
[AZX_MAX_CODECS
]; /* number of pending requests */
463 u32 res
[AZX_MAX_CODECS
]; /* last read value */
469 struct hda_codec
*codec
;
470 struct hda_pcm_stream
*hinfo
[2];
471 struct list_head list
;
475 struct snd_card
*card
;
479 /* chip type specific */
481 unsigned int driver_caps
;
482 int playback_streams
;
483 int playback_index_offset
;
485 int capture_index_offset
;
490 void __iomem
*remap_addr
;
495 struct mutex open_mutex
;
496 struct completion probe_wait
;
498 /* streams (x num_streams) */
499 struct azx_dev
*azx_dev
;
502 struct list_head pcm_list
; /* azx_pcm list */
505 unsigned short codec_mask
;
506 int codec_probe_mask
; /* copied from probe_mask option */
508 unsigned int beep_mode
;
514 /* CORB/RIRB and position buffers */
515 struct snd_dma_buffer rb
;
516 struct snd_dma_buffer posbuf
;
518 #ifdef CONFIG_SND_HDA_PATCH_LOADER
519 const struct firmware
*fw
;
523 int position_fix
[2]; /* for both playback/capture streams */
525 unsigned int running
:1;
526 unsigned int initialized
:1;
527 unsigned int single_cmd
:1;
528 unsigned int polling_mode
:1;
530 unsigned int irq_pending_warned
:1;
531 unsigned int probing
:1; /* codec probing phase */
532 unsigned int snoop
:1;
533 unsigned int align_buffer_size
:1;
534 unsigned int region_requested
:1;
536 /* VGA-switcheroo setup */
537 unsigned int use_vga_switcheroo
:1;
538 unsigned int vga_switcheroo_registered
:1;
539 unsigned int init_failed
:1; /* delayed init failed */
540 unsigned int disabled
:1; /* disabled by VGA-switcher */
543 unsigned int last_cmd
[AZX_MAX_CODECS
];
545 /* for pending irqs */
546 struct work_struct irq_pending_work
;
548 struct work_struct probe_work
;
550 /* reboot notifier (for mysterious hangup problem at power-down) */
551 struct notifier_block reboot_notifier
;
553 /* card list (for power_save trigger) */
554 struct list_head list
;
556 #ifdef CONFIG_SND_HDA_DSP_LOADER
557 struct azx_dev saved_azx_dev
;
560 /* secondary power domain for hdmi audio under vga device */
561 struct dev_pm_domain hdmi_pm_domain
;
564 #define CREATE_TRACE_POINTS
565 #include "hda_intel_trace.h"
575 AZX_DRIVER_ATIHDMI_NS
,
584 AZX_NUM_DRIVERS
, /* keep this as last entry */
587 /* driver quirks (capabilities) */
588 /* bits 0-7 are used for indicating driver type */
589 #define AZX_DCAPS_NO_TCSEL (1 << 8) /* No Intel TCSEL bit */
590 #define AZX_DCAPS_NO_MSI (1 << 9) /* No MSI support */
591 #define AZX_DCAPS_ATI_SNOOP (1 << 10) /* ATI snoop enable */
592 #define AZX_DCAPS_NVIDIA_SNOOP (1 << 11) /* Nvidia snoop enable */
593 #define AZX_DCAPS_SCH_SNOOP (1 << 12) /* SCH/PCH snoop enable */
594 #define AZX_DCAPS_RIRB_DELAY (1 << 13) /* Long delay in read loop */
595 #define AZX_DCAPS_RIRB_PRE_DELAY (1 << 14) /* Put a delay before read */
596 #define AZX_DCAPS_CTX_WORKAROUND (1 << 15) /* X-Fi workaround */
597 #define AZX_DCAPS_POSFIX_LPIB (1 << 16) /* Use LPIB as default */
598 #define AZX_DCAPS_POSFIX_VIA (1 << 17) /* Use VIACOMBO as default */
599 #define AZX_DCAPS_NO_64BIT (1 << 18) /* No 64bit address */
600 #define AZX_DCAPS_SYNC_WRITE (1 << 19) /* sync each cmd write */
601 #define AZX_DCAPS_OLD_SSYNC (1 << 20) /* Old SSYNC reg for ICH */
602 #define AZX_DCAPS_BUFSIZE (1 << 21) /* no buffer size alignment */
603 #define AZX_DCAPS_ALIGN_BUFSIZE (1 << 22) /* buffer size alignment */
604 #define AZX_DCAPS_4K_BDLE_BOUNDARY (1 << 23) /* BDLE in 4k boundary */
605 #define AZX_DCAPS_COUNT_LPIB_DELAY (1 << 25) /* Take LPIB as delay */
606 #define AZX_DCAPS_PM_RUNTIME (1 << 26) /* runtime PM support */
607 #define AZX_DCAPS_I915_POWERWELL (1 << 27) /* HSW i915 power well support */
609 /* quirks for Intel PCH */
610 #define AZX_DCAPS_INTEL_PCH_NOPM \
611 (AZX_DCAPS_SCH_SNOOP | AZX_DCAPS_BUFSIZE | \
612 AZX_DCAPS_COUNT_LPIB_DELAY)
614 #define AZX_DCAPS_INTEL_PCH \
615 (AZX_DCAPS_INTEL_PCH_NOPM | AZX_DCAPS_PM_RUNTIME)
617 #define AZX_DCAPS_INTEL_HASWELL \
618 (AZX_DCAPS_SCH_SNOOP | AZX_DCAPS_ALIGN_BUFSIZE | \
619 AZX_DCAPS_COUNT_LPIB_DELAY | AZX_DCAPS_PM_RUNTIME | \
620 AZX_DCAPS_I915_POWERWELL)
622 /* quirks for ATI SB / AMD Hudson */
623 #define AZX_DCAPS_PRESET_ATI_SB \
624 (AZX_DCAPS_ATI_SNOOP | AZX_DCAPS_NO_TCSEL | \
625 AZX_DCAPS_SYNC_WRITE | AZX_DCAPS_POSFIX_LPIB)
627 /* quirks for ATI/AMD HDMI */
628 #define AZX_DCAPS_PRESET_ATI_HDMI \
629 (AZX_DCAPS_NO_TCSEL | AZX_DCAPS_SYNC_WRITE | AZX_DCAPS_POSFIX_LPIB)
631 /* quirks for Nvidia */
632 #define AZX_DCAPS_PRESET_NVIDIA \
633 (AZX_DCAPS_NVIDIA_SNOOP | AZX_DCAPS_RIRB_DELAY | AZX_DCAPS_NO_MSI |\
634 AZX_DCAPS_ALIGN_BUFSIZE | AZX_DCAPS_NO_64BIT)
636 #define AZX_DCAPS_PRESET_CTHDA \
637 (AZX_DCAPS_NO_MSI | AZX_DCAPS_POSFIX_LPIB | AZX_DCAPS_4K_BDLE_BOUNDARY)
640 * VGA-switcher support
642 #ifdef SUPPORT_VGA_SWITCHEROO
643 #define use_vga_switcheroo(chip) ((chip)->use_vga_switcheroo)
645 #define use_vga_switcheroo(chip) 0
648 static char *driver_short_names
[] = {
649 [AZX_DRIVER_ICH
] = "HDA Intel",
650 [AZX_DRIVER_PCH
] = "HDA Intel PCH",
651 [AZX_DRIVER_SCH
] = "HDA Intel MID",
652 [AZX_DRIVER_HDMI
] = "HDA Intel HDMI",
653 [AZX_DRIVER_ATI
] = "HDA ATI SB",
654 [AZX_DRIVER_ATIHDMI
] = "HDA ATI HDMI",
655 [AZX_DRIVER_ATIHDMI_NS
] = "HDA ATI HDMI",
656 [AZX_DRIVER_VIA
] = "HDA VIA VT82xx",
657 [AZX_DRIVER_SIS
] = "HDA SIS966",
658 [AZX_DRIVER_ULI
] = "HDA ULI M5461",
659 [AZX_DRIVER_NVIDIA
] = "HDA NVidia",
660 [AZX_DRIVER_TERA
] = "HDA Teradici",
661 [AZX_DRIVER_CTX
] = "HDA Creative",
662 [AZX_DRIVER_CTHDA
] = "HDA Creative",
663 [AZX_DRIVER_GENERIC
] = "HD-Audio Generic",
667 * macros for easy use
669 #define azx_writel(chip,reg,value) \
670 writel(value, (chip)->remap_addr + ICH6_REG_##reg)
671 #define azx_readl(chip,reg) \
672 readl((chip)->remap_addr + ICH6_REG_##reg)
673 #define azx_writew(chip,reg,value) \
674 writew(value, (chip)->remap_addr + ICH6_REG_##reg)
675 #define azx_readw(chip,reg) \
676 readw((chip)->remap_addr + ICH6_REG_##reg)
677 #define azx_writeb(chip,reg,value) \
678 writeb(value, (chip)->remap_addr + ICH6_REG_##reg)
679 #define azx_readb(chip,reg) \
680 readb((chip)->remap_addr + ICH6_REG_##reg)
682 #define azx_sd_writel(dev,reg,value) \
683 writel(value, (dev)->sd_addr + ICH6_REG_##reg)
684 #define azx_sd_readl(dev,reg) \
685 readl((dev)->sd_addr + ICH6_REG_##reg)
686 #define azx_sd_writew(dev,reg,value) \
687 writew(value, (dev)->sd_addr + ICH6_REG_##reg)
688 #define azx_sd_readw(dev,reg) \
689 readw((dev)->sd_addr + ICH6_REG_##reg)
690 #define azx_sd_writeb(dev,reg,value) \
691 writeb(value, (dev)->sd_addr + ICH6_REG_##reg)
692 #define azx_sd_readb(dev,reg) \
693 readb((dev)->sd_addr + ICH6_REG_##reg)
695 /* for pcm support */
696 #define get_azx_dev(substream) (substream->runtime->private_data)
699 static void __mark_pages_wc(struct azx
*chip
, struct snd_dma_buffer
*dmab
, bool on
)
705 if (!dmab
|| !dmab
->area
|| !dmab
->bytes
)
708 #ifdef CONFIG_SND_DMA_SGBUF
709 if (dmab
->dev
.type
== SNDRV_DMA_TYPE_DEV_SG
) {
710 struct snd_sg_buf
*sgbuf
= dmab
->private_data
;
712 set_pages_array_wc(sgbuf
->page_table
, sgbuf
->pages
);
714 set_pages_array_wb(sgbuf
->page_table
, sgbuf
->pages
);
719 pages
= (dmab
->bytes
+ PAGE_SIZE
- 1) >> PAGE_SHIFT
;
721 set_memory_wc((unsigned long)dmab
->area
, pages
);
723 set_memory_wb((unsigned long)dmab
->area
, pages
);
726 static inline void mark_pages_wc(struct azx
*chip
, struct snd_dma_buffer
*buf
,
729 __mark_pages_wc(chip
, buf
, on
);
731 static inline void mark_runtime_wc(struct azx
*chip
, struct azx_dev
*azx_dev
,
732 struct snd_pcm_substream
*substream
, bool on
)
734 if (azx_dev
->wc_marked
!= on
) {
735 __mark_pages_wc(chip
, snd_pcm_get_dma_buf(substream
), on
);
736 azx_dev
->wc_marked
= on
;
740 /* NOP for other archs */
741 static inline void mark_pages_wc(struct azx
*chip
, struct snd_dma_buffer
*buf
,
745 static inline void mark_runtime_wc(struct azx
*chip
, struct azx_dev
*azx_dev
,
746 struct snd_pcm_substream
*substream
, bool on
)
751 static int azx_acquire_irq(struct azx
*chip
, int do_disconnect
);
752 static int azx_send_cmd(struct hda_bus
*bus
, unsigned int val
);
754 * Interface for HD codec
758 * CORB / RIRB interface
760 static int azx_alloc_cmd_io(struct azx
*chip
)
764 /* single page (at least 4096 bytes) must suffice for both ringbuffes */
765 err
= snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV
,
766 snd_dma_pci_data(chip
->pci
),
767 PAGE_SIZE
, &chip
->rb
);
769 snd_printk(KERN_ERR SFX
"%s: cannot allocate CORB/RIRB\n", pci_name(chip
->pci
));
772 mark_pages_wc(chip
, &chip
->rb
, true);
776 static void azx_init_cmd_io(struct azx
*chip
)
778 spin_lock_irq(&chip
->reg_lock
);
780 chip
->corb
.addr
= chip
->rb
.addr
;
781 chip
->corb
.buf
= (u32
*)chip
->rb
.area
;
782 azx_writel(chip
, CORBLBASE
, (u32
)chip
->corb
.addr
);
783 azx_writel(chip
, CORBUBASE
, upper_32_bits(chip
->corb
.addr
));
785 /* set the corb size to 256 entries (ULI requires explicitly) */
786 azx_writeb(chip
, CORBSIZE
, 0x02);
787 /* set the corb write pointer to 0 */
788 azx_writew(chip
, CORBWP
, 0);
789 /* reset the corb hw read pointer */
790 azx_writew(chip
, CORBRP
, ICH6_CORBRP_RST
);
791 /* enable corb dma */
792 azx_writeb(chip
, CORBCTL
, ICH6_CORBCTL_RUN
);
795 chip
->rirb
.addr
= chip
->rb
.addr
+ 2048;
796 chip
->rirb
.buf
= (u32
*)(chip
->rb
.area
+ 2048);
797 chip
->rirb
.wp
= chip
->rirb
.rp
= 0;
798 memset(chip
->rirb
.cmds
, 0, sizeof(chip
->rirb
.cmds
));
799 azx_writel(chip
, RIRBLBASE
, (u32
)chip
->rirb
.addr
);
800 azx_writel(chip
, RIRBUBASE
, upper_32_bits(chip
->rirb
.addr
));
802 /* set the rirb size to 256 entries (ULI requires explicitly) */
803 azx_writeb(chip
, RIRBSIZE
, 0x02);
804 /* reset the rirb hw write pointer */
805 azx_writew(chip
, RIRBWP
, ICH6_RIRBWP_RST
);
806 /* set N=1, get RIRB response interrupt for new entry */
807 if (chip
->driver_caps
& AZX_DCAPS_CTX_WORKAROUND
)
808 azx_writew(chip
, RINTCNT
, 0xc0);
810 azx_writew(chip
, RINTCNT
, 1);
811 /* enable rirb dma and response irq */
812 azx_writeb(chip
, RIRBCTL
, ICH6_RBCTL_DMA_EN
| ICH6_RBCTL_IRQ_EN
);
813 spin_unlock_irq(&chip
->reg_lock
);
816 static void azx_free_cmd_io(struct azx
*chip
)
818 spin_lock_irq(&chip
->reg_lock
);
819 /* disable ringbuffer DMAs */
820 azx_writeb(chip
, RIRBCTL
, 0);
821 azx_writeb(chip
, CORBCTL
, 0);
822 spin_unlock_irq(&chip
->reg_lock
);
825 static unsigned int azx_command_addr(u32 cmd
)
827 unsigned int addr
= cmd
>> 28;
829 if (addr
>= AZX_MAX_CODECS
) {
837 static unsigned int azx_response_addr(u32 res
)
839 unsigned int addr
= res
& 0xf;
841 if (addr
>= AZX_MAX_CODECS
) {
850 static int azx_corb_send_cmd(struct hda_bus
*bus
, u32 val
)
852 struct azx
*chip
= bus
->private_data
;
853 unsigned int addr
= azx_command_addr(val
);
856 spin_lock_irq(&chip
->reg_lock
);
858 /* add command to corb */
859 wp
= azx_readw(chip
, CORBWP
);
861 /* something wrong, controller likely turned to D3 */
862 spin_unlock_irq(&chip
->reg_lock
);
866 wp
%= ICH6_MAX_CORB_ENTRIES
;
868 rp
= azx_readw(chip
, CORBRP
);
870 /* oops, it's full */
871 spin_unlock_irq(&chip
->reg_lock
);
875 chip
->rirb
.cmds
[addr
]++;
876 chip
->corb
.buf
[wp
] = cpu_to_le32(val
);
877 azx_writel(chip
, CORBWP
, wp
);
879 spin_unlock_irq(&chip
->reg_lock
);
884 #define ICH6_RIRB_EX_UNSOL_EV (1<<4)
886 /* retrieve RIRB entry - called from interrupt handler */
887 static void azx_update_rirb(struct azx
*chip
)
893 wp
= azx_readw(chip
, RIRBWP
);
895 /* something wrong, controller likely turned to D3 */
899 if (wp
== chip
->rirb
.wp
)
903 while (chip
->rirb
.rp
!= wp
) {
905 chip
->rirb
.rp
%= ICH6_MAX_RIRB_ENTRIES
;
907 rp
= chip
->rirb
.rp
<< 1; /* an RIRB entry is 8-bytes */
908 res_ex
= le32_to_cpu(chip
->rirb
.buf
[rp
+ 1]);
909 res
= le32_to_cpu(chip
->rirb
.buf
[rp
]);
910 addr
= azx_response_addr(res_ex
);
911 if (res_ex
& ICH6_RIRB_EX_UNSOL_EV
)
912 snd_hda_queue_unsol_event(chip
->bus
, res
, res_ex
);
913 else if (chip
->rirb
.cmds
[addr
]) {
914 chip
->rirb
.res
[addr
] = res
;
916 chip
->rirb
.cmds
[addr
]--;
917 } else if (printk_ratelimit()) {
918 snd_printk(KERN_ERR SFX
"%s: spurious response %#x:%#x, last cmd=%#08x\n",
921 chip
->last_cmd
[addr
]);
926 /* receive a response */
927 static unsigned int azx_rirb_get_response(struct hda_bus
*bus
,
930 struct azx
*chip
= bus
->private_data
;
931 unsigned long timeout
;
932 unsigned long loopcounter
;
936 timeout
= jiffies
+ msecs_to_jiffies(1000);
938 for (loopcounter
= 0;; loopcounter
++) {
939 if (chip
->polling_mode
|| do_poll
) {
940 spin_lock_irq(&chip
->reg_lock
);
941 azx_update_rirb(chip
);
942 spin_unlock_irq(&chip
->reg_lock
);
944 if (!chip
->rirb
.cmds
[addr
]) {
949 chip
->poll_count
= 0;
950 return chip
->rirb
.res
[addr
]; /* the last value */
952 if (time_after(jiffies
, timeout
))
954 if (bus
->needs_damn_long_delay
|| loopcounter
> 3000)
955 msleep(2); /* temporary workaround */
962 if (!bus
->no_response_fallback
)
965 if (!chip
->polling_mode
&& chip
->poll_count
< 2) {
966 snd_printdd(SFX
"%s: azx_get_response timeout, "
967 "polling the codec once: last cmd=0x%08x\n",
968 pci_name(chip
->pci
), chip
->last_cmd
[addr
]);
975 if (!chip
->polling_mode
) {
976 snd_printk(KERN_WARNING SFX
"%s: azx_get_response timeout, "
977 "switching to polling mode: last cmd=0x%08x\n",
978 pci_name(chip
->pci
), chip
->last_cmd
[addr
]);
979 chip
->polling_mode
= 1;
984 snd_printk(KERN_WARNING SFX
"%s: No response from codec, "
985 "disabling MSI: last cmd=0x%08x\n",
986 pci_name(chip
->pci
), chip
->last_cmd
[addr
]);
987 free_irq(chip
->irq
, chip
);
989 pci_disable_msi(chip
->pci
);
991 if (azx_acquire_irq(chip
, 1) < 0) {
999 /* If this critical timeout happens during the codec probing
1000 * phase, this is likely an access to a non-existing codec
1001 * slot. Better to return an error and reset the system.
1006 /* a fatal communication error; need either to reset or to fallback
1007 * to the single_cmd mode
1009 bus
->rirb_error
= 1;
1010 if (bus
->allow_bus_reset
&& !bus
->response_reset
&& !bus
->in_reset
) {
1011 bus
->response_reset
= 1;
1012 return -1; /* give a chance to retry */
1015 snd_printk(KERN_ERR
"hda_intel: azx_get_response timeout, "
1016 "switching to single_cmd mode: last cmd=0x%08x\n",
1017 chip
->last_cmd
[addr
]);
1018 chip
->single_cmd
= 1;
1019 bus
->response_reset
= 0;
1020 /* release CORB/RIRB */
1021 azx_free_cmd_io(chip
);
1022 /* disable unsolicited responses */
1023 azx_writel(chip
, GCTL
, azx_readl(chip
, GCTL
) & ~ICH6_GCTL_UNSOL
);
1028 * Use the single immediate command instead of CORB/RIRB for simplicity
1030 * Note: according to Intel, this is not preferred use. The command was
1031 * intended for the BIOS only, and may get confused with unsolicited
1032 * responses. So, we shouldn't use it for normal operation from the
1034 * I left the codes, however, for debugging/testing purposes.
1037 /* receive a response */
1038 static int azx_single_wait_for_response(struct azx
*chip
, unsigned int addr
)
1043 /* check IRV busy bit */
1044 if (azx_readw(chip
, IRS
) & ICH6_IRS_VALID
) {
1045 /* reuse rirb.res as the response return value */
1046 chip
->rirb
.res
[addr
] = azx_readl(chip
, IR
);
1051 if (printk_ratelimit())
1052 snd_printd(SFX
"%s: get_response timeout: IRS=0x%x\n",
1053 pci_name(chip
->pci
), azx_readw(chip
, IRS
));
1054 chip
->rirb
.res
[addr
] = -1;
1058 /* send a command */
1059 static int azx_single_send_cmd(struct hda_bus
*bus
, u32 val
)
1061 struct azx
*chip
= bus
->private_data
;
1062 unsigned int addr
= azx_command_addr(val
);
1065 bus
->rirb_error
= 0;
1067 /* check ICB busy bit */
1068 if (!((azx_readw(chip
, IRS
) & ICH6_IRS_BUSY
))) {
1069 /* Clear IRV valid bit */
1070 azx_writew(chip
, IRS
, azx_readw(chip
, IRS
) |
1072 azx_writel(chip
, IC
, val
);
1073 azx_writew(chip
, IRS
, azx_readw(chip
, IRS
) |
1075 return azx_single_wait_for_response(chip
, addr
);
1079 if (printk_ratelimit())
1080 snd_printd(SFX
"%s: send_cmd timeout: IRS=0x%x, val=0x%x\n",
1081 pci_name(chip
->pci
), azx_readw(chip
, IRS
), val
);
1085 /* receive a response */
1086 static unsigned int azx_single_get_response(struct hda_bus
*bus
,
1089 struct azx
*chip
= bus
->private_data
;
1090 return chip
->rirb
.res
[addr
];
1094 * The below are the main callbacks from hda_codec.
1096 * They are just the skeleton to call sub-callbacks according to the
1097 * current setting of chip->single_cmd.
1100 /* send a command */
1101 static int azx_send_cmd(struct hda_bus
*bus
, unsigned int val
)
1103 struct azx
*chip
= bus
->private_data
;
1107 chip
->last_cmd
[azx_command_addr(val
)] = val
;
1108 if (chip
->single_cmd
)
1109 return azx_single_send_cmd(bus
, val
);
1111 return azx_corb_send_cmd(bus
, val
);
1114 /* get a response */
1115 static unsigned int azx_get_response(struct hda_bus
*bus
,
1118 struct azx
*chip
= bus
->private_data
;
1121 if (chip
->single_cmd
)
1122 return azx_single_get_response(bus
, addr
);
1124 return azx_rirb_get_response(bus
, addr
);
1128 static void azx_power_notify(struct hda_bus
*bus
, bool power_up
);
1131 #ifdef CONFIG_SND_HDA_DSP_LOADER
1132 static int azx_load_dsp_prepare(struct hda_bus
*bus
, unsigned int format
,
1133 unsigned int byte_size
,
1134 struct snd_dma_buffer
*bufp
);
1135 static void azx_load_dsp_trigger(struct hda_bus
*bus
, bool start
);
1136 static void azx_load_dsp_cleanup(struct hda_bus
*bus
,
1137 struct snd_dma_buffer
*dmab
);
1140 /* enter link reset */
1141 static void azx_enter_link_reset(struct azx
*chip
)
1143 unsigned long timeout
;
1145 /* reset controller */
1146 azx_writel(chip
, GCTL
, azx_readl(chip
, GCTL
) & ~ICH6_GCTL_RESET
);
1148 timeout
= jiffies
+ msecs_to_jiffies(100);
1149 while ((azx_readb(chip
, GCTL
) & ICH6_GCTL_RESET
) &&
1150 time_before(jiffies
, timeout
))
1151 usleep_range(500, 1000);
1154 /* exit link reset */
1155 static void azx_exit_link_reset(struct azx
*chip
)
1157 unsigned long timeout
;
1159 azx_writeb(chip
, GCTL
, azx_readb(chip
, GCTL
) | ICH6_GCTL_RESET
);
1161 timeout
= jiffies
+ msecs_to_jiffies(100);
1162 while (!azx_readb(chip
, GCTL
) &&
1163 time_before(jiffies
, timeout
))
1164 usleep_range(500, 1000);
1167 /* reset codec link */
1168 static int azx_reset(struct azx
*chip
, int full_reset
)
1173 /* clear STATESTS */
1174 azx_writew(chip
, STATESTS
, STATESTS_INT_MASK
);
1176 /* reset controller */
1177 azx_enter_link_reset(chip
);
1179 /* delay for >= 100us for codec PLL to settle per spec
1180 * Rev 0.9 section 5.5.1
1182 usleep_range(500, 1000);
1184 /* Bring controller out of reset */
1185 azx_exit_link_reset(chip
);
1187 /* Brent Chartrand said to wait >= 540us for codecs to initialize */
1188 usleep_range(1000, 1200);
1191 /* check to see if controller is ready */
1192 if (!azx_readb(chip
, GCTL
)) {
1193 snd_printd(SFX
"%s: azx_reset: controller not ready!\n", pci_name(chip
->pci
));
1197 /* Accept unsolicited responses */
1198 if (!chip
->single_cmd
)
1199 azx_writel(chip
, GCTL
, azx_readl(chip
, GCTL
) |
1203 if (!chip
->codec_mask
) {
1204 chip
->codec_mask
= azx_readw(chip
, STATESTS
);
1205 snd_printdd(SFX
"%s: codec_mask = 0x%x\n", pci_name(chip
->pci
), chip
->codec_mask
);
1213 * Lowlevel interface
1216 /* enable interrupts */
1217 static void azx_int_enable(struct azx
*chip
)
1219 /* enable controller CIE and GIE */
1220 azx_writel(chip
, INTCTL
, azx_readl(chip
, INTCTL
) |
1221 ICH6_INT_CTRL_EN
| ICH6_INT_GLOBAL_EN
);
1224 /* disable interrupts */
1225 static void azx_int_disable(struct azx
*chip
)
1229 /* disable interrupts in stream descriptor */
1230 for (i
= 0; i
< chip
->num_streams
; i
++) {
1231 struct azx_dev
*azx_dev
= &chip
->azx_dev
[i
];
1232 azx_sd_writeb(azx_dev
, SD_CTL
,
1233 azx_sd_readb(azx_dev
, SD_CTL
) & ~SD_INT_MASK
);
1236 /* disable SIE for all streams */
1237 azx_writeb(chip
, INTCTL
, 0);
1239 /* disable controller CIE and GIE */
1240 azx_writel(chip
, INTCTL
, azx_readl(chip
, INTCTL
) &
1241 ~(ICH6_INT_CTRL_EN
| ICH6_INT_GLOBAL_EN
));
1244 /* clear interrupts */
1245 static void azx_int_clear(struct azx
*chip
)
1249 /* clear stream status */
1250 for (i
= 0; i
< chip
->num_streams
; i
++) {
1251 struct azx_dev
*azx_dev
= &chip
->azx_dev
[i
];
1252 azx_sd_writeb(azx_dev
, SD_STS
, SD_INT_MASK
);
1255 /* clear STATESTS */
1256 azx_writew(chip
, STATESTS
, STATESTS_INT_MASK
);
1258 /* clear rirb status */
1259 azx_writeb(chip
, RIRBSTS
, RIRB_INT_MASK
);
1261 /* clear int status */
1262 azx_writel(chip
, INTSTS
, ICH6_INT_CTRL_EN
| ICH6_INT_ALL_STREAM
);
1265 /* start a stream */
1266 static void azx_stream_start(struct azx
*chip
, struct azx_dev
*azx_dev
)
1269 * Before stream start, initialize parameter
1271 azx_dev
->insufficient
= 1;
1274 azx_writel(chip
, INTCTL
,
1275 azx_readl(chip
, INTCTL
) | (1 << azx_dev
->index
));
1276 /* set DMA start and interrupt mask */
1277 azx_sd_writeb(azx_dev
, SD_CTL
, azx_sd_readb(azx_dev
, SD_CTL
) |
1278 SD_CTL_DMA_START
| SD_INT_MASK
);
1282 static void azx_stream_clear(struct azx
*chip
, struct azx_dev
*azx_dev
)
1284 azx_sd_writeb(azx_dev
, SD_CTL
, azx_sd_readb(azx_dev
, SD_CTL
) &
1285 ~(SD_CTL_DMA_START
| SD_INT_MASK
));
1286 azx_sd_writeb(azx_dev
, SD_STS
, SD_INT_MASK
); /* to be sure */
1290 static void azx_stream_stop(struct azx
*chip
, struct azx_dev
*azx_dev
)
1292 azx_stream_clear(chip
, azx_dev
);
1294 azx_writel(chip
, INTCTL
,
1295 azx_readl(chip
, INTCTL
) & ~(1 << azx_dev
->index
));
1300 * reset and start the controller registers
1302 static void azx_init_chip(struct azx
*chip
, int full_reset
)
1304 if (chip
->initialized
)
1307 /* reset controller */
1308 azx_reset(chip
, full_reset
);
1310 /* initialize interrupts */
1311 azx_int_clear(chip
);
1312 azx_int_enable(chip
);
1314 /* initialize the codec command I/O */
1315 if (!chip
->single_cmd
)
1316 azx_init_cmd_io(chip
);
1318 /* program the position buffer */
1319 azx_writel(chip
, DPLBASE
, (u32
)chip
->posbuf
.addr
);
1320 azx_writel(chip
, DPUBASE
, upper_32_bits(chip
->posbuf
.addr
));
1322 chip
->initialized
= 1;
1326 * initialize the PCI registers
1328 /* update bits in a PCI register byte */
1329 static void update_pci_byte(struct pci_dev
*pci
, unsigned int reg
,
1330 unsigned char mask
, unsigned char val
)
1334 pci_read_config_byte(pci
, reg
, &data
);
1336 data
|= (val
& mask
);
1337 pci_write_config_byte(pci
, reg
, data
);
1340 static void azx_init_pci(struct azx
*chip
)
1342 /* Clear bits 0-2 of PCI register TCSEL (at offset 0x44)
1343 * TCSEL == Traffic Class Select Register, which sets PCI express QOS
1344 * Ensuring these bits are 0 clears playback static on some HD Audio
1346 * The PCI register TCSEL is defined in the Intel manuals.
1348 if (!(chip
->driver_caps
& AZX_DCAPS_NO_TCSEL
)) {
1349 snd_printdd(SFX
"%s: Clearing TCSEL\n", pci_name(chip
->pci
));
1350 update_pci_byte(chip
->pci
, ICH6_PCIREG_TCSEL
, 0x07, 0);
1353 /* For ATI SB450/600/700/800/900 and AMD Hudson azalia HD audio,
1354 * we need to enable snoop.
1356 if (chip
->driver_caps
& AZX_DCAPS_ATI_SNOOP
) {
1357 snd_printdd(SFX
"%s: Setting ATI snoop: %d\n", pci_name(chip
->pci
), azx_snoop(chip
));
1358 update_pci_byte(chip
->pci
,
1359 ATI_SB450_HDAUDIO_MISC_CNTR2_ADDR
, 0x07,
1360 azx_snoop(chip
) ? ATI_SB450_HDAUDIO_ENABLE_SNOOP
: 0);
1363 /* For NVIDIA HDA, enable snoop */
1364 if (chip
->driver_caps
& AZX_DCAPS_NVIDIA_SNOOP
) {
1365 snd_printdd(SFX
"%s: Setting Nvidia snoop: %d\n", pci_name(chip
->pci
), azx_snoop(chip
));
1366 update_pci_byte(chip
->pci
,
1367 NVIDIA_HDA_TRANSREG_ADDR
,
1368 0x0f, NVIDIA_HDA_ENABLE_COHBITS
);
1369 update_pci_byte(chip
->pci
,
1370 NVIDIA_HDA_ISTRM_COH
,
1371 0x01, NVIDIA_HDA_ENABLE_COHBIT
);
1372 update_pci_byte(chip
->pci
,
1373 NVIDIA_HDA_OSTRM_COH
,
1374 0x01, NVIDIA_HDA_ENABLE_COHBIT
);
1377 /* Enable SCH/PCH snoop if needed */
1378 if (chip
->driver_caps
& AZX_DCAPS_SCH_SNOOP
) {
1379 unsigned short snoop
;
1380 pci_read_config_word(chip
->pci
, INTEL_SCH_HDA_DEVC
, &snoop
);
1381 if ((!azx_snoop(chip
) && !(snoop
& INTEL_SCH_HDA_DEVC_NOSNOOP
)) ||
1382 (azx_snoop(chip
) && (snoop
& INTEL_SCH_HDA_DEVC_NOSNOOP
))) {
1383 snoop
&= ~INTEL_SCH_HDA_DEVC_NOSNOOP
;
1384 if (!azx_snoop(chip
))
1385 snoop
|= INTEL_SCH_HDA_DEVC_NOSNOOP
;
1386 pci_write_config_word(chip
->pci
, INTEL_SCH_HDA_DEVC
, snoop
);
1387 pci_read_config_word(chip
->pci
,
1388 INTEL_SCH_HDA_DEVC
, &snoop
);
1390 snd_printdd(SFX
"%s: SCH snoop: %s\n",
1391 pci_name(chip
->pci
), (snoop
& INTEL_SCH_HDA_DEVC_NOSNOOP
)
1392 ? "Disabled" : "Enabled");
1397 static int azx_position_ok(struct azx
*chip
, struct azx_dev
*azx_dev
);
1402 static irqreturn_t
azx_interrupt(int irq
, void *dev_id
)
1404 struct azx
*chip
= dev_id
;
1405 struct azx_dev
*azx_dev
;
1410 #ifdef CONFIG_PM_RUNTIME
1411 if (chip
->driver_caps
& AZX_DCAPS_PM_RUNTIME
)
1412 if (chip
->pci
->dev
.power
.runtime_status
!= RPM_ACTIVE
)
1416 spin_lock(&chip
->reg_lock
);
1418 if (chip
->disabled
) {
1419 spin_unlock(&chip
->reg_lock
);
1423 status
= azx_readl(chip
, INTSTS
);
1424 if (status
== 0 || status
== 0xffffffff) {
1425 spin_unlock(&chip
->reg_lock
);
1429 for (i
= 0; i
< chip
->num_streams
; i
++) {
1430 azx_dev
= &chip
->azx_dev
[i
];
1431 if (status
& azx_dev
->sd_int_sta_mask
) {
1432 sd_status
= azx_sd_readb(azx_dev
, SD_STS
);
1433 azx_sd_writeb(azx_dev
, SD_STS
, SD_INT_MASK
);
1434 if (!azx_dev
->substream
|| !azx_dev
->running
||
1435 !(sd_status
& SD_INT_COMPLETE
))
1437 /* check whether this IRQ is really acceptable */
1438 ok
= azx_position_ok(chip
, azx_dev
);
1440 azx_dev
->irq_pending
= 0;
1441 spin_unlock(&chip
->reg_lock
);
1442 snd_pcm_period_elapsed(azx_dev
->substream
);
1443 spin_lock(&chip
->reg_lock
);
1444 } else if (ok
== 0 && chip
->bus
&& chip
->bus
->workq
) {
1445 /* bogus IRQ, process it later */
1446 azx_dev
->irq_pending
= 1;
1447 queue_work(chip
->bus
->workq
,
1448 &chip
->irq_pending_work
);
1453 /* clear rirb int */
1454 status
= azx_readb(chip
, RIRBSTS
);
1455 if (status
& RIRB_INT_MASK
) {
1456 if (status
& RIRB_INT_RESPONSE
) {
1457 if (chip
->driver_caps
& AZX_DCAPS_RIRB_PRE_DELAY
)
1459 azx_update_rirb(chip
);
1461 azx_writeb(chip
, RIRBSTS
, RIRB_INT_MASK
);
1465 /* clear state status int */
1466 if (azx_readw(chip
, STATESTS
) & 0x04)
1467 azx_writew(chip
, STATESTS
, 0x04);
1469 spin_unlock(&chip
->reg_lock
);
1476 * set up a BDL entry
1478 static int setup_bdle(struct azx
*chip
,
1479 struct snd_dma_buffer
*dmab
,
1480 struct azx_dev
*azx_dev
, u32
**bdlp
,
1481 int ofs
, int size
, int with_ioc
)
1489 if (azx_dev
->frags
>= AZX_MAX_BDL_ENTRIES
)
1492 addr
= snd_sgbuf_get_addr(dmab
, ofs
);
1493 /* program the address field of the BDL entry */
1494 bdl
[0] = cpu_to_le32((u32
)addr
);
1495 bdl
[1] = cpu_to_le32(upper_32_bits(addr
));
1496 /* program the size field of the BDL entry */
1497 chunk
= snd_sgbuf_get_chunk_size(dmab
, ofs
, size
);
1498 /* one BDLE cannot cross 4K boundary on CTHDA chips */
1499 if (chip
->driver_caps
& AZX_DCAPS_4K_BDLE_BOUNDARY
) {
1500 u32 remain
= 0x1000 - (ofs
& 0xfff);
1504 bdl
[2] = cpu_to_le32(chunk
);
1505 /* program the IOC to enable interrupt
1506 * only when the whole fragment is processed
1509 bdl
[3] = (size
|| !with_ioc
) ? 0 : cpu_to_le32(0x01);
1519 * set up BDL entries
1521 static int azx_setup_periods(struct azx
*chip
,
1522 struct snd_pcm_substream
*substream
,
1523 struct azx_dev
*azx_dev
)
1526 int i
, ofs
, periods
, period_bytes
;
1529 /* reset BDL address */
1530 azx_sd_writel(azx_dev
, SD_BDLPL
, 0);
1531 azx_sd_writel(azx_dev
, SD_BDLPU
, 0);
1533 period_bytes
= azx_dev
->period_bytes
;
1534 periods
= azx_dev
->bufsize
/ period_bytes
;
1536 /* program the initial BDL entries */
1537 bdl
= (u32
*)azx_dev
->bdl
.area
;
1540 pos_adj
= bdl_pos_adj
[chip
->dev_index
];
1541 if (!azx_dev
->no_period_wakeup
&& pos_adj
> 0) {
1542 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
1543 int pos_align
= pos_adj
;
1544 pos_adj
= (pos_adj
* runtime
->rate
+ 47999) / 48000;
1546 pos_adj
= pos_align
;
1548 pos_adj
= ((pos_adj
+ pos_align
- 1) / pos_align
) *
1550 pos_adj
= frames_to_bytes(runtime
, pos_adj
);
1551 if (pos_adj
>= period_bytes
) {
1552 snd_printk(KERN_WARNING SFX
"%s: Too big adjustment %d\n",
1553 pci_name(chip
->pci
), bdl_pos_adj
[chip
->dev_index
]);
1556 ofs
= setup_bdle(chip
, snd_pcm_get_dma_buf(substream
),
1558 &bdl
, ofs
, pos_adj
, true);
1564 for (i
= 0; i
< periods
; i
++) {
1565 if (i
== periods
- 1 && pos_adj
)
1566 ofs
= setup_bdle(chip
, snd_pcm_get_dma_buf(substream
),
1568 period_bytes
- pos_adj
, 0);
1570 ofs
= setup_bdle(chip
, snd_pcm_get_dma_buf(substream
),
1573 !azx_dev
->no_period_wakeup
);
1580 snd_printk(KERN_ERR SFX
"%s: Too many BDL entries: buffer=%d, period=%d\n",
1581 pci_name(chip
->pci
), azx_dev
->bufsize
, period_bytes
);
1586 static void azx_stream_reset(struct azx
*chip
, struct azx_dev
*azx_dev
)
1591 azx_stream_clear(chip
, azx_dev
);
1593 azx_sd_writeb(azx_dev
, SD_CTL
, azx_sd_readb(azx_dev
, SD_CTL
) |
1594 SD_CTL_STREAM_RESET
);
1597 while (!((val
= azx_sd_readb(azx_dev
, SD_CTL
)) & SD_CTL_STREAM_RESET
) &&
1600 val
&= ~SD_CTL_STREAM_RESET
;
1601 azx_sd_writeb(azx_dev
, SD_CTL
, val
);
1605 /* waiting for hardware to report that the stream is out of reset */
1606 while (((val
= azx_sd_readb(azx_dev
, SD_CTL
)) & SD_CTL_STREAM_RESET
) &&
1610 /* reset first position - may not be synced with hw at this time */
1611 *azx_dev
->posbuf
= 0;
1615 * set up the SD for streaming
1617 static int azx_setup_controller(struct azx
*chip
, struct azx_dev
*azx_dev
)
1620 /* make sure the run bit is zero for SD */
1621 azx_stream_clear(chip
, azx_dev
);
1622 /* program the stream_tag */
1623 val
= azx_sd_readl(azx_dev
, SD_CTL
);
1624 val
= (val
& ~SD_CTL_STREAM_TAG_MASK
) |
1625 (azx_dev
->stream_tag
<< SD_CTL_STREAM_TAG_SHIFT
);
1626 if (!azx_snoop(chip
))
1627 val
|= SD_CTL_TRAFFIC_PRIO
;
1628 azx_sd_writel(azx_dev
, SD_CTL
, val
);
1630 /* program the length of samples in cyclic buffer */
1631 azx_sd_writel(azx_dev
, SD_CBL
, azx_dev
->bufsize
);
1633 /* program the stream format */
1634 /* this value needs to be the same as the one programmed */
1635 azx_sd_writew(azx_dev
, SD_FORMAT
, azx_dev
->format_val
);
1637 /* program the stream LVI (last valid index) of the BDL */
1638 azx_sd_writew(azx_dev
, SD_LVI
, azx_dev
->frags
- 1);
1640 /* program the BDL address */
1641 /* lower BDL address */
1642 azx_sd_writel(azx_dev
, SD_BDLPL
, (u32
)azx_dev
->bdl
.addr
);
1643 /* upper BDL address */
1644 azx_sd_writel(azx_dev
, SD_BDLPU
, upper_32_bits(azx_dev
->bdl
.addr
));
1646 /* enable the position buffer */
1647 if (chip
->position_fix
[0] != POS_FIX_LPIB
||
1648 chip
->position_fix
[1] != POS_FIX_LPIB
) {
1649 if (!(azx_readl(chip
, DPLBASE
) & ICH6_DPLBASE_ENABLE
))
1650 azx_writel(chip
, DPLBASE
,
1651 (u32
)chip
->posbuf
.addr
| ICH6_DPLBASE_ENABLE
);
1654 /* set the interrupt enable bits in the descriptor control register */
1655 azx_sd_writel(azx_dev
, SD_CTL
,
1656 azx_sd_readl(azx_dev
, SD_CTL
) | SD_INT_MASK
);
1662 * Probe the given codec address
1664 static int probe_codec(struct azx
*chip
, int addr
)
1666 unsigned int cmd
= (addr
<< 28) | (AC_NODE_ROOT
<< 20) |
1667 (AC_VERB_PARAMETERS
<< 8) | AC_PAR_VENDOR_ID
;
1670 mutex_lock(&chip
->bus
->cmd_mutex
);
1672 azx_send_cmd(chip
->bus
, cmd
);
1673 res
= azx_get_response(chip
->bus
, addr
);
1675 mutex_unlock(&chip
->bus
->cmd_mutex
);
1678 snd_printdd(SFX
"%s: codec #%d probed OK\n", pci_name(chip
->pci
), addr
);
1682 static int azx_attach_pcm_stream(struct hda_bus
*bus
, struct hda_codec
*codec
,
1683 struct hda_pcm
*cpcm
);
1684 static void azx_stop_chip(struct azx
*chip
);
1686 static void azx_bus_reset(struct hda_bus
*bus
)
1688 struct azx
*chip
= bus
->private_data
;
1691 azx_stop_chip(chip
);
1692 azx_init_chip(chip
, 1);
1694 if (chip
->initialized
) {
1696 list_for_each_entry(p
, &chip
->pcm_list
, list
)
1697 snd_pcm_suspend_all(p
->pcm
);
1698 snd_hda_suspend(chip
->bus
);
1699 snd_hda_resume(chip
->bus
);
1705 static int get_jackpoll_interval(struct azx
*chip
)
1707 int i
= jackpoll_ms
[chip
->dev_index
];
1711 if (i
< 50 || i
> 60000)
1714 j
= msecs_to_jiffies(i
);
1716 snd_printk(KERN_WARNING SFX
1717 "jackpoll_ms value out of range: %d\n", i
);
1722 * Codec initialization
1725 /* number of codec slots for each chipset: 0 = default slots (i.e. 4) */
1726 static unsigned int azx_max_codecs
[AZX_NUM_DRIVERS
] = {
1727 [AZX_DRIVER_NVIDIA
] = 8,
1728 [AZX_DRIVER_TERA
] = 1,
1731 static int azx_codec_create(struct azx
*chip
, const char *model
)
1733 struct hda_bus_template bus_temp
;
1737 memset(&bus_temp
, 0, sizeof(bus_temp
));
1738 bus_temp
.private_data
= chip
;
1739 bus_temp
.modelname
= model
;
1740 bus_temp
.pci
= chip
->pci
;
1741 bus_temp
.ops
.command
= azx_send_cmd
;
1742 bus_temp
.ops
.get_response
= azx_get_response
;
1743 bus_temp
.ops
.attach_pcm
= azx_attach_pcm_stream
;
1744 bus_temp
.ops
.bus_reset
= azx_bus_reset
;
1746 bus_temp
.power_save
= &power_save
;
1747 bus_temp
.ops
.pm_notify
= azx_power_notify
;
1749 #ifdef CONFIG_SND_HDA_DSP_LOADER
1750 bus_temp
.ops
.load_dsp_prepare
= azx_load_dsp_prepare
;
1751 bus_temp
.ops
.load_dsp_trigger
= azx_load_dsp_trigger
;
1752 bus_temp
.ops
.load_dsp_cleanup
= azx_load_dsp_cleanup
;
1755 err
= snd_hda_bus_new(chip
->card
, &bus_temp
, &chip
->bus
);
1759 if (chip
->driver_caps
& AZX_DCAPS_RIRB_DELAY
) {
1760 snd_printd(SFX
"%s: Enable delay in RIRB handling\n", pci_name(chip
->pci
));
1761 chip
->bus
->needs_damn_long_delay
= 1;
1765 max_slots
= azx_max_codecs
[chip
->driver_type
];
1767 max_slots
= AZX_DEFAULT_CODECS
;
1769 /* First try to probe all given codec slots */
1770 for (c
= 0; c
< max_slots
; c
++) {
1771 if ((chip
->codec_mask
& (1 << c
)) & chip
->codec_probe_mask
) {
1772 if (probe_codec(chip
, c
) < 0) {
1773 /* Some BIOSen give you wrong codec addresses
1776 snd_printk(KERN_WARNING SFX
1777 "%s: Codec #%d probe error; "
1778 "disabling it...\n", pci_name(chip
->pci
), c
);
1779 chip
->codec_mask
&= ~(1 << c
);
1780 /* More badly, accessing to a non-existing
1781 * codec often screws up the controller chip,
1782 * and disturbs the further communications.
1783 * Thus if an error occurs during probing,
1784 * better to reset the controller chip to
1785 * get back to the sanity state.
1787 azx_stop_chip(chip
);
1788 azx_init_chip(chip
, 1);
1793 /* AMD chipsets often cause the communication stalls upon certain
1794 * sequence like the pin-detection. It seems that forcing the synced
1795 * access works around the stall. Grrr...
1797 if (chip
->driver_caps
& AZX_DCAPS_SYNC_WRITE
) {
1798 snd_printd(SFX
"%s: Enable sync_write for stable communication\n",
1799 pci_name(chip
->pci
));
1800 chip
->bus
->sync_write
= 1;
1801 chip
->bus
->allow_bus_reset
= 1;
1804 /* Then create codec instances */
1805 for (c
= 0; c
< max_slots
; c
++) {
1806 if ((chip
->codec_mask
& (1 << c
)) & chip
->codec_probe_mask
) {
1807 struct hda_codec
*codec
;
1808 err
= snd_hda_codec_new(chip
->bus
, c
, &codec
);
1811 codec
->jackpoll_interval
= get_jackpoll_interval(chip
);
1812 codec
->beep_mode
= chip
->beep_mode
;
1817 snd_printk(KERN_ERR SFX
"%s: no codecs initialized\n", pci_name(chip
->pci
));
1823 /* configure each codec instance */
1824 static int azx_codec_configure(struct azx
*chip
)
1826 struct hda_codec
*codec
;
1827 list_for_each_entry(codec
, &chip
->bus
->codec_list
, list
) {
1828 snd_hda_codec_configure(codec
);
1838 /* assign a stream for the PCM */
1839 static inline struct azx_dev
*
1840 azx_assign_device(struct azx
*chip
, struct snd_pcm_substream
*substream
)
1843 struct azx_dev
*res
= NULL
;
1844 /* make a non-zero unique key for the substream */
1845 int key
= (substream
->pcm
->device
<< 16) | (substream
->number
<< 2) |
1846 (substream
->stream
+ 1);
1848 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
1849 dev
= chip
->playback_index_offset
;
1850 nums
= chip
->playback_streams
;
1852 dev
= chip
->capture_index_offset
;
1853 nums
= chip
->capture_streams
;
1855 for (i
= 0; i
< nums
; i
++, dev
++) {
1856 struct azx_dev
*azx_dev
= &chip
->azx_dev
[dev
];
1858 if (!azx_dev
->opened
&& !dsp_is_locked(azx_dev
)) {
1860 if (res
->assigned_key
== key
) {
1862 res
->assigned_key
= key
;
1863 dsp_unlock(azx_dev
);
1867 dsp_unlock(azx_dev
);
1872 res
->assigned_key
= key
;
1878 /* release the assigned stream */
1879 static inline void azx_release_device(struct azx_dev
*azx_dev
)
1881 azx_dev
->opened
= 0;
1884 static cycle_t
azx_cc_read(const struct cyclecounter
*cc
)
1886 struct azx_dev
*azx_dev
= container_of(cc
, struct azx_dev
, azx_cc
);
1887 struct snd_pcm_substream
*substream
= azx_dev
->substream
;
1888 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
1889 struct azx
*chip
= apcm
->chip
;
1891 return azx_readl(chip
, WALLCLK
);
1894 static void azx_timecounter_init(struct snd_pcm_substream
*substream
,
1895 bool force
, cycle_t last
)
1897 struct azx_dev
*azx_dev
= get_azx_dev(substream
);
1898 struct timecounter
*tc
= &azx_dev
->azx_tc
;
1899 struct cyclecounter
*cc
= &azx_dev
->azx_cc
;
1902 cc
->read
= azx_cc_read
;
1903 cc
->mask
= CLOCKSOURCE_MASK(32);
1906 * Converting from 24 MHz to ns means applying a 125/3 factor.
1907 * To avoid any saturation issues in intermediate operations,
1908 * the 125 factor is applied first. The division is applied
1909 * last after reading the timecounter value.
1910 * Applying the 1/3 factor as part of the multiplication
1911 * requires at least 20 bits for a decent precision, however
1912 * overflows occur after about 4 hours or less, not a option.
1915 cc
->mult
= 125; /* saturation after 195 years */
1918 nsec
= 0; /* audio time is elapsed time since trigger */
1919 timecounter_init(tc
, cc
, nsec
);
1922 * force timecounter to use predefined value,
1923 * used for synchronized starts
1925 tc
->cycle_last
= last
;
1928 static u64
azx_adjust_codec_delay(struct snd_pcm_substream
*substream
,
1931 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
1932 struct hda_pcm_stream
*hinfo
= apcm
->hinfo
[substream
->stream
];
1933 u64 codec_frames
, codec_nsecs
;
1935 if (!hinfo
->ops
.get_delay
)
1938 codec_frames
= hinfo
->ops
.get_delay(hinfo
, apcm
->codec
, substream
);
1939 codec_nsecs
= div_u64(codec_frames
* 1000000000LL,
1940 substream
->runtime
->rate
);
1942 if (substream
->stream
== SNDRV_PCM_STREAM_CAPTURE
)
1943 return nsec
+ codec_nsecs
;
1945 return (nsec
> codec_nsecs
) ? nsec
- codec_nsecs
: 0;
1948 static int azx_get_wallclock_tstamp(struct snd_pcm_substream
*substream
,
1949 struct timespec
*ts
)
1951 struct azx_dev
*azx_dev
= get_azx_dev(substream
);
1954 nsec
= timecounter_read(&azx_dev
->azx_tc
);
1955 nsec
= div_u64(nsec
, 3); /* can be optimized */
1956 nsec
= azx_adjust_codec_delay(substream
, nsec
);
1958 *ts
= ns_to_timespec(nsec
);
1963 static struct snd_pcm_hardware azx_pcm_hw
= {
1964 .info
= (SNDRV_PCM_INFO_MMAP
|
1965 SNDRV_PCM_INFO_INTERLEAVED
|
1966 SNDRV_PCM_INFO_BLOCK_TRANSFER
|
1967 SNDRV_PCM_INFO_MMAP_VALID
|
1968 /* No full-resume yet implemented */
1969 /* SNDRV_PCM_INFO_RESUME |*/
1970 SNDRV_PCM_INFO_PAUSE
|
1971 SNDRV_PCM_INFO_SYNC_START
|
1972 SNDRV_PCM_INFO_HAS_WALL_CLOCK
|
1973 SNDRV_PCM_INFO_NO_PERIOD_WAKEUP
),
1974 .formats
= SNDRV_PCM_FMTBIT_S16_LE
,
1975 .rates
= SNDRV_PCM_RATE_48000
,
1980 .buffer_bytes_max
= AZX_MAX_BUF_SIZE
,
1981 .period_bytes_min
= 128,
1982 .period_bytes_max
= AZX_MAX_BUF_SIZE
/ 2,
1984 .periods_max
= AZX_MAX_FRAG
,
1988 static int azx_pcm_open(struct snd_pcm_substream
*substream
)
1990 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
1991 struct hda_pcm_stream
*hinfo
= apcm
->hinfo
[substream
->stream
];
1992 struct azx
*chip
= apcm
->chip
;
1993 struct azx_dev
*azx_dev
;
1994 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
1995 unsigned long flags
;
1999 mutex_lock(&chip
->open_mutex
);
2000 azx_dev
= azx_assign_device(chip
, substream
);
2001 if (azx_dev
== NULL
) {
2002 mutex_unlock(&chip
->open_mutex
);
2005 runtime
->hw
= azx_pcm_hw
;
2006 runtime
->hw
.channels_min
= hinfo
->channels_min
;
2007 runtime
->hw
.channels_max
= hinfo
->channels_max
;
2008 runtime
->hw
.formats
= hinfo
->formats
;
2009 runtime
->hw
.rates
= hinfo
->rates
;
2010 snd_pcm_limit_hw_rates(runtime
);
2011 snd_pcm_hw_constraint_integer(runtime
, SNDRV_PCM_HW_PARAM_PERIODS
);
2013 /* avoid wrap-around with wall-clock */
2014 snd_pcm_hw_constraint_minmax(runtime
, SNDRV_PCM_HW_PARAM_BUFFER_TIME
,
2018 if (chip
->align_buffer_size
)
2019 /* constrain buffer sizes to be multiple of 128
2020 bytes. This is more efficient in terms of memory
2021 access but isn't required by the HDA spec and
2022 prevents users from specifying exact period/buffer
2023 sizes. For example for 44.1kHz, a period size set
2024 to 20ms will be rounded to 19.59ms. */
2027 /* Don't enforce steps on buffer sizes, still need to
2028 be multiple of 4 bytes (HDA spec). Tested on Intel
2029 HDA controllers, may not work on all devices where
2030 option needs to be disabled */
2033 snd_pcm_hw_constraint_step(runtime
, 0, SNDRV_PCM_HW_PARAM_BUFFER_BYTES
,
2035 snd_pcm_hw_constraint_step(runtime
, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES
,
2037 snd_hda_power_up_d3wait(apcm
->codec
);
2038 err
= hinfo
->ops
.open(hinfo
, apcm
->codec
, substream
);
2040 azx_release_device(azx_dev
);
2041 snd_hda_power_down(apcm
->codec
);
2042 mutex_unlock(&chip
->open_mutex
);
2045 snd_pcm_limit_hw_rates(runtime
);
2047 if (snd_BUG_ON(!runtime
->hw
.channels_min
) ||
2048 snd_BUG_ON(!runtime
->hw
.channels_max
) ||
2049 snd_BUG_ON(!runtime
->hw
.formats
) ||
2050 snd_BUG_ON(!runtime
->hw
.rates
)) {
2051 azx_release_device(azx_dev
);
2052 hinfo
->ops
.close(hinfo
, apcm
->codec
, substream
);
2053 snd_hda_power_down(apcm
->codec
);
2054 mutex_unlock(&chip
->open_mutex
);
2058 /* disable WALLCLOCK timestamps for capture streams
2059 until we figure out how to handle digital inputs */
2060 if (substream
->stream
== SNDRV_PCM_STREAM_CAPTURE
)
2061 runtime
->hw
.info
&= ~SNDRV_PCM_INFO_HAS_WALL_CLOCK
;
2063 spin_lock_irqsave(&chip
->reg_lock
, flags
);
2064 azx_dev
->substream
= substream
;
2065 azx_dev
->running
= 0;
2066 spin_unlock_irqrestore(&chip
->reg_lock
, flags
);
2068 runtime
->private_data
= azx_dev
;
2069 snd_pcm_set_sync(substream
);
2070 mutex_unlock(&chip
->open_mutex
);
2074 static int azx_pcm_close(struct snd_pcm_substream
*substream
)
2076 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2077 struct hda_pcm_stream
*hinfo
= apcm
->hinfo
[substream
->stream
];
2078 struct azx
*chip
= apcm
->chip
;
2079 struct azx_dev
*azx_dev
= get_azx_dev(substream
);
2080 unsigned long flags
;
2082 mutex_lock(&chip
->open_mutex
);
2083 spin_lock_irqsave(&chip
->reg_lock
, flags
);
2084 azx_dev
->substream
= NULL
;
2085 azx_dev
->running
= 0;
2086 spin_unlock_irqrestore(&chip
->reg_lock
, flags
);
2087 azx_release_device(azx_dev
);
2088 hinfo
->ops
.close(hinfo
, apcm
->codec
, substream
);
2089 snd_hda_power_down(apcm
->codec
);
2090 mutex_unlock(&chip
->open_mutex
);
2094 static int azx_pcm_hw_params(struct snd_pcm_substream
*substream
,
2095 struct snd_pcm_hw_params
*hw_params
)
2097 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2098 struct azx
*chip
= apcm
->chip
;
2099 struct azx_dev
*azx_dev
= get_azx_dev(substream
);
2103 if (dsp_is_locked(azx_dev
)) {
2108 mark_runtime_wc(chip
, azx_dev
, substream
, false);
2109 azx_dev
->bufsize
= 0;
2110 azx_dev
->period_bytes
= 0;
2111 azx_dev
->format_val
= 0;
2112 ret
= snd_pcm_lib_malloc_pages(substream
,
2113 params_buffer_bytes(hw_params
));
2116 mark_runtime_wc(chip
, azx_dev
, substream
, true);
2118 dsp_unlock(azx_dev
);
2122 static int azx_pcm_hw_free(struct snd_pcm_substream
*substream
)
2124 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2125 struct azx_dev
*azx_dev
= get_azx_dev(substream
);
2126 struct azx
*chip
= apcm
->chip
;
2127 struct hda_pcm_stream
*hinfo
= apcm
->hinfo
[substream
->stream
];
2129 /* reset BDL address */
2131 if (!dsp_is_locked(azx_dev
)) {
2132 azx_sd_writel(azx_dev
, SD_BDLPL
, 0);
2133 azx_sd_writel(azx_dev
, SD_BDLPU
, 0);
2134 azx_sd_writel(azx_dev
, SD_CTL
, 0);
2135 azx_dev
->bufsize
= 0;
2136 azx_dev
->period_bytes
= 0;
2137 azx_dev
->format_val
= 0;
2140 snd_hda_codec_cleanup(apcm
->codec
, hinfo
, substream
);
2142 mark_runtime_wc(chip
, azx_dev
, substream
, false);
2143 azx_dev
->prepared
= 0;
2144 dsp_unlock(azx_dev
);
2145 return snd_pcm_lib_free_pages(substream
);
2148 static int azx_pcm_prepare(struct snd_pcm_substream
*substream
)
2150 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2151 struct azx
*chip
= apcm
->chip
;
2152 struct azx_dev
*azx_dev
= get_azx_dev(substream
);
2153 struct hda_pcm_stream
*hinfo
= apcm
->hinfo
[substream
->stream
];
2154 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
2155 unsigned int bufsize
, period_bytes
, format_val
, stream_tag
;
2157 struct hda_spdif_out
*spdif
=
2158 snd_hda_spdif_out_of_nid(apcm
->codec
, hinfo
->nid
);
2159 unsigned short ctls
= spdif
? spdif
->ctls
: 0;
2162 if (dsp_is_locked(azx_dev
)) {
2167 azx_stream_reset(chip
, azx_dev
);
2168 format_val
= snd_hda_calc_stream_format(runtime
->rate
,
2174 snd_printk(KERN_ERR SFX
2175 "%s: invalid format_val, rate=%d, ch=%d, format=%d\n",
2176 pci_name(chip
->pci
), runtime
->rate
, runtime
->channels
, runtime
->format
);
2181 bufsize
= snd_pcm_lib_buffer_bytes(substream
);
2182 period_bytes
= snd_pcm_lib_period_bytes(substream
);
2184 snd_printdd(SFX
"%s: azx_pcm_prepare: bufsize=0x%x, format=0x%x\n",
2185 pci_name(chip
->pci
), bufsize
, format_val
);
2187 if (bufsize
!= azx_dev
->bufsize
||
2188 period_bytes
!= azx_dev
->period_bytes
||
2189 format_val
!= azx_dev
->format_val
||
2190 runtime
->no_period_wakeup
!= azx_dev
->no_period_wakeup
) {
2191 azx_dev
->bufsize
= bufsize
;
2192 azx_dev
->period_bytes
= period_bytes
;
2193 azx_dev
->format_val
= format_val
;
2194 azx_dev
->no_period_wakeup
= runtime
->no_period_wakeup
;
2195 err
= azx_setup_periods(chip
, substream
, azx_dev
);
2200 /* when LPIB delay correction gives a small negative value,
2201 * we ignore it; currently set the threshold statically to
2204 if (runtime
->period_size
> 64)
2205 azx_dev
->delay_negative_threshold
= -frames_to_bytes(runtime
, 64);
2207 azx_dev
->delay_negative_threshold
= 0;
2209 /* wallclk has 24Mhz clock source */
2210 azx_dev
->period_wallclk
= (((runtime
->period_size
* 24000) /
2211 runtime
->rate
) * 1000);
2212 azx_setup_controller(chip
, azx_dev
);
2213 if (substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
)
2214 azx_dev
->fifo_size
= azx_sd_readw(azx_dev
, SD_FIFOSIZE
) + 1;
2216 azx_dev
->fifo_size
= 0;
2218 stream_tag
= azx_dev
->stream_tag
;
2219 /* CA-IBG chips need the playback stream starting from 1 */
2220 if ((chip
->driver_caps
& AZX_DCAPS_CTX_WORKAROUND
) &&
2221 stream_tag
> chip
->capture_streams
)
2222 stream_tag
-= chip
->capture_streams
;
2223 err
= snd_hda_codec_prepare(apcm
->codec
, hinfo
, stream_tag
,
2224 azx_dev
->format_val
, substream
);
2228 azx_dev
->prepared
= 1;
2229 dsp_unlock(azx_dev
);
2233 static int azx_pcm_trigger(struct snd_pcm_substream
*substream
, int cmd
)
2235 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2236 struct azx
*chip
= apcm
->chip
;
2237 struct azx_dev
*azx_dev
;
2238 struct snd_pcm_substream
*s
;
2239 int rstart
= 0, start
, nsync
= 0, sbits
= 0;
2242 azx_dev
= get_azx_dev(substream
);
2243 trace_azx_pcm_trigger(chip
, azx_dev
, cmd
);
2245 if (dsp_is_locked(azx_dev
) || !azx_dev
->prepared
)
2249 case SNDRV_PCM_TRIGGER_START
:
2251 case SNDRV_PCM_TRIGGER_PAUSE_RELEASE
:
2252 case SNDRV_PCM_TRIGGER_RESUME
:
2255 case SNDRV_PCM_TRIGGER_PAUSE_PUSH
:
2256 case SNDRV_PCM_TRIGGER_SUSPEND
:
2257 case SNDRV_PCM_TRIGGER_STOP
:
2264 snd_pcm_group_for_each_entry(s
, substream
) {
2265 if (s
->pcm
->card
!= substream
->pcm
->card
)
2267 azx_dev
= get_azx_dev(s
);
2268 sbits
|= 1 << azx_dev
->index
;
2270 snd_pcm_trigger_done(s
, substream
);
2273 spin_lock(&chip
->reg_lock
);
2275 /* first, set SYNC bits of corresponding streams */
2276 if (chip
->driver_caps
& AZX_DCAPS_OLD_SSYNC
)
2277 azx_writel(chip
, OLD_SSYNC
,
2278 azx_readl(chip
, OLD_SSYNC
) | sbits
);
2280 azx_writel(chip
, SSYNC
, azx_readl(chip
, SSYNC
) | sbits
);
2282 snd_pcm_group_for_each_entry(s
, substream
) {
2283 if (s
->pcm
->card
!= substream
->pcm
->card
)
2285 azx_dev
= get_azx_dev(s
);
2287 azx_dev
->start_wallclk
= azx_readl(chip
, WALLCLK
);
2289 azx_dev
->start_wallclk
-=
2290 azx_dev
->period_wallclk
;
2291 azx_stream_start(chip
, azx_dev
);
2293 azx_stream_stop(chip
, azx_dev
);
2295 azx_dev
->running
= start
;
2297 spin_unlock(&chip
->reg_lock
);
2299 /* wait until all FIFOs get ready */
2300 for (timeout
= 5000; timeout
; timeout
--) {
2302 snd_pcm_group_for_each_entry(s
, substream
) {
2303 if (s
->pcm
->card
!= substream
->pcm
->card
)
2305 azx_dev
= get_azx_dev(s
);
2306 if (!(azx_sd_readb(azx_dev
, SD_STS
) &
2315 /* wait until all RUN bits are cleared */
2316 for (timeout
= 5000; timeout
; timeout
--) {
2318 snd_pcm_group_for_each_entry(s
, substream
) {
2319 if (s
->pcm
->card
!= substream
->pcm
->card
)
2321 azx_dev
= get_azx_dev(s
);
2322 if (azx_sd_readb(azx_dev
, SD_CTL
) &
2331 spin_lock(&chip
->reg_lock
);
2332 /* reset SYNC bits */
2333 if (chip
->driver_caps
& AZX_DCAPS_OLD_SSYNC
)
2334 azx_writel(chip
, OLD_SSYNC
,
2335 azx_readl(chip
, OLD_SSYNC
) & ~sbits
);
2337 azx_writel(chip
, SSYNC
, azx_readl(chip
, SSYNC
) & ~sbits
);
2339 azx_timecounter_init(substream
, 0, 0);
2343 /* same start cycle for master and group */
2344 azx_dev
= get_azx_dev(substream
);
2345 cycle_last
= azx_dev
->azx_tc
.cycle_last
;
2347 snd_pcm_group_for_each_entry(s
, substream
) {
2348 if (s
->pcm
->card
!= substream
->pcm
->card
)
2350 azx_timecounter_init(s
, 1, cycle_last
);
2354 spin_unlock(&chip
->reg_lock
);
2358 /* get the current DMA position with correction on VIA chips */
2359 static unsigned int azx_via_get_position(struct azx
*chip
,
2360 struct azx_dev
*azx_dev
)
2362 unsigned int link_pos
, mini_pos
, bound_pos
;
2363 unsigned int mod_link_pos
, mod_dma_pos
, mod_mini_pos
;
2364 unsigned int fifo_size
;
2366 link_pos
= azx_sd_readl(azx_dev
, SD_LPIB
);
2367 if (azx_dev
->substream
->stream
== SNDRV_PCM_STREAM_PLAYBACK
) {
2368 /* Playback, no problem using link position */
2374 * use mod to get the DMA position just like old chipset
2376 mod_dma_pos
= le32_to_cpu(*azx_dev
->posbuf
);
2377 mod_dma_pos
%= azx_dev
->period_bytes
;
2379 /* azx_dev->fifo_size can't get FIFO size of in stream.
2380 * Get from base address + offset.
2382 fifo_size
= readw(chip
->remap_addr
+ VIA_IN_STREAM0_FIFO_SIZE_OFFSET
);
2384 if (azx_dev
->insufficient
) {
2385 /* Link position never gather than FIFO size */
2386 if (link_pos
<= fifo_size
)
2389 azx_dev
->insufficient
= 0;
2392 if (link_pos
<= fifo_size
)
2393 mini_pos
= azx_dev
->bufsize
+ link_pos
- fifo_size
;
2395 mini_pos
= link_pos
- fifo_size
;
2397 /* Find nearest previous boudary */
2398 mod_mini_pos
= mini_pos
% azx_dev
->period_bytes
;
2399 mod_link_pos
= link_pos
% azx_dev
->period_bytes
;
2400 if (mod_link_pos
>= fifo_size
)
2401 bound_pos
= link_pos
- mod_link_pos
;
2402 else if (mod_dma_pos
>= mod_mini_pos
)
2403 bound_pos
= mini_pos
- mod_mini_pos
;
2405 bound_pos
= mini_pos
- mod_mini_pos
+ azx_dev
->period_bytes
;
2406 if (bound_pos
>= azx_dev
->bufsize
)
2410 /* Calculate real DMA position we want */
2411 return bound_pos
+ mod_dma_pos
;
2414 static unsigned int azx_get_position(struct azx
*chip
,
2415 struct azx_dev
*azx_dev
,
2418 struct snd_pcm_substream
*substream
= azx_dev
->substream
;
2419 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2421 int stream
= substream
->stream
;
2422 struct hda_pcm_stream
*hinfo
= apcm
->hinfo
[stream
];
2425 switch (chip
->position_fix
[stream
]) {
2428 pos
= azx_sd_readl(azx_dev
, SD_LPIB
);
2430 case POS_FIX_VIACOMBO
:
2431 pos
= azx_via_get_position(chip
, azx_dev
);
2434 /* use the position buffer */
2435 pos
= le32_to_cpu(*azx_dev
->posbuf
);
2436 if (with_check
&& chip
->position_fix
[stream
] == POS_FIX_AUTO
) {
2437 if (!pos
|| pos
== (u32
)-1) {
2439 "hda-intel: Invalid position buffer, "
2440 "using LPIB read method instead.\n");
2441 chip
->position_fix
[stream
] = POS_FIX_LPIB
;
2442 pos
= azx_sd_readl(azx_dev
, SD_LPIB
);
2444 chip
->position_fix
[stream
] = POS_FIX_POSBUF
;
2449 if (pos
>= azx_dev
->bufsize
)
2452 /* calculate runtime delay from LPIB */
2453 if (substream
->runtime
&&
2454 chip
->position_fix
[stream
] == POS_FIX_POSBUF
&&
2455 (chip
->driver_caps
& AZX_DCAPS_COUNT_LPIB_DELAY
)) {
2456 unsigned int lpib_pos
= azx_sd_readl(azx_dev
, SD_LPIB
);
2457 if (stream
== SNDRV_PCM_STREAM_PLAYBACK
)
2458 delay
= pos
- lpib_pos
;
2460 delay
= lpib_pos
- pos
;
2462 if (delay
>= azx_dev
->delay_negative_threshold
)
2465 delay
+= azx_dev
->bufsize
;
2467 if (delay
>= azx_dev
->period_bytes
) {
2468 snd_printk(KERN_WARNING SFX
2469 "%s: Unstable LPIB (%d >= %d); "
2470 "disabling LPIB delay counting\n",
2471 pci_name(chip
->pci
), delay
, azx_dev
->period_bytes
);
2473 chip
->driver_caps
&= ~AZX_DCAPS_COUNT_LPIB_DELAY
;
2475 delay
= bytes_to_frames(substream
->runtime
, delay
);
2478 if (substream
->runtime
) {
2479 if (hinfo
->ops
.get_delay
)
2480 delay
+= hinfo
->ops
.get_delay(hinfo
, apcm
->codec
,
2482 substream
->runtime
->delay
= delay
;
2485 trace_azx_get_position(chip
, azx_dev
, pos
, delay
);
2489 static snd_pcm_uframes_t
azx_pcm_pointer(struct snd_pcm_substream
*substream
)
2491 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2492 struct azx
*chip
= apcm
->chip
;
2493 struct azx_dev
*azx_dev
= get_azx_dev(substream
);
2494 return bytes_to_frames(substream
->runtime
,
2495 azx_get_position(chip
, azx_dev
, false));
2499 * Check whether the current DMA position is acceptable for updating
2500 * periods. Returns non-zero if it's OK.
2502 * Many HD-audio controllers appear pretty inaccurate about
2503 * the update-IRQ timing. The IRQ is issued before actually the
2504 * data is processed. So, we need to process it afterwords in a
2507 static int azx_position_ok(struct azx
*chip
, struct azx_dev
*azx_dev
)
2512 wallclk
= azx_readl(chip
, WALLCLK
) - azx_dev
->start_wallclk
;
2513 if (wallclk
< (azx_dev
->period_wallclk
* 2) / 3)
2514 return -1; /* bogus (too early) interrupt */
2516 pos
= azx_get_position(chip
, azx_dev
, true);
2518 if (WARN_ONCE(!azx_dev
->period_bytes
,
2519 "hda-intel: zero azx_dev->period_bytes"))
2520 return -1; /* this shouldn't happen! */
2521 if (wallclk
< (azx_dev
->period_wallclk
* 5) / 4 &&
2522 pos
% azx_dev
->period_bytes
> azx_dev
->period_bytes
/ 2)
2523 /* NG - it's below the first next period boundary */
2524 return bdl_pos_adj
[chip
->dev_index
] ? 0 : -1;
2525 azx_dev
->start_wallclk
+= wallclk
;
2526 return 1; /* OK, it's fine */
2530 * The work for pending PCM period updates.
2532 static void azx_irq_pending_work(struct work_struct
*work
)
2534 struct azx
*chip
= container_of(work
, struct azx
, irq_pending_work
);
2537 if (!chip
->irq_pending_warned
) {
2539 "hda-intel: IRQ timing workaround is activated "
2540 "for card #%d. Suggest a bigger bdl_pos_adj.\n",
2541 chip
->card
->number
);
2542 chip
->irq_pending_warned
= 1;
2547 spin_lock_irq(&chip
->reg_lock
);
2548 for (i
= 0; i
< chip
->num_streams
; i
++) {
2549 struct azx_dev
*azx_dev
= &chip
->azx_dev
[i
];
2550 if (!azx_dev
->irq_pending
||
2551 !azx_dev
->substream
||
2554 ok
= azx_position_ok(chip
, azx_dev
);
2556 azx_dev
->irq_pending
= 0;
2557 spin_unlock(&chip
->reg_lock
);
2558 snd_pcm_period_elapsed(azx_dev
->substream
);
2559 spin_lock(&chip
->reg_lock
);
2560 } else if (ok
< 0) {
2561 pending
= 0; /* too early */
2565 spin_unlock_irq(&chip
->reg_lock
);
2572 /* clear irq_pending flags and assure no on-going workq */
2573 static void azx_clear_irq_pending(struct azx
*chip
)
2577 spin_lock_irq(&chip
->reg_lock
);
2578 for (i
= 0; i
< chip
->num_streams
; i
++)
2579 chip
->azx_dev
[i
].irq_pending
= 0;
2580 spin_unlock_irq(&chip
->reg_lock
);
2584 static int azx_pcm_mmap(struct snd_pcm_substream
*substream
,
2585 struct vm_area_struct
*area
)
2587 struct azx_pcm
*apcm
= snd_pcm_substream_chip(substream
);
2588 struct azx
*chip
= apcm
->chip
;
2589 if (!azx_snoop(chip
))
2590 area
->vm_page_prot
= pgprot_writecombine(area
->vm_page_prot
);
2591 return snd_pcm_lib_default_mmap(substream
, area
);
2594 #define azx_pcm_mmap NULL
2597 static struct snd_pcm_ops azx_pcm_ops
= {
2598 .open
= azx_pcm_open
,
2599 .close
= azx_pcm_close
,
2600 .ioctl
= snd_pcm_lib_ioctl
,
2601 .hw_params
= azx_pcm_hw_params
,
2602 .hw_free
= azx_pcm_hw_free
,
2603 .prepare
= azx_pcm_prepare
,
2604 .trigger
= azx_pcm_trigger
,
2605 .pointer
= azx_pcm_pointer
,
2606 .wall_clock
= azx_get_wallclock_tstamp
,
2607 .mmap
= azx_pcm_mmap
,
2608 .page
= snd_pcm_sgbuf_ops_page
,
2611 static void azx_pcm_free(struct snd_pcm
*pcm
)
2613 struct azx_pcm
*apcm
= pcm
->private_data
;
2615 list_del(&apcm
->list
);
2620 #define MAX_PREALLOC_SIZE (32 * 1024 * 1024)
2623 azx_attach_pcm_stream(struct hda_bus
*bus
, struct hda_codec
*codec
,
2624 struct hda_pcm
*cpcm
)
2626 struct azx
*chip
= bus
->private_data
;
2627 struct snd_pcm
*pcm
;
2628 struct azx_pcm
*apcm
;
2629 int pcm_dev
= cpcm
->device
;
2633 list_for_each_entry(apcm
, &chip
->pcm_list
, list
) {
2634 if (apcm
->pcm
->device
== pcm_dev
) {
2635 snd_printk(KERN_ERR SFX
"%s: PCM %d already exists\n",
2636 pci_name(chip
->pci
), pcm_dev
);
2640 err
= snd_pcm_new(chip
->card
, cpcm
->name
, pcm_dev
,
2641 cpcm
->stream
[SNDRV_PCM_STREAM_PLAYBACK
].substreams
,
2642 cpcm
->stream
[SNDRV_PCM_STREAM_CAPTURE
].substreams
,
2646 strlcpy(pcm
->name
, cpcm
->name
, sizeof(pcm
->name
));
2647 apcm
= kzalloc(sizeof(*apcm
), GFP_KERNEL
);
2652 apcm
->codec
= codec
;
2653 pcm
->private_data
= apcm
;
2654 pcm
->private_free
= azx_pcm_free
;
2655 if (cpcm
->pcm_type
== HDA_PCM_TYPE_MODEM
)
2656 pcm
->dev_class
= SNDRV_PCM_CLASS_MODEM
;
2657 list_add_tail(&apcm
->list
, &chip
->pcm_list
);
2659 for (s
= 0; s
< 2; s
++) {
2660 apcm
->hinfo
[s
] = &cpcm
->stream
[s
];
2661 if (cpcm
->stream
[s
].substreams
)
2662 snd_pcm_set_ops(pcm
, s
, &azx_pcm_ops
);
2664 /* buffer pre-allocation */
2665 size
= CONFIG_SND_HDA_PREALLOC_SIZE
* 1024;
2666 if (size
> MAX_PREALLOC_SIZE
)
2667 size
= MAX_PREALLOC_SIZE
;
2668 snd_pcm_lib_preallocate_pages_for_all(pcm
, SNDRV_DMA_TYPE_DEV_SG
,
2669 snd_dma_pci_data(chip
->pci
),
2670 size
, MAX_PREALLOC_SIZE
);
2675 * mixer creation - all stuff is implemented in hda module
2677 static int azx_mixer_create(struct azx
*chip
)
2679 return snd_hda_build_controls(chip
->bus
);
2684 * initialize SD streams
2686 static int azx_init_stream(struct azx
*chip
)
2690 /* initialize each stream (aka device)
2691 * assign the starting bdl address to each stream (device)
2694 for (i
= 0; i
< chip
->num_streams
; i
++) {
2695 struct azx_dev
*azx_dev
= &chip
->azx_dev
[i
];
2696 azx_dev
->posbuf
= (u32 __iomem
*)(chip
->posbuf
.area
+ i
* 8);
2697 /* offset: SDI0=0x80, SDI1=0xa0, ... SDO3=0x160 */
2698 azx_dev
->sd_addr
= chip
->remap_addr
+ (0x20 * i
+ 0x80);
2699 /* int mask: SDI0=0x01, SDI1=0x02, ... SDO3=0x80 */
2700 azx_dev
->sd_int_sta_mask
= 1 << i
;
2701 /* stream tag: must be non-zero and unique */
2703 azx_dev
->stream_tag
= i
+ 1;
2709 static int azx_acquire_irq(struct azx
*chip
, int do_disconnect
)
2711 if (request_irq(chip
->pci
->irq
, azx_interrupt
,
2712 chip
->msi
? 0 : IRQF_SHARED
,
2713 KBUILD_MODNAME
, chip
)) {
2714 printk(KERN_ERR
"hda-intel: unable to grab IRQ %d, "
2715 "disabling device\n", chip
->pci
->irq
);
2717 snd_card_disconnect(chip
->card
);
2720 chip
->irq
= chip
->pci
->irq
;
2721 pci_intx(chip
->pci
, !chip
->msi
);
2726 static void azx_stop_chip(struct azx
*chip
)
2728 if (!chip
->initialized
)
2731 /* disable interrupts */
2732 azx_int_disable(chip
);
2733 azx_int_clear(chip
);
2735 /* disable CORB/RIRB */
2736 azx_free_cmd_io(chip
);
2738 /* disable position buffer */
2739 azx_writel(chip
, DPLBASE
, 0);
2740 azx_writel(chip
, DPUBASE
, 0);
2742 chip
->initialized
= 0;
2745 #ifdef CONFIG_SND_HDA_DSP_LOADER
2747 * DSP loading code (e.g. for CA0132)
2750 /* use the first stream for loading DSP */
2751 static struct azx_dev
*
2752 azx_get_dsp_loader_dev(struct azx
*chip
)
2754 return &chip
->azx_dev
[chip
->playback_index_offset
];
2757 static int azx_load_dsp_prepare(struct hda_bus
*bus
, unsigned int format
,
2758 unsigned int byte_size
,
2759 struct snd_dma_buffer
*bufp
)
2762 struct azx
*chip
= bus
->private_data
;
2763 struct azx_dev
*azx_dev
;
2766 azx_dev
= azx_get_dsp_loader_dev(chip
);
2769 spin_lock_irq(&chip
->reg_lock
);
2770 if (azx_dev
->running
|| azx_dev
->locked
) {
2771 spin_unlock_irq(&chip
->reg_lock
);
2775 azx_dev
->prepared
= 0;
2776 chip
->saved_azx_dev
= *azx_dev
;
2777 azx_dev
->locked
= 1;
2778 spin_unlock_irq(&chip
->reg_lock
);
2780 err
= snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV_SG
,
2781 snd_dma_pci_data(chip
->pci
),
2786 mark_pages_wc(chip
, bufp
, true);
2787 azx_dev
->bufsize
= byte_size
;
2788 azx_dev
->period_bytes
= byte_size
;
2789 azx_dev
->format_val
= format
;
2791 azx_stream_reset(chip
, azx_dev
);
2793 /* reset BDL address */
2794 azx_sd_writel(azx_dev
, SD_BDLPL
, 0);
2795 azx_sd_writel(azx_dev
, SD_BDLPU
, 0);
2798 bdl
= (u32
*)azx_dev
->bdl
.area
;
2799 err
= setup_bdle(chip
, bufp
, azx_dev
, &bdl
, 0, byte_size
, 0);
2803 azx_setup_controller(chip
, azx_dev
);
2804 dsp_unlock(azx_dev
);
2805 return azx_dev
->stream_tag
;
2808 mark_pages_wc(chip
, bufp
, false);
2809 snd_dma_free_pages(bufp
);
2811 spin_lock_irq(&chip
->reg_lock
);
2812 if (azx_dev
->opened
)
2813 *azx_dev
= chip
->saved_azx_dev
;
2814 azx_dev
->locked
= 0;
2815 spin_unlock_irq(&chip
->reg_lock
);
2817 dsp_unlock(azx_dev
);
2821 static void azx_load_dsp_trigger(struct hda_bus
*bus
, bool start
)
2823 struct azx
*chip
= bus
->private_data
;
2824 struct azx_dev
*azx_dev
= azx_get_dsp_loader_dev(chip
);
2827 azx_stream_start(chip
, azx_dev
);
2829 azx_stream_stop(chip
, azx_dev
);
2830 azx_dev
->running
= start
;
2833 static void azx_load_dsp_cleanup(struct hda_bus
*bus
,
2834 struct snd_dma_buffer
*dmab
)
2836 struct azx
*chip
= bus
->private_data
;
2837 struct azx_dev
*azx_dev
= azx_get_dsp_loader_dev(chip
);
2839 if (!dmab
->area
|| !azx_dev
->locked
)
2843 /* reset BDL address */
2844 azx_sd_writel(azx_dev
, SD_BDLPL
, 0);
2845 azx_sd_writel(azx_dev
, SD_BDLPU
, 0);
2846 azx_sd_writel(azx_dev
, SD_CTL
, 0);
2847 azx_dev
->bufsize
= 0;
2848 azx_dev
->period_bytes
= 0;
2849 azx_dev
->format_val
= 0;
2851 mark_pages_wc(chip
, dmab
, false);
2852 snd_dma_free_pages(dmab
);
2855 spin_lock_irq(&chip
->reg_lock
);
2856 if (azx_dev
->opened
)
2857 *azx_dev
= chip
->saved_azx_dev
;
2858 azx_dev
->locked
= 0;
2859 spin_unlock_irq(&chip
->reg_lock
);
2860 dsp_unlock(azx_dev
);
2862 #endif /* CONFIG_SND_HDA_DSP_LOADER */
2865 /* power-up/down the controller */
2866 static void azx_power_notify(struct hda_bus
*bus
, bool power_up
)
2868 struct azx
*chip
= bus
->private_data
;
2870 if (!(chip
->driver_caps
& AZX_DCAPS_PM_RUNTIME
))
2874 pm_runtime_get_sync(&chip
->pci
->dev
);
2876 pm_runtime_put_sync(&chip
->pci
->dev
);
2879 static DEFINE_MUTEX(card_list_lock
);
2880 static LIST_HEAD(card_list
);
2882 static void azx_add_card_list(struct azx
*chip
)
2884 mutex_lock(&card_list_lock
);
2885 list_add(&chip
->list
, &card_list
);
2886 mutex_unlock(&card_list_lock
);
2889 static void azx_del_card_list(struct azx
*chip
)
2891 mutex_lock(&card_list_lock
);
2892 list_del_init(&chip
->list
);
2893 mutex_unlock(&card_list_lock
);
2896 /* trigger power-save check at writing parameter */
2897 static int param_set_xint(const char *val
, const struct kernel_param
*kp
)
2900 struct hda_codec
*c
;
2901 int prev
= power_save
;
2902 int ret
= param_set_int(val
, kp
);
2904 if (ret
|| prev
== power_save
)
2907 mutex_lock(&card_list_lock
);
2908 list_for_each_entry(chip
, &card_list
, list
) {
2909 if (!chip
->bus
|| chip
->disabled
)
2911 list_for_each_entry(c
, &chip
->bus
->codec_list
, list
)
2912 snd_hda_power_sync(c
);
2914 mutex_unlock(&card_list_lock
);
2918 #define azx_add_card_list(chip) /* NOP */
2919 #define azx_del_card_list(chip) /* NOP */
2920 #endif /* CONFIG_PM */
2922 #if defined(CONFIG_PM_SLEEP) || defined(SUPPORT_VGA_SWITCHEROO)
2926 static int azx_suspend(struct device
*dev
)
2928 struct pci_dev
*pci
= to_pci_dev(dev
);
2929 struct snd_card
*card
= dev_get_drvdata(dev
);
2930 struct azx
*chip
= card
->private_data
;
2936 snd_power_change_state(card
, SNDRV_CTL_POWER_D3hot
);
2937 azx_clear_irq_pending(chip
);
2938 list_for_each_entry(p
, &chip
->pcm_list
, list
)
2939 snd_pcm_suspend_all(p
->pcm
);
2940 if (chip
->initialized
)
2941 snd_hda_suspend(chip
->bus
);
2942 azx_stop_chip(chip
);
2943 azx_enter_link_reset(chip
);
2944 if (chip
->irq
>= 0) {
2945 free_irq(chip
->irq
, chip
);
2949 pci_disable_msi(chip
->pci
);
2950 pci_disable_device(pci
);
2951 pci_save_state(pci
);
2952 pci_set_power_state(pci
, PCI_D3hot
);
2953 if (chip
->driver_caps
& AZX_DCAPS_I915_POWERWELL
)
2954 hda_display_power(false);
2958 static int azx_resume(struct device
*dev
)
2960 struct pci_dev
*pci
= to_pci_dev(dev
);
2961 struct snd_card
*card
= dev_get_drvdata(dev
);
2962 struct azx
*chip
= card
->private_data
;
2967 if (chip
->driver_caps
& AZX_DCAPS_I915_POWERWELL
)
2968 hda_display_power(true);
2969 pci_set_power_state(pci
, PCI_D0
);
2970 pci_restore_state(pci
);
2971 if (pci_enable_device(pci
) < 0) {
2972 printk(KERN_ERR
"hda-intel: pci_enable_device failed, "
2973 "disabling device\n");
2974 snd_card_disconnect(card
);
2977 pci_set_master(pci
);
2979 if (pci_enable_msi(pci
) < 0)
2981 if (azx_acquire_irq(chip
, 1) < 0)
2985 azx_init_chip(chip
, 1);
2987 snd_hda_resume(chip
->bus
);
2988 snd_power_change_state(card
, SNDRV_CTL_POWER_D0
);
2991 #endif /* CONFIG_PM_SLEEP || SUPPORT_VGA_SWITCHEROO */
2993 #ifdef CONFIG_PM_RUNTIME
2994 static int azx_runtime_suspend(struct device
*dev
)
2996 struct snd_card
*card
= dev_get_drvdata(dev
);
2997 struct azx
*chip
= card
->private_data
;
3002 if (!(chip
->driver_caps
& AZX_DCAPS_PM_RUNTIME
))
3005 /* enable controller wake up event */
3006 azx_writew(chip
, WAKEEN
, azx_readw(chip
, WAKEEN
) |
3009 azx_stop_chip(chip
);
3010 azx_enter_link_reset(chip
);
3011 azx_clear_irq_pending(chip
);
3012 if (chip
->driver_caps
& AZX_DCAPS_I915_POWERWELL
)
3013 hda_display_power(false);
3017 static int azx_runtime_resume(struct device
*dev
)
3019 struct snd_card
*card
= dev_get_drvdata(dev
);
3020 struct azx
*chip
= card
->private_data
;
3021 struct hda_bus
*bus
;
3022 struct hda_codec
*codec
;
3028 if (!(chip
->driver_caps
& AZX_DCAPS_PM_RUNTIME
))
3031 if (chip
->driver_caps
& AZX_DCAPS_I915_POWERWELL
)
3032 hda_display_power(true);
3034 /* Read STATESTS before controller reset */
3035 status
= azx_readw(chip
, STATESTS
);
3038 azx_init_chip(chip
, 1);
3041 if (status
&& bus
) {
3042 list_for_each_entry(codec
, &bus
->codec_list
, list
)
3043 if (status
& (1 << codec
->addr
))
3044 queue_delayed_work(codec
->bus
->workq
,
3045 &codec
->jackpoll_work
, codec
->jackpoll_interval
);
3048 /* disable controller Wake Up event*/
3049 azx_writew(chip
, WAKEEN
, azx_readw(chip
, WAKEEN
) &
3050 ~STATESTS_INT_MASK
);
3055 static int azx_runtime_idle(struct device
*dev
)
3057 struct snd_card
*card
= dev_get_drvdata(dev
);
3058 struct azx
*chip
= card
->private_data
;
3063 if (!power_save_controller
||
3064 !(chip
->driver_caps
& AZX_DCAPS_PM_RUNTIME
))
3070 #endif /* CONFIG_PM_RUNTIME */
3073 static const struct dev_pm_ops azx_pm
= {
3074 SET_SYSTEM_SLEEP_PM_OPS(azx_suspend
, azx_resume
)
3075 SET_RUNTIME_PM_OPS(azx_runtime_suspend
, azx_runtime_resume
, azx_runtime_idle
)
3078 #define AZX_PM_OPS &azx_pm
3080 #define AZX_PM_OPS NULL
3081 #endif /* CONFIG_PM */
3085 * reboot notifier for hang-up problem at power-down
3087 static int azx_halt(struct notifier_block
*nb
, unsigned long event
, void *buf
)
3089 struct azx
*chip
= container_of(nb
, struct azx
, reboot_notifier
);
3090 snd_hda_bus_reboot_notify(chip
->bus
);
3091 azx_stop_chip(chip
);
3095 static void azx_notifier_register(struct azx
*chip
)
3097 chip
->reboot_notifier
.notifier_call
= azx_halt
;
3098 register_reboot_notifier(&chip
->reboot_notifier
);
3101 static void azx_notifier_unregister(struct azx
*chip
)
3103 if (chip
->reboot_notifier
.notifier_call
)
3104 unregister_reboot_notifier(&chip
->reboot_notifier
);
3107 static int azx_probe_continue(struct azx
*chip
);
3109 #ifdef SUPPORT_VGA_SWITCHEROO
3110 static struct pci_dev
*get_bound_vga(struct pci_dev
*pci
);
3112 static void azx_vs_set_state(struct pci_dev
*pci
,
3113 enum vga_switcheroo_state state
)
3115 struct snd_card
*card
= pci_get_drvdata(pci
);
3116 struct azx
*chip
= card
->private_data
;
3119 wait_for_completion(&chip
->probe_wait
);
3120 if (chip
->init_failed
)
3123 disabled
= (state
== VGA_SWITCHEROO_OFF
);
3124 if (chip
->disabled
== disabled
)
3128 chip
->disabled
= disabled
;
3130 snd_printk(KERN_INFO SFX
3131 "%s: Start delayed initialization\n",
3132 pci_name(chip
->pci
));
3133 if (azx_probe_continue(chip
) < 0) {
3134 snd_printk(KERN_ERR SFX
3135 "%s: initialization error\n",
3136 pci_name(chip
->pci
));
3137 chip
->init_failed
= true;
3141 snd_printk(KERN_INFO SFX
3142 "%s: %s via VGA-switcheroo\n", pci_name(chip
->pci
),
3143 disabled
? "Disabling" : "Enabling");
3145 pm_runtime_put_sync_suspend(&pci
->dev
);
3146 azx_suspend(&pci
->dev
);
3147 /* when we get suspended by vga switcheroo we end up in D3cold,
3148 * however we have no ACPI handle, so pci/acpi can't put us there,
3149 * put ourselves there */
3150 pci
->current_state
= PCI_D3cold
;
3151 chip
->disabled
= true;
3152 if (snd_hda_lock_devices(chip
->bus
))
3153 snd_printk(KERN_WARNING SFX
"%s: Cannot lock devices!\n",
3154 pci_name(chip
->pci
));
3156 snd_hda_unlock_devices(chip
->bus
);
3157 pm_runtime_get_noresume(&pci
->dev
);
3158 chip
->disabled
= false;
3159 azx_resume(&pci
->dev
);
3164 static bool azx_vs_can_switch(struct pci_dev
*pci
)
3166 struct snd_card
*card
= pci_get_drvdata(pci
);
3167 struct azx
*chip
= card
->private_data
;
3169 wait_for_completion(&chip
->probe_wait
);
3170 if (chip
->init_failed
)
3172 if (chip
->disabled
|| !chip
->bus
)
3174 if (snd_hda_lock_devices(chip
->bus
))
3176 snd_hda_unlock_devices(chip
->bus
);
3180 static void init_vga_switcheroo(struct azx
*chip
)
3182 struct pci_dev
*p
= get_bound_vga(chip
->pci
);
3184 snd_printk(KERN_INFO SFX
3185 "%s: Handle VGA-switcheroo audio client\n",
3186 pci_name(chip
->pci
));
3187 chip
->use_vga_switcheroo
= 1;
3192 static const struct vga_switcheroo_client_ops azx_vs_ops
= {
3193 .set_gpu_state
= azx_vs_set_state
,
3194 .can_switch
= azx_vs_can_switch
,
3197 static int register_vga_switcheroo(struct azx
*chip
)
3201 if (!chip
->use_vga_switcheroo
)
3203 /* FIXME: currently only handling DIS controller
3204 * is there any machine with two switchable HDMI audio controllers?
3206 err
= vga_switcheroo_register_audio_client(chip
->pci
, &azx_vs_ops
,
3211 chip
->vga_switcheroo_registered
= 1;
3213 /* register as an optimus hdmi audio power domain */
3214 vga_switcheroo_init_domain_pm_optimus_hdmi_audio(&chip
->pci
->dev
, &chip
->hdmi_pm_domain
);
3218 #define init_vga_switcheroo(chip) /* NOP */
3219 #define register_vga_switcheroo(chip) 0
3220 #define check_hdmi_disabled(pci) false
3221 #endif /* SUPPORT_VGA_SWITCHER */
3226 static int azx_free(struct azx
*chip
)
3228 struct pci_dev
*pci
= chip
->pci
;
3231 if ((chip
->driver_caps
& AZX_DCAPS_PM_RUNTIME
)
3233 pm_runtime_get_noresume(&pci
->dev
);
3235 azx_del_card_list(chip
);
3237 azx_notifier_unregister(chip
);
3239 chip
->init_failed
= 1; /* to be sure */
3240 complete_all(&chip
->probe_wait
);
3242 if (use_vga_switcheroo(chip
)) {
3243 if (chip
->disabled
&& chip
->bus
)
3244 snd_hda_unlock_devices(chip
->bus
);
3245 if (chip
->vga_switcheroo_registered
)
3246 vga_switcheroo_unregister_client(chip
->pci
);
3249 if (chip
->initialized
) {
3250 azx_clear_irq_pending(chip
);
3251 for (i
= 0; i
< chip
->num_streams
; i
++)
3252 azx_stream_stop(chip
, &chip
->azx_dev
[i
]);
3253 azx_stop_chip(chip
);
3257 free_irq(chip
->irq
, (void*)chip
);
3259 pci_disable_msi(chip
->pci
);
3260 if (chip
->remap_addr
)
3261 iounmap(chip
->remap_addr
);
3263 if (chip
->azx_dev
) {
3264 for (i
= 0; i
< chip
->num_streams
; i
++)
3265 if (chip
->azx_dev
[i
].bdl
.area
) {
3266 mark_pages_wc(chip
, &chip
->azx_dev
[i
].bdl
, false);
3267 snd_dma_free_pages(&chip
->azx_dev
[i
].bdl
);
3270 if (chip
->rb
.area
) {
3271 mark_pages_wc(chip
, &chip
->rb
, false);
3272 snd_dma_free_pages(&chip
->rb
);
3274 if (chip
->posbuf
.area
) {
3275 mark_pages_wc(chip
, &chip
->posbuf
, false);
3276 snd_dma_free_pages(&chip
->posbuf
);
3278 if (chip
->region_requested
)
3279 pci_release_regions(chip
->pci
);
3280 pci_disable_device(chip
->pci
);
3281 kfree(chip
->azx_dev
);
3282 #ifdef CONFIG_SND_HDA_PATCH_LOADER
3284 release_firmware(chip
->fw
);
3286 if (chip
->driver_caps
& AZX_DCAPS_I915_POWERWELL
) {
3287 hda_display_power(false);
3295 static int azx_dev_free(struct snd_device
*device
)
3297 return azx_free(device
->device_data
);
3300 #ifdef SUPPORT_VGA_SWITCHEROO
3302 * Check of disabled HDMI controller by vga-switcheroo
3304 static struct pci_dev
*get_bound_vga(struct pci_dev
*pci
)
3308 /* check only discrete GPU */
3309 switch (pci
->vendor
) {
3310 case PCI_VENDOR_ID_ATI
:
3311 case PCI_VENDOR_ID_AMD
:
3312 case PCI_VENDOR_ID_NVIDIA
:
3313 if (pci
->devfn
== 1) {
3314 p
= pci_get_domain_bus_and_slot(pci_domain_nr(pci
->bus
),
3315 pci
->bus
->number
, 0);
3317 if ((p
->class >> 8) == PCI_CLASS_DISPLAY_VGA
)
3327 static bool check_hdmi_disabled(struct pci_dev
*pci
)
3329 bool vga_inactive
= false;
3330 struct pci_dev
*p
= get_bound_vga(pci
);
3333 if (vga_switcheroo_get_client_state(p
) == VGA_SWITCHEROO_OFF
)
3334 vga_inactive
= true;
3337 return vga_inactive
;
3339 #endif /* SUPPORT_VGA_SWITCHEROO */
3342 * white/black-listing for position_fix
3344 static struct snd_pci_quirk position_fix_list
[] = {
3345 SND_PCI_QUIRK(0x1028, 0x01cc, "Dell D820", POS_FIX_LPIB
),
3346 SND_PCI_QUIRK(0x1028, 0x01de, "Dell Precision 390", POS_FIX_LPIB
),
3347 SND_PCI_QUIRK(0x103c, 0x306d, "HP dv3", POS_FIX_LPIB
),
3348 SND_PCI_QUIRK(0x1043, 0x813d, "ASUS P5AD2", POS_FIX_LPIB
),
3349 SND_PCI_QUIRK(0x1043, 0x81b3, "ASUS", POS_FIX_LPIB
),
3350 SND_PCI_QUIRK(0x1043, 0x81e7, "ASUS M2V", POS_FIX_LPIB
),
3351 SND_PCI_QUIRK(0x104d, 0x9069, "Sony VPCS11V9E", POS_FIX_LPIB
),
3352 SND_PCI_QUIRK(0x10de, 0xcb89, "Macbook Pro 7,1", POS_FIX_LPIB
),
3353 SND_PCI_QUIRK(0x1297, 0x3166, "Shuttle", POS_FIX_LPIB
),
3354 SND_PCI_QUIRK(0x1458, 0xa022, "ga-ma770-ud3", POS_FIX_LPIB
),
3355 SND_PCI_QUIRK(0x1462, 0x1002, "MSI Wind U115", POS_FIX_LPIB
),
3356 SND_PCI_QUIRK(0x1565, 0x8218, "Biostar Microtech", POS_FIX_LPIB
),
3357 SND_PCI_QUIRK(0x1849, 0x0888, "775Dual-VSTA", POS_FIX_LPIB
),
3358 SND_PCI_QUIRK(0x8086, 0x2503, "DG965OT AAD63733-203", POS_FIX_LPIB
),
3362 static int check_position_fix(struct azx
*chip
, int fix
)
3364 const struct snd_pci_quirk
*q
;
3369 case POS_FIX_POSBUF
:
3370 case POS_FIX_VIACOMBO
:
3375 q
= snd_pci_quirk_lookup(chip
->pci
, position_fix_list
);
3378 "hda_intel: position_fix set to %d "
3379 "for device %04x:%04x\n",
3380 q
->value
, q
->subvendor
, q
->subdevice
);
3384 /* Check VIA/ATI HD Audio Controller exist */
3385 if (chip
->driver_caps
& AZX_DCAPS_POSFIX_VIA
) {
3386 snd_printd(SFX
"%s: Using VIACOMBO position fix\n", pci_name(chip
->pci
));
3387 return POS_FIX_VIACOMBO
;
3389 if (chip
->driver_caps
& AZX_DCAPS_POSFIX_LPIB
) {
3390 snd_printd(SFX
"%s: Using LPIB position fix\n", pci_name(chip
->pci
));
3391 return POS_FIX_LPIB
;
3393 return POS_FIX_AUTO
;
3397 * black-lists for probe_mask
3399 static struct snd_pci_quirk probe_mask_list
[] = {
3400 /* Thinkpad often breaks the controller communication when accessing
3401 * to the non-working (or non-existing) modem codec slot.
3403 SND_PCI_QUIRK(0x1014, 0x05b7, "Thinkpad Z60", 0x01),
3404 SND_PCI_QUIRK(0x17aa, 0x2010, "Thinkpad X/T/R60", 0x01),
3405 SND_PCI_QUIRK(0x17aa, 0x20ac, "Thinkpad X/T/R61", 0x01),
3407 SND_PCI_QUIRK(0x1028, 0x20ac, "Dell Studio Desktop", 0x01),
3408 /* including bogus ALC268 in slot#2 that conflicts with ALC888 */
3409 SND_PCI_QUIRK(0x17c0, 0x4085, "Medion MD96630", 0x01),
3410 /* forced codec slots */
3411 SND_PCI_QUIRK(0x1043, 0x1262, "ASUS W5Fm", 0x103),
3412 SND_PCI_QUIRK(0x1046, 0x1262, "ASUS W5F", 0x103),
3413 /* WinFast VP200 H (Teradici) user reported broken communication */
3414 SND_PCI_QUIRK(0x3a21, 0x040d, "WinFast VP200 H", 0x101),
3418 #define AZX_FORCE_CODEC_MASK 0x100
3420 static void check_probe_mask(struct azx
*chip
, int dev
)
3422 const struct snd_pci_quirk
*q
;
3424 chip
->codec_probe_mask
= probe_mask
[dev
];
3425 if (chip
->codec_probe_mask
== -1) {
3426 q
= snd_pci_quirk_lookup(chip
->pci
, probe_mask_list
);
3429 "hda_intel: probe_mask set to 0x%x "
3430 "for device %04x:%04x\n",
3431 q
->value
, q
->subvendor
, q
->subdevice
);
3432 chip
->codec_probe_mask
= q
->value
;
3436 /* check forced option */
3437 if (chip
->codec_probe_mask
!= -1 &&
3438 (chip
->codec_probe_mask
& AZX_FORCE_CODEC_MASK
)) {
3439 chip
->codec_mask
= chip
->codec_probe_mask
& 0xff;
3440 printk(KERN_INFO
"hda_intel: codec_mask forced to 0x%x\n",
3446 * white/black-list for enable_msi
3448 static struct snd_pci_quirk msi_black_list
[] = {
3449 SND_PCI_QUIRK(0x103c, 0x2191, "HP", 0), /* AMD Hudson */
3450 SND_PCI_QUIRK(0x103c, 0x2192, "HP", 0), /* AMD Hudson */
3451 SND_PCI_QUIRK(0x103c, 0x21f7, "HP", 0), /* AMD Hudson */
3452 SND_PCI_QUIRK(0x103c, 0x21fa, "HP", 0), /* AMD Hudson */
3453 SND_PCI_QUIRK(0x1043, 0x81f2, "ASUS", 0), /* Athlon64 X2 + nvidia */
3454 SND_PCI_QUIRK(0x1043, 0x81f6, "ASUS", 0), /* nvidia */
3455 SND_PCI_QUIRK(0x1043, 0x822d, "ASUS", 0), /* Athlon64 X2 + nvidia MCP55 */
3456 SND_PCI_QUIRK(0x1179, 0xfb44, "Toshiba Satellite C870", 0), /* AMD Hudson */
3457 SND_PCI_QUIRK(0x1849, 0x0888, "ASRock", 0), /* Athlon64 X2 + nvidia */
3458 SND_PCI_QUIRK(0xa0a0, 0x0575, "Aopen MZ915-M", 0), /* ICH6 */
3462 static void check_msi(struct azx
*chip
)
3464 const struct snd_pci_quirk
*q
;
3466 if (enable_msi
>= 0) {
3467 chip
->msi
= !!enable_msi
;
3470 chip
->msi
= 1; /* enable MSI as default */
3471 q
= snd_pci_quirk_lookup(chip
->pci
, msi_black_list
);
3474 "hda_intel: msi for device %04x:%04x set to %d\n",
3475 q
->subvendor
, q
->subdevice
, q
->value
);
3476 chip
->msi
= q
->value
;
3480 /* NVidia chipsets seem to cause troubles with MSI */
3481 if (chip
->driver_caps
& AZX_DCAPS_NO_MSI
) {
3482 printk(KERN_INFO
"hda_intel: Disabling MSI\n");
3487 /* check the snoop mode availability */
3488 static void azx_check_snoop_available(struct azx
*chip
)
3490 bool snoop
= chip
->snoop
;
3492 switch (chip
->driver_type
) {
3493 case AZX_DRIVER_VIA
:
3494 /* force to non-snoop mode for a new VIA controller
3499 pci_read_config_byte(chip
->pci
, 0x42, &val
);
3500 if (!(val
& 0x80) && chip
->pci
->revision
== 0x30)
3504 case AZX_DRIVER_ATIHDMI_NS
:
3505 /* new ATI HDMI requires non-snoop */
3508 case AZX_DRIVER_CTHDA
:
3513 if (snoop
!= chip
->snoop
) {
3514 snd_printk(KERN_INFO SFX
"%s: Force to %s mode\n",
3515 pci_name(chip
->pci
), snoop
? "snoop" : "non-snoop");
3516 chip
->snoop
= snoop
;
3520 static void azx_probe_work(struct work_struct
*work
)
3522 azx_probe_continue(container_of(work
, struct azx
, probe_work
));
3528 static int azx_create(struct snd_card
*card
, struct pci_dev
*pci
,
3529 int dev
, unsigned int driver_caps
,
3532 static struct snd_device_ops ops
= {
3533 .dev_free
= azx_dev_free
,
3540 err
= pci_enable_device(pci
);
3544 chip
= kzalloc(sizeof(*chip
), GFP_KERNEL
);
3546 snd_printk(KERN_ERR SFX
"%s: Cannot allocate chip\n", pci_name(pci
));
3547 pci_disable_device(pci
);
3551 spin_lock_init(&chip
->reg_lock
);
3552 mutex_init(&chip
->open_mutex
);
3556 chip
->driver_caps
= driver_caps
;
3557 chip
->driver_type
= driver_caps
& 0xff;
3559 chip
->dev_index
= dev
;
3560 INIT_WORK(&chip
->irq_pending_work
, azx_irq_pending_work
);
3561 INIT_LIST_HEAD(&chip
->pcm_list
);
3562 INIT_LIST_HEAD(&chip
->list
);
3563 init_vga_switcheroo(chip
);
3564 init_completion(&chip
->probe_wait
);
3566 chip
->position_fix
[0] = chip
->position_fix
[1] =
3567 check_position_fix(chip
, position_fix
[dev
]);
3568 /* combo mode uses LPIB for playback */
3569 if (chip
->position_fix
[0] == POS_FIX_COMBO
) {
3570 chip
->position_fix
[0] = POS_FIX_LPIB
;
3571 chip
->position_fix
[1] = POS_FIX_AUTO
;
3574 check_probe_mask(chip
, dev
);
3576 chip
->single_cmd
= single_cmd
;
3577 chip
->snoop
= hda_snoop
;
3578 azx_check_snoop_available(chip
);
3580 if (bdl_pos_adj
[dev
] < 0) {
3581 switch (chip
->driver_type
) {
3582 case AZX_DRIVER_ICH
:
3583 case AZX_DRIVER_PCH
:
3584 bdl_pos_adj
[dev
] = 1;
3587 bdl_pos_adj
[dev
] = 32;
3592 err
= snd_device_new(card
, SNDRV_DEV_LOWLEVEL
, chip
, &ops
);
3594 snd_printk(KERN_ERR SFX
"%s: Error creating device [card]!\n",
3595 pci_name(chip
->pci
));
3600 /* continue probing in work context as may trigger request module */
3601 INIT_WORK(&chip
->probe_work
, azx_probe_work
);
3608 static int azx_first_init(struct azx
*chip
)
3610 int dev
= chip
->dev_index
;
3611 struct pci_dev
*pci
= chip
->pci
;
3612 struct snd_card
*card
= chip
->card
;
3614 unsigned short gcap
;
3616 #if BITS_PER_LONG != 64
3617 /* Fix up base address on ULI M5461 */
3618 if (chip
->driver_type
== AZX_DRIVER_ULI
) {
3620 pci_read_config_word(pci
, 0x40, &tmp3
);
3621 pci_write_config_word(pci
, 0x40, tmp3
| 0x10);
3622 pci_write_config_dword(pci
, PCI_BASE_ADDRESS_1
, 0);
3626 err
= pci_request_regions(pci
, "ICH HD audio");
3629 chip
->region_requested
= 1;
3631 chip
->addr
= pci_resource_start(pci
, 0);
3632 chip
->remap_addr
= pci_ioremap_bar(pci
, 0);
3633 if (chip
->remap_addr
== NULL
) {
3634 snd_printk(KERN_ERR SFX
"%s: ioremap error\n", pci_name(chip
->pci
));
3639 if (pci_enable_msi(pci
) < 0)
3642 if (azx_acquire_irq(chip
, 0) < 0)
3645 pci_set_master(pci
);
3646 synchronize_irq(chip
->irq
);
3648 gcap
= azx_readw(chip
, GCAP
);
3649 snd_printdd(SFX
"%s: chipset global capabilities = 0x%x\n", pci_name(chip
->pci
), gcap
);
3651 /* disable SB600 64bit support for safety */
3652 if (chip
->pci
->vendor
== PCI_VENDOR_ID_ATI
) {
3653 struct pci_dev
*p_smbus
;
3654 p_smbus
= pci_get_device(PCI_VENDOR_ID_ATI
,
3655 PCI_DEVICE_ID_ATI_SBX00_SMBUS
,
3658 if (p_smbus
->revision
< 0x30)
3659 gcap
&= ~ICH6_GCAP_64OK
;
3660 pci_dev_put(p_smbus
);
3664 /* disable 64bit DMA address on some devices */
3665 if (chip
->driver_caps
& AZX_DCAPS_NO_64BIT
) {
3666 snd_printd(SFX
"%s: Disabling 64bit DMA\n", pci_name(chip
->pci
));
3667 gcap
&= ~ICH6_GCAP_64OK
;
3670 /* disable buffer size rounding to 128-byte multiples if supported */
3671 if (align_buffer_size
>= 0)
3672 chip
->align_buffer_size
= !!align_buffer_size
;
3674 if (chip
->driver_caps
& AZX_DCAPS_BUFSIZE
)
3675 chip
->align_buffer_size
= 0;
3676 else if (chip
->driver_caps
& AZX_DCAPS_ALIGN_BUFSIZE
)
3677 chip
->align_buffer_size
= 1;
3679 chip
->align_buffer_size
= 1;
3682 /* allow 64bit DMA address if supported by H/W */
3683 if ((gcap
& ICH6_GCAP_64OK
) && !pci_set_dma_mask(pci
, DMA_BIT_MASK(64)))
3684 pci_set_consistent_dma_mask(pci
, DMA_BIT_MASK(64));
3686 pci_set_dma_mask(pci
, DMA_BIT_MASK(32));
3687 pci_set_consistent_dma_mask(pci
, DMA_BIT_MASK(32));
3690 /* read number of streams from GCAP register instead of using
3693 chip
->capture_streams
= (gcap
>> 8) & 0x0f;
3694 chip
->playback_streams
= (gcap
>> 12) & 0x0f;
3695 if (!chip
->playback_streams
&& !chip
->capture_streams
) {
3696 /* gcap didn't give any info, switching to old method */
3698 switch (chip
->driver_type
) {
3699 case AZX_DRIVER_ULI
:
3700 chip
->playback_streams
= ULI_NUM_PLAYBACK
;
3701 chip
->capture_streams
= ULI_NUM_CAPTURE
;
3703 case AZX_DRIVER_ATIHDMI
:
3704 case AZX_DRIVER_ATIHDMI_NS
:
3705 chip
->playback_streams
= ATIHDMI_NUM_PLAYBACK
;
3706 chip
->capture_streams
= ATIHDMI_NUM_CAPTURE
;
3708 case AZX_DRIVER_GENERIC
:
3710 chip
->playback_streams
= ICH6_NUM_PLAYBACK
;
3711 chip
->capture_streams
= ICH6_NUM_CAPTURE
;
3715 chip
->capture_index_offset
= 0;
3716 chip
->playback_index_offset
= chip
->capture_streams
;
3717 chip
->num_streams
= chip
->playback_streams
+ chip
->capture_streams
;
3718 chip
->azx_dev
= kcalloc(chip
->num_streams
, sizeof(*chip
->azx_dev
),
3720 if (!chip
->azx_dev
) {
3721 snd_printk(KERN_ERR SFX
"%s: cannot malloc azx_dev\n", pci_name(chip
->pci
));
3725 for (i
= 0; i
< chip
->num_streams
; i
++) {
3726 dsp_lock_init(&chip
->azx_dev
[i
]);
3727 /* allocate memory for the BDL for each stream */
3728 err
= snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV
,
3729 snd_dma_pci_data(chip
->pci
),
3730 BDL_SIZE
, &chip
->azx_dev
[i
].bdl
);
3732 snd_printk(KERN_ERR SFX
"%s: cannot allocate BDL\n", pci_name(chip
->pci
));
3735 mark_pages_wc(chip
, &chip
->azx_dev
[i
].bdl
, true);
3737 /* allocate memory for the position buffer */
3738 err
= snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV
,
3739 snd_dma_pci_data(chip
->pci
),
3740 chip
->num_streams
* 8, &chip
->posbuf
);
3742 snd_printk(KERN_ERR SFX
"%s: cannot allocate posbuf\n", pci_name(chip
->pci
));
3745 mark_pages_wc(chip
, &chip
->posbuf
, true);
3746 /* allocate CORB/RIRB */
3747 err
= azx_alloc_cmd_io(chip
);
3751 /* initialize streams */
3752 azx_init_stream(chip
);
3754 /* initialize chip */
3756 azx_init_chip(chip
, (probe_only
[dev
] & 2) == 0);
3758 /* codec detection */
3759 if (!chip
->codec_mask
) {
3760 snd_printk(KERN_ERR SFX
"%s: no codecs found!\n", pci_name(chip
->pci
));
3764 strcpy(card
->driver
, "HDA-Intel");
3765 strlcpy(card
->shortname
, driver_short_names
[chip
->driver_type
],
3766 sizeof(card
->shortname
));
3767 snprintf(card
->longname
, sizeof(card
->longname
),
3768 "%s at 0x%lx irq %i",
3769 card
->shortname
, chip
->addr
, chip
->irq
);
3774 static void power_down_all_codecs(struct azx
*chip
)
3777 /* The codecs were powered up in snd_hda_codec_new().
3778 * Now all initialization done, so turn them down if possible
3780 struct hda_codec
*codec
;
3781 list_for_each_entry(codec
, &chip
->bus
->codec_list
, list
) {
3782 snd_hda_power_down(codec
);
3787 #ifdef CONFIG_SND_HDA_PATCH_LOADER
3788 /* callback from request_firmware_nowait() */
3789 static void azx_firmware_cb(const struct firmware
*fw
, void *context
)
3791 struct snd_card
*card
= context
;
3792 struct azx
*chip
= card
->private_data
;
3793 struct pci_dev
*pci
= chip
->pci
;
3796 snd_printk(KERN_ERR SFX
"%s: Cannot load firmware, aborting\n",
3797 pci_name(chip
->pci
));
3802 if (!chip
->disabled
) {
3803 /* continue probing */
3804 if (azx_probe_continue(chip
))
3810 snd_card_free(card
);
3811 pci_set_drvdata(pci
, NULL
);
3815 static int azx_probe(struct pci_dev
*pci
,
3816 const struct pci_device_id
*pci_id
)
3819 struct snd_card
*card
;
3821 bool schedule_probe
;
3824 if (dev
>= SNDRV_CARDS
)
3831 err
= snd_card_create(index
[dev
], id
[dev
], THIS_MODULE
, 0, &card
);
3833 snd_printk(KERN_ERR
"hda-intel: Error creating card!\n");
3837 snd_card_set_dev(card
, &pci
->dev
);
3839 err
= azx_create(card
, pci
, dev
, pci_id
->driver_data
, &chip
);
3842 card
->private_data
= chip
;
3844 pci_set_drvdata(pci
, card
);
3846 err
= register_vga_switcheroo(chip
);
3848 snd_printk(KERN_ERR SFX
3849 "%s: Error registering VGA-switcheroo client\n", pci_name(pci
));
3853 if (check_hdmi_disabled(pci
)) {
3854 snd_printk(KERN_INFO SFX
"%s: VGA controller is disabled\n",
3856 snd_printk(KERN_INFO SFX
"%s: Delaying initialization\n", pci_name(pci
));
3857 chip
->disabled
= true;
3860 schedule_probe
= !chip
->disabled
;
3862 #ifdef CONFIG_SND_HDA_PATCH_LOADER
3863 if (patch
[dev
] && *patch
[dev
]) {
3864 snd_printk(KERN_ERR SFX
"%s: Applying patch firmware '%s'\n",
3865 pci_name(pci
), patch
[dev
]);
3866 err
= request_firmware_nowait(THIS_MODULE
, true, patch
[dev
],
3867 &pci
->dev
, GFP_KERNEL
, card
,
3871 schedule_probe
= false; /* continued in azx_firmware_cb() */
3873 #endif /* CONFIG_SND_HDA_PATCH_LOADER */
3875 #ifndef CONFIG_SND_HDA_I915
3876 if (chip
->driver_caps
& AZX_DCAPS_I915_POWERWELL
)
3877 snd_printk(KERN_ERR SFX
"Haswell must build in CONFIG_SND_HDA_I915\n");
3881 schedule_work(&chip
->probe_work
);
3885 complete_all(&chip
->probe_wait
);
3889 snd_card_free(card
);
3893 static int azx_probe_continue(struct azx
*chip
)
3895 struct pci_dev
*pci
= chip
->pci
;
3896 int dev
= chip
->dev_index
;
3899 /* Request power well for Haswell HDA controller and codec */
3900 if (chip
->driver_caps
& AZX_DCAPS_I915_POWERWELL
) {
3901 #ifdef CONFIG_SND_HDA_I915
3902 err
= hda_i915_init();
3904 snd_printk(KERN_ERR SFX
"Error request power-well from i915\n");
3908 hda_display_power(true);
3911 err
= azx_first_init(chip
);
3915 #ifdef CONFIG_SND_HDA_INPUT_BEEP
3916 chip
->beep_mode
= beep_mode
[dev
];
3919 /* create codec instances */
3920 err
= azx_codec_create(chip
, model
[dev
]);
3923 #ifdef CONFIG_SND_HDA_PATCH_LOADER
3925 err
= snd_hda_load_patch(chip
->bus
, chip
->fw
->size
,
3930 release_firmware(chip
->fw
); /* no longer needed */
3935 if ((probe_only
[dev
] & 1) == 0) {
3936 err
= azx_codec_configure(chip
);
3941 /* create PCM streams */
3942 err
= snd_hda_build_pcms(chip
->bus
);
3946 /* create mixer controls */
3947 err
= azx_mixer_create(chip
);
3951 err
= snd_card_register(chip
->card
);
3956 power_down_all_codecs(chip
);
3957 azx_notifier_register(chip
);
3958 azx_add_card_list(chip
);
3959 if ((chip
->driver_caps
& AZX_DCAPS_PM_RUNTIME
) || chip
->use_vga_switcheroo
)
3960 pm_runtime_put_noidle(&pci
->dev
);
3964 chip
->init_failed
= 1;
3965 complete_all(&chip
->probe_wait
);
3969 static void azx_remove(struct pci_dev
*pci
)
3971 struct snd_card
*card
= pci_get_drvdata(pci
);
3974 snd_card_free(card
);
3978 static DEFINE_PCI_DEVICE_TABLE(azx_ids
) = {
3980 { PCI_DEVICE(0x8086, 0x1c20),
3981 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH_NOPM
},
3983 { PCI_DEVICE(0x8086, 0x1d20),
3984 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH_NOPM
},
3986 { PCI_DEVICE(0x8086, 0x1e20),
3987 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH
},
3989 { PCI_DEVICE(0x8086, 0x8c20),
3990 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH
},
3992 { PCI_DEVICE(0x8086, 0x8d20),
3993 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH
},
3994 { PCI_DEVICE(0x8086, 0x8d21),
3995 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH
},
3997 { PCI_DEVICE(0x8086, 0x9c20),
3998 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH
},
4000 { PCI_DEVICE(0x8086, 0x9c21),
4001 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH
},
4002 /* Wildcat Point-LP */
4003 { PCI_DEVICE(0x8086, 0x9ca0),
4004 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH
},
4006 { PCI_DEVICE(0x8086, 0x0a0c),
4007 .driver_data
= AZX_DRIVER_HDMI
| AZX_DCAPS_INTEL_HASWELL
},
4008 { PCI_DEVICE(0x8086, 0x0c0c),
4009 .driver_data
= AZX_DRIVER_HDMI
| AZX_DCAPS_INTEL_HASWELL
},
4010 { PCI_DEVICE(0x8086, 0x0d0c),
4011 .driver_data
= AZX_DRIVER_HDMI
| AZX_DCAPS_INTEL_HASWELL
},
4013 { PCI_DEVICE(0x8086, 0x160c),
4014 .driver_data
= AZX_DRIVER_HDMI
| AZX_DCAPS_INTEL_HASWELL
},
4016 { PCI_DEVICE(0x8086, 0x3b56),
4017 .driver_data
= AZX_DRIVER_SCH
| AZX_DCAPS_INTEL_PCH_NOPM
},
4019 { PCI_DEVICE(0x8086, 0x811b),
4020 .driver_data
= AZX_DRIVER_SCH
| AZX_DCAPS_INTEL_PCH_NOPM
},
4022 { PCI_DEVICE(0x8086, 0x080a),
4023 .driver_data
= AZX_DRIVER_SCH
| AZX_DCAPS_INTEL_PCH_NOPM
},
4025 { PCI_DEVICE(0x8086, 0x0f04),
4026 .driver_data
= AZX_DRIVER_PCH
| AZX_DCAPS_INTEL_PCH_NOPM
},
4028 { PCI_DEVICE(0x8086, 0x2668),
4029 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4030 AZX_DCAPS_BUFSIZE
}, /* ICH6 */
4031 { PCI_DEVICE(0x8086, 0x27d8),
4032 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4033 AZX_DCAPS_BUFSIZE
}, /* ICH7 */
4034 { PCI_DEVICE(0x8086, 0x269a),
4035 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4036 AZX_DCAPS_BUFSIZE
}, /* ESB2 */
4037 { PCI_DEVICE(0x8086, 0x284b),
4038 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4039 AZX_DCAPS_BUFSIZE
}, /* ICH8 */
4040 { PCI_DEVICE(0x8086, 0x293e),
4041 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4042 AZX_DCAPS_BUFSIZE
}, /* ICH9 */
4043 { PCI_DEVICE(0x8086, 0x293f),
4044 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4045 AZX_DCAPS_BUFSIZE
}, /* ICH9 */
4046 { PCI_DEVICE(0x8086, 0x3a3e),
4047 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4048 AZX_DCAPS_BUFSIZE
}, /* ICH10 */
4049 { PCI_DEVICE(0x8086, 0x3a6e),
4050 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_OLD_SSYNC
|
4051 AZX_DCAPS_BUFSIZE
}, /* ICH10 */
4053 { PCI_DEVICE(PCI_VENDOR_ID_INTEL
, PCI_ANY_ID
),
4054 .class = PCI_CLASS_MULTIMEDIA_HD_AUDIO
<< 8,
4055 .class_mask
= 0xffffff,
4056 .driver_data
= AZX_DRIVER_ICH
| AZX_DCAPS_BUFSIZE
},
4057 /* ATI SB 450/600/700/800/900 */
4058 { PCI_DEVICE(0x1002, 0x437b),
4059 .driver_data
= AZX_DRIVER_ATI
| AZX_DCAPS_PRESET_ATI_SB
},
4060 { PCI_DEVICE(0x1002, 0x4383),
4061 .driver_data
= AZX_DRIVER_ATI
| AZX_DCAPS_PRESET_ATI_SB
},
4063 { PCI_DEVICE(0x1022, 0x780d),
4064 .driver_data
= AZX_DRIVER_GENERIC
| AZX_DCAPS_PRESET_ATI_SB
},
4066 { PCI_DEVICE(0x1002, 0x793b),
4067 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4068 { PCI_DEVICE(0x1002, 0x7919),
4069 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4070 { PCI_DEVICE(0x1002, 0x960f),
4071 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4072 { PCI_DEVICE(0x1002, 0x970f),
4073 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4074 { PCI_DEVICE(0x1002, 0xaa00),
4075 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4076 { PCI_DEVICE(0x1002, 0xaa08),
4077 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4078 { PCI_DEVICE(0x1002, 0xaa10),
4079 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4080 { PCI_DEVICE(0x1002, 0xaa18),
4081 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4082 { PCI_DEVICE(0x1002, 0xaa20),
4083 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4084 { PCI_DEVICE(0x1002, 0xaa28),
4085 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4086 { PCI_DEVICE(0x1002, 0xaa30),
4087 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4088 { PCI_DEVICE(0x1002, 0xaa38),
4089 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4090 { PCI_DEVICE(0x1002, 0xaa40),
4091 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4092 { PCI_DEVICE(0x1002, 0xaa48),
4093 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4094 { PCI_DEVICE(0x1002, 0xaa50),
4095 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4096 { PCI_DEVICE(0x1002, 0xaa58),
4097 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4098 { PCI_DEVICE(0x1002, 0xaa60),
4099 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4100 { PCI_DEVICE(0x1002, 0xaa68),
4101 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4102 { PCI_DEVICE(0x1002, 0xaa80),
4103 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4104 { PCI_DEVICE(0x1002, 0xaa88),
4105 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4106 { PCI_DEVICE(0x1002, 0xaa90),
4107 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4108 { PCI_DEVICE(0x1002, 0xaa98),
4109 .driver_data
= AZX_DRIVER_ATIHDMI
| AZX_DCAPS_PRESET_ATI_HDMI
},
4110 { PCI_DEVICE(0x1002, 0x9902),
4111 .driver_data
= AZX_DRIVER_ATIHDMI_NS
| AZX_DCAPS_PRESET_ATI_HDMI
},
4112 { PCI_DEVICE(0x1002, 0xaaa0),
4113 .driver_data
= AZX_DRIVER_ATIHDMI_NS
| AZX_DCAPS_PRESET_ATI_HDMI
},
4114 { PCI_DEVICE(0x1002, 0xaaa8),
4115 .driver_data
= AZX_DRIVER_ATIHDMI_NS
| AZX_DCAPS_PRESET_ATI_HDMI
},
4116 { PCI_DEVICE(0x1002, 0xaab0),
4117 .driver_data
= AZX_DRIVER_ATIHDMI_NS
| AZX_DCAPS_PRESET_ATI_HDMI
},
4118 /* VIA VT8251/VT8237A */
4119 { PCI_DEVICE(0x1106, 0x3288),
4120 .driver_data
= AZX_DRIVER_VIA
| AZX_DCAPS_POSFIX_VIA
},
4121 /* VIA GFX VT7122/VX900 */
4122 { PCI_DEVICE(0x1106, 0x9170), .driver_data
= AZX_DRIVER_GENERIC
},
4123 /* VIA GFX VT6122/VX11 */
4124 { PCI_DEVICE(0x1106, 0x9140), .driver_data
= AZX_DRIVER_GENERIC
},
4126 { PCI_DEVICE(0x1039, 0x7502), .driver_data
= AZX_DRIVER_SIS
},
4128 { PCI_DEVICE(0x10b9, 0x5461), .driver_data
= AZX_DRIVER_ULI
},
4130 { PCI_DEVICE(PCI_VENDOR_ID_NVIDIA
, PCI_ANY_ID
),
4131 .class = PCI_CLASS_MULTIMEDIA_HD_AUDIO
<< 8,
4132 .class_mask
= 0xffffff,
4133 .driver_data
= AZX_DRIVER_NVIDIA
| AZX_DCAPS_PRESET_NVIDIA
},
4135 { PCI_DEVICE(0x6549, 0x1200),
4136 .driver_data
= AZX_DRIVER_TERA
| AZX_DCAPS_NO_64BIT
},
4137 { PCI_DEVICE(0x6549, 0x2200),
4138 .driver_data
= AZX_DRIVER_TERA
| AZX_DCAPS_NO_64BIT
},
4139 /* Creative X-Fi (CA0110-IBG) */
4141 { PCI_DEVICE(0x1102, 0x0010),
4142 .driver_data
= AZX_DRIVER_CTHDA
| AZX_DCAPS_PRESET_CTHDA
},
4143 { PCI_DEVICE(0x1102, 0x0012),
4144 .driver_data
= AZX_DRIVER_CTHDA
| AZX_DCAPS_PRESET_CTHDA
},
4145 #if !defined(CONFIG_SND_CTXFI) && !defined(CONFIG_SND_CTXFI_MODULE)
4146 /* the following entry conflicts with snd-ctxfi driver,
4147 * as ctxfi driver mutates from HD-audio to native mode with
4148 * a special command sequence.
4150 { PCI_DEVICE(PCI_VENDOR_ID_CREATIVE
, PCI_ANY_ID
),
4151 .class = PCI_CLASS_MULTIMEDIA_HD_AUDIO
<< 8,
4152 .class_mask
= 0xffffff,
4153 .driver_data
= AZX_DRIVER_CTX
| AZX_DCAPS_CTX_WORKAROUND
|
4154 AZX_DCAPS_RIRB_PRE_DELAY
| AZX_DCAPS_POSFIX_LPIB
},
4156 /* this entry seems still valid -- i.e. without emu20kx chip */
4157 { PCI_DEVICE(0x1102, 0x0009),
4158 .driver_data
= AZX_DRIVER_CTX
| AZX_DCAPS_CTX_WORKAROUND
|
4159 AZX_DCAPS_RIRB_PRE_DELAY
| AZX_DCAPS_POSFIX_LPIB
},
4162 { PCI_DEVICE(0x17f3, 0x3010), .driver_data
= AZX_DRIVER_GENERIC
},
4163 /* VMware HDAudio */
4164 { PCI_DEVICE(0x15ad, 0x1977), .driver_data
= AZX_DRIVER_GENERIC
},
4165 /* AMD/ATI Generic, PCI class code and Vendor ID for HD Audio */
4166 { PCI_DEVICE(PCI_VENDOR_ID_ATI
, PCI_ANY_ID
),
4167 .class = PCI_CLASS_MULTIMEDIA_HD_AUDIO
<< 8,
4168 .class_mask
= 0xffffff,
4169 .driver_data
= AZX_DRIVER_GENERIC
| AZX_DCAPS_PRESET_ATI_HDMI
},
4170 { PCI_DEVICE(PCI_VENDOR_ID_AMD
, PCI_ANY_ID
),
4171 .class = PCI_CLASS_MULTIMEDIA_HD_AUDIO
<< 8,
4172 .class_mask
= 0xffffff,
4173 .driver_data
= AZX_DRIVER_GENERIC
| AZX_DCAPS_PRESET_ATI_HDMI
},
4176 MODULE_DEVICE_TABLE(pci
, azx_ids
);
4178 /* pci_driver definition */
4179 static struct pci_driver azx_driver
= {
4180 .name
= KBUILD_MODNAME
,
4181 .id_table
= azx_ids
,
4183 .remove
= azx_remove
,
4189 module_pci_driver(azx_driver
);