Staging: unisys: Remove RETINT macro
[linux/fpc-iii.git] / sound / pci / hda / hda_intel.c
blobe354ab1ec20f2dcd942931582761cc10b5543648
1 /*
3 * hda_intel.c - Implementation of primary alsa driver code base
4 * for Intel HD Audio.
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)
14 * any later version.
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
19 * more details.
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.
25 * CONTACTS:
27 * Matt Jared matt.jared@intel.com
28 * Andy Kopp andy.kopp@intel.com
29 * Dan Kogan dan.d.kogan@intel.com
31 * CHANGES:
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>
48 #include <linux/io.h>
49 #include <linux/pm_runtime.h>
50 #include <linux/clocksource.h>
51 #include <linux/time.h>
52 #include <linux/completion.h>
54 #ifdef CONFIG_X86
55 /* for snoop control */
56 #include <asm/pgtable.h>
57 #include <asm/cacheflush.h>
58 #endif
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"
65 #include "hda_i915.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];
81 #endif
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};
85 #endif
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.");
114 #endif
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).");
119 #endif
121 #ifdef CONFIG_PM
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
136 * wake up.
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.");
148 #ifdef CONFIG_X86
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
153 #else
154 #define hda_snoop true
155 #define azx_snoop(chip) true
156 #endif
159 MODULE_LICENSE("GPL");
160 MODULE_SUPPORTED_DEVICE("{{Intel, ICH6},"
161 "{Intel, ICH6M},"
162 "{Intel, ICH7},"
163 "{Intel, ESB2},"
164 "{Intel, ICH8},"
165 "{Intel, ICH9},"
166 "{Intel, ICH10},"
167 "{Intel, PCH},"
168 "{Intel, CPT},"
169 "{Intel, PPT},"
170 "{Intel, LPT},"
171 "{Intel, LPT_LP},"
172 "{Intel, WPT_LP},"
173 "{Intel, HPT},"
174 "{Intel, PBG},"
175 "{Intel, SCH},"
176 "{ATI, SB450},"
177 "{ATI, SB600},"
178 "{ATI, RS600},"
179 "{ATI, RS690},"
180 "{ATI, RS780},"
181 "{ATI, R600},"
182 "{ATI, RV630},"
183 "{ATI, RV610},"
184 "{ATI, RV670},"
185 "{ATI, RV635},"
186 "{ATI, RV620},"
187 "{ATI, RV770},"
188 "{VIA, VT8251},"
189 "{VIA, VT8237A},"
190 "{SiS, SIS966},"
191 "{ULI, M5461}}");
192 MODULE_DESCRIPTION("Intel HDA driver");
194 #ifdef CONFIG_SND_VERBOSE_PRINTK
195 #define SFX /* nop */
196 #else
197 #define SFX "hda-intel "
198 #endif
200 #if defined(CONFIG_PM) && defined(CONFIG_VGA_SWITCHEROO)
201 #if IS_ENABLED(CONFIG_SND_HDA_CODEC_HDMI)
202 #define SUPPORT_VGA_SWITCHEROO
203 #endif
204 #endif
208 * registers
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
284 /* PCI space */
285 #define ICH6_PCIREG_TCSEL 0x44
288 * other constants
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)
328 /* SD_CTL bits */
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|\
342 SD_INT_COMPLETE)
344 /* SD_STS */
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 */
357 enum {
358 POS_FIX_AUTO,
359 POS_FIX_LPIB,
360 POS_FIX_POSBUF,
361 POS_FIX_VIACOMBO,
362 POS_FIX_COMBO,
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
391 struct azx_dev {
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 */
406 /* pcm support */
407 struct snd_pcm_substream *substream; /* assigned substream,
408 * set in PCM open
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;
423 * For VIA:
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;
438 #endif
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)
447 #else
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
452 #endif
454 /* CORB/RIRB */
455 struct azx_rb {
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 */
460 /* for RIRB */
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 */
466 struct azx_pcm {
467 struct azx *chip;
468 struct snd_pcm *pcm;
469 struct hda_codec *codec;
470 struct hda_pcm_stream *hinfo[2];
471 struct list_head list;
474 struct azx {
475 struct snd_card *card;
476 struct pci_dev *pci;
477 int dev_index;
479 /* chip type specific */
480 int driver_type;
481 unsigned int driver_caps;
482 int playback_streams;
483 int playback_index_offset;
484 int capture_streams;
485 int capture_index_offset;
486 int num_streams;
488 /* pci resources */
489 unsigned long addr;
490 void __iomem *remap_addr;
491 int irq;
493 /* locks */
494 spinlock_t reg_lock;
495 struct mutex open_mutex;
496 struct completion probe_wait;
498 /* streams (x num_streams) */
499 struct azx_dev *azx_dev;
501 /* PCM */
502 struct list_head pcm_list; /* azx_pcm list */
504 /* HD codec */
505 unsigned short codec_mask;
506 int codec_probe_mask; /* copied from probe_mask option */
507 struct hda_bus *bus;
508 unsigned int beep_mode;
510 /* CORB/RIRB */
511 struct azx_rb corb;
512 struct azx_rb rirb;
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;
520 #endif
522 /* flags */
523 int position_fix[2]; /* for both playback/capture streams */
524 int poll_count;
525 unsigned int running :1;
526 unsigned int initialized :1;
527 unsigned int single_cmd :1;
528 unsigned int polling_mode :1;
529 unsigned int msi :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 */
542 /* for debugging */
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;
558 #endif
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"
567 /* driver types */
568 enum {
569 AZX_DRIVER_ICH,
570 AZX_DRIVER_PCH,
571 AZX_DRIVER_SCH,
572 AZX_DRIVER_HDMI,
573 AZX_DRIVER_ATI,
574 AZX_DRIVER_ATIHDMI,
575 AZX_DRIVER_ATIHDMI_NS,
576 AZX_DRIVER_VIA,
577 AZX_DRIVER_SIS,
578 AZX_DRIVER_ULI,
579 AZX_DRIVER_NVIDIA,
580 AZX_DRIVER_TERA,
581 AZX_DRIVER_CTX,
582 AZX_DRIVER_CTHDA,
583 AZX_DRIVER_GENERIC,
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)
644 #else
645 #define use_vga_switcheroo(chip) 0
646 #endif
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)
698 #ifdef CONFIG_X86
699 static void __mark_pages_wc(struct azx *chip, struct snd_dma_buffer *dmab, bool on)
701 int pages;
703 if (azx_snoop(chip))
704 return;
705 if (!dmab || !dmab->area || !dmab->bytes)
706 return;
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;
711 if (on)
712 set_pages_array_wc(sgbuf->page_table, sgbuf->pages);
713 else
714 set_pages_array_wb(sgbuf->page_table, sgbuf->pages);
715 return;
717 #endif
719 pages = (dmab->bytes + PAGE_SIZE - 1) >> PAGE_SHIFT;
720 if (on)
721 set_memory_wc((unsigned long)dmab->area, pages);
722 else
723 set_memory_wb((unsigned long)dmab->area, pages);
726 static inline void mark_pages_wc(struct azx *chip, struct snd_dma_buffer *buf,
727 bool on)
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;
739 #else
740 /* NOP for other archs */
741 static inline void mark_pages_wc(struct azx *chip, struct snd_dma_buffer *buf,
742 bool on)
745 static inline void mark_runtime_wc(struct azx *chip, struct azx_dev *azx_dev,
746 struct snd_pcm_substream *substream, bool on)
749 #endif
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)
762 int err;
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);
768 if (err < 0) {
769 snd_printk(KERN_ERR SFX "%s: cannot allocate CORB/RIRB\n", pci_name(chip->pci));
770 return err;
772 mark_pages_wc(chip, &chip->rb, true);
773 return 0;
776 static void azx_init_cmd_io(struct azx *chip)
778 spin_lock_irq(&chip->reg_lock);
779 /* CORB set up */
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);
794 /* RIRB set up */
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);
809 else
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) {
830 snd_BUG();
831 addr = 0;
834 return addr;
837 static unsigned int azx_response_addr(u32 res)
839 unsigned int addr = res & 0xf;
841 if (addr >= AZX_MAX_CODECS) {
842 snd_BUG();
843 addr = 0;
846 return addr;
849 /* send a command */
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);
854 unsigned int wp, rp;
856 spin_lock_irq(&chip->reg_lock);
858 /* add command to corb */
859 wp = azx_readw(chip, CORBWP);
860 if (wp == 0xffff) {
861 /* something wrong, controller likely turned to D3 */
862 spin_unlock_irq(&chip->reg_lock);
863 return -EIO;
865 wp++;
866 wp %= ICH6_MAX_CORB_ENTRIES;
868 rp = azx_readw(chip, CORBRP);
869 if (wp == rp) {
870 /* oops, it's full */
871 spin_unlock_irq(&chip->reg_lock);
872 return -EAGAIN;
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);
881 return 0;
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)
889 unsigned int rp, wp;
890 unsigned int addr;
891 u32 res, res_ex;
893 wp = azx_readw(chip, RIRBWP);
894 if (wp == 0xffff) {
895 /* something wrong, controller likely turned to D3 */
896 return;
899 if (wp == chip->rirb.wp)
900 return;
901 chip->rirb.wp = wp;
903 while (chip->rirb.rp != wp) {
904 chip->rirb.rp++;
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;
915 smp_wmb();
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",
919 pci_name(chip->pci),
920 res, res_ex,
921 chip->last_cmd[addr]);
926 /* receive a response */
927 static unsigned int azx_rirb_get_response(struct hda_bus *bus,
928 unsigned int addr)
930 struct azx *chip = bus->private_data;
931 unsigned long timeout;
932 unsigned long loopcounter;
933 int do_poll = 0;
935 again:
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]) {
945 smp_rmb();
946 bus->rirb_error = 0;
948 if (!do_poll)
949 chip->poll_count = 0;
950 return chip->rirb.res[addr]; /* the last value */
952 if (time_after(jiffies, timeout))
953 break;
954 if (bus->needs_damn_long_delay || loopcounter > 3000)
955 msleep(2); /* temporary workaround */
956 else {
957 udelay(10);
958 cond_resched();
962 if (!bus->no_response_fallback)
963 return -1;
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]);
969 do_poll = 1;
970 chip->poll_count++;
971 goto again;
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;
980 goto again;
983 if (chip->msi) {
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);
988 chip->irq = -1;
989 pci_disable_msi(chip->pci);
990 chip->msi = 0;
991 if (azx_acquire_irq(chip, 1) < 0) {
992 bus->rirb_error = 1;
993 return -1;
995 goto again;
998 if (chip->probing) {
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.
1003 return -1;
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);
1024 return -1;
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
1033 * driver.
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)
1040 int timeout = 50;
1042 while (timeout--) {
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);
1047 return 0;
1049 udelay(1);
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;
1055 return -EIO;
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);
1063 int timeout = 50;
1065 bus->rirb_error = 0;
1066 while (timeout--) {
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) |
1071 ICH6_IRS_VALID);
1072 azx_writel(chip, IC, val);
1073 azx_writew(chip, IRS, azx_readw(chip, IRS) |
1074 ICH6_IRS_BUSY);
1075 return azx_single_wait_for_response(chip, addr);
1077 udelay(1);
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);
1082 return -EIO;
1085 /* receive a response */
1086 static unsigned int azx_single_get_response(struct hda_bus *bus,
1087 unsigned int addr)
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;
1105 if (chip->disabled)
1106 return 0;
1107 chip->last_cmd[azx_command_addr(val)] = val;
1108 if (chip->single_cmd)
1109 return azx_single_send_cmd(bus, val);
1110 else
1111 return azx_corb_send_cmd(bus, val);
1114 /* get a response */
1115 static unsigned int azx_get_response(struct hda_bus *bus,
1116 unsigned int addr)
1118 struct azx *chip = bus->private_data;
1119 if (chip->disabled)
1120 return 0;
1121 if (chip->single_cmd)
1122 return azx_single_get_response(bus, addr);
1123 else
1124 return azx_rirb_get_response(bus, addr);
1127 #ifdef CONFIG_PM
1128 static void azx_power_notify(struct hda_bus *bus, bool power_up);
1129 #endif
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);
1138 #endif
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)
1170 if (!full_reset)
1171 goto __skip;
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);
1190 __skip:
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));
1194 return -EBUSY;
1197 /* Accept unsolicited responses */
1198 if (!chip->single_cmd)
1199 azx_writel(chip, GCTL, azx_readl(chip, GCTL) |
1200 ICH6_GCTL_UNSOL);
1202 /* detect codecs */
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);
1208 return 0;
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)
1227 int i;
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)
1247 int i;
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;
1273 /* enable SIE */
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);
1281 /* stop DMA */
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 */
1289 /* stop a stream */
1290 static void azx_stream_stop(struct azx *chip, struct azx_dev *azx_dev)
1292 azx_stream_clear(chip, azx_dev);
1293 /* disable SIE */
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)
1305 return;
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)
1332 unsigned char data;
1334 pci_read_config_byte(pci, reg, &data);
1335 data &= ~mask;
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
1345 * codecs.
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);
1400 * interrupt handler
1402 static irqreturn_t azx_interrupt(int irq, void *dev_id)
1404 struct azx *chip = dev_id;
1405 struct azx_dev *azx_dev;
1406 u32 status;
1407 u8 sd_status;
1408 int i, ok;
1410 #ifdef CONFIG_PM_RUNTIME
1411 if (chip->driver_caps & AZX_DCAPS_PM_RUNTIME)
1412 if (chip->pci->dev.power.runtime_status != RPM_ACTIVE)
1413 return IRQ_NONE;
1414 #endif
1416 spin_lock(&chip->reg_lock);
1418 if (chip->disabled) {
1419 spin_unlock(&chip->reg_lock);
1420 return IRQ_NONE;
1423 status = azx_readl(chip, INTSTS);
1424 if (status == 0 || status == 0xffffffff) {
1425 spin_unlock(&chip->reg_lock);
1426 return IRQ_NONE;
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))
1436 continue;
1437 /* check whether this IRQ is really acceptable */
1438 ok = azx_position_ok(chip, azx_dev);
1439 if (ok == 1) {
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)
1458 udelay(80);
1459 azx_update_rirb(chip);
1461 azx_writeb(chip, RIRBSTS, RIRB_INT_MASK);
1464 #if 0
1465 /* clear state status int */
1466 if (azx_readw(chip, STATESTS) & 0x04)
1467 azx_writew(chip, STATESTS, 0x04);
1468 #endif
1469 spin_unlock(&chip->reg_lock);
1471 return IRQ_HANDLED;
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)
1483 u32 *bdl = *bdlp;
1485 while (size > 0) {
1486 dma_addr_t addr;
1487 int chunk;
1489 if (azx_dev->frags >= AZX_MAX_BDL_ENTRIES)
1490 return -EINVAL;
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);
1501 if (chunk > remain)
1502 chunk = remain;
1504 bdl[2] = cpu_to_le32(chunk);
1505 /* program the IOC to enable interrupt
1506 * only when the whole fragment is processed
1508 size -= chunk;
1509 bdl[3] = (size || !with_ioc) ? 0 : cpu_to_le32(0x01);
1510 bdl += 4;
1511 azx_dev->frags++;
1512 ofs += chunk;
1514 *bdlp = bdl;
1515 return ofs;
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)
1525 u32 *bdl;
1526 int i, ofs, periods, period_bytes;
1527 int pos_adj;
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;
1538 ofs = 0;
1539 azx_dev->frags = 0;
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;
1545 if (!pos_adj)
1546 pos_adj = pos_align;
1547 else
1548 pos_adj = ((pos_adj + pos_align - 1) / pos_align) *
1549 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]);
1554 pos_adj = 0;
1555 } else {
1556 ofs = setup_bdle(chip, snd_pcm_get_dma_buf(substream),
1557 azx_dev,
1558 &bdl, ofs, pos_adj, true);
1559 if (ofs < 0)
1560 goto error;
1562 } else
1563 pos_adj = 0;
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),
1567 azx_dev, &bdl, ofs,
1568 period_bytes - pos_adj, 0);
1569 else
1570 ofs = setup_bdle(chip, snd_pcm_get_dma_buf(substream),
1571 azx_dev, &bdl, ofs,
1572 period_bytes,
1573 !azx_dev->no_period_wakeup);
1574 if (ofs < 0)
1575 goto error;
1577 return 0;
1579 error:
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);
1582 return -EINVAL;
1585 /* reset stream */
1586 static void azx_stream_reset(struct azx *chip, struct azx_dev *azx_dev)
1588 unsigned char val;
1589 int timeout;
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);
1595 udelay(3);
1596 timeout = 300;
1597 while (!((val = azx_sd_readb(azx_dev, SD_CTL)) & SD_CTL_STREAM_RESET) &&
1598 --timeout)
1600 val &= ~SD_CTL_STREAM_RESET;
1601 azx_sd_writeb(azx_dev, SD_CTL, val);
1602 udelay(3);
1604 timeout = 300;
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) &&
1607 --timeout)
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)
1619 unsigned int val;
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);
1658 return 0;
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;
1668 unsigned int res;
1670 mutex_lock(&chip->bus->cmd_mutex);
1671 chip->probing = 1;
1672 azx_send_cmd(chip->bus, cmd);
1673 res = azx_get_response(chip->bus, addr);
1674 chip->probing = 0;
1675 mutex_unlock(&chip->bus->cmd_mutex);
1676 if (res == -1)
1677 return -EIO;
1678 snd_printdd(SFX "%s: codec #%d probed OK\n", pci_name(chip->pci), addr);
1679 return 0;
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;
1690 bus->in_reset = 1;
1691 azx_stop_chip(chip);
1692 azx_init_chip(chip, 1);
1693 #ifdef CONFIG_PM
1694 if (chip->initialized) {
1695 struct azx_pcm *p;
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);
1701 #endif
1702 bus->in_reset = 0;
1705 static int get_jackpoll_interval(struct azx *chip)
1707 int i = jackpoll_ms[chip->dev_index];
1708 unsigned int j;
1709 if (i == 0)
1710 return 0;
1711 if (i < 50 || i > 60000)
1712 j = 0;
1713 else
1714 j = msecs_to_jiffies(i);
1715 if (j == 0)
1716 snd_printk(KERN_WARNING SFX
1717 "jackpoll_ms value out of range: %d\n", i);
1718 return j;
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;
1734 int c, codecs, err;
1735 int max_slots;
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;
1745 #ifdef CONFIG_PM
1746 bus_temp.power_save = &power_save;
1747 bus_temp.ops.pm_notify = azx_power_notify;
1748 #endif
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;
1753 #endif
1755 err = snd_hda_bus_new(chip->card, &bus_temp, &chip->bus);
1756 if (err < 0)
1757 return err;
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;
1764 codecs = 0;
1765 max_slots = azx_max_codecs[chip->driver_type];
1766 if (!max_slots)
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
1774 * that don't exist
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);
1809 if (err < 0)
1810 continue;
1811 codec->jackpoll_interval = get_jackpoll_interval(chip);
1812 codec->beep_mode = chip->beep_mode;
1813 codecs++;
1816 if (!codecs) {
1817 snd_printk(KERN_ERR SFX "%s: no codecs initialized\n", pci_name(chip->pci));
1818 return -ENXIO;
1820 return 0;
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);
1830 return 0;
1835 * PCM support
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)
1842 int dev, i, nums;
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;
1851 } else {
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];
1857 dsp_lock(azx_dev);
1858 if (!azx_dev->opened && !dsp_is_locked(azx_dev)) {
1859 res = azx_dev;
1860 if (res->assigned_key == key) {
1861 res->opened = 1;
1862 res->assigned_key = key;
1863 dsp_unlock(azx_dev);
1864 return azx_dev;
1867 dsp_unlock(azx_dev);
1869 if (res) {
1870 dsp_lock(res);
1871 res->opened = 1;
1872 res->assigned_key = key;
1873 dsp_unlock(res);
1875 return res;
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;
1900 u64 nsec;
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 */
1916 cc->shift = 0;
1918 nsec = 0; /* audio time is elapsed time since trigger */
1919 timecounter_init(tc, cc, nsec);
1920 if (force)
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,
1929 u64 nsec)
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)
1936 return nsec;
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);
1952 u64 nsec;
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);
1960 return 0;
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,
1976 .rate_min = 48000,
1977 .rate_max = 48000,
1978 .channels_min = 2,
1979 .channels_max = 2,
1980 .buffer_bytes_max = AZX_MAX_BUF_SIZE,
1981 .period_bytes_min = 128,
1982 .period_bytes_max = AZX_MAX_BUF_SIZE / 2,
1983 .periods_min = 2,
1984 .periods_max = AZX_MAX_FRAG,
1985 .fifo_size = 0,
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;
1996 int err;
1997 int buff_step;
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);
2003 return -EBUSY;
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,
2016 178000000);
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. */
2025 buff_step = 128;
2026 else
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 */
2031 buff_step = 4;
2033 snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_BUFFER_BYTES,
2034 buff_step);
2035 snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES,
2036 buff_step);
2037 snd_hda_power_up_d3wait(apcm->codec);
2038 err = hinfo->ops.open(hinfo, apcm->codec, substream);
2039 if (err < 0) {
2040 azx_release_device(azx_dev);
2041 snd_hda_power_down(apcm->codec);
2042 mutex_unlock(&chip->open_mutex);
2043 return err;
2045 snd_pcm_limit_hw_rates(runtime);
2046 /* sanity check */
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);
2055 return -EINVAL;
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);
2071 return 0;
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);
2091 return 0;
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);
2100 int ret;
2102 dsp_lock(azx_dev);
2103 if (dsp_is_locked(azx_dev)) {
2104 ret = -EBUSY;
2105 goto unlock;
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));
2114 if (ret < 0)
2115 goto unlock;
2116 mark_runtime_wc(chip, azx_dev, substream, true);
2117 unlock:
2118 dsp_unlock(azx_dev);
2119 return ret;
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 */
2130 dsp_lock(azx_dev);
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;
2156 int err;
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;
2161 dsp_lock(azx_dev);
2162 if (dsp_is_locked(azx_dev)) {
2163 err = -EBUSY;
2164 goto unlock;
2167 azx_stream_reset(chip, azx_dev);
2168 format_val = snd_hda_calc_stream_format(runtime->rate,
2169 runtime->channels,
2170 runtime->format,
2171 hinfo->maxbps,
2172 ctls);
2173 if (!format_val) {
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);
2177 err = -EINVAL;
2178 goto unlock;
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);
2196 if (err < 0)
2197 goto unlock;
2200 /* when LPIB delay correction gives a small negative value,
2201 * we ignore it; currently set the threshold statically to
2202 * 64 frames
2204 if (runtime->period_size > 64)
2205 azx_dev->delay_negative_threshold = -frames_to_bytes(runtime, 64);
2206 else
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;
2215 else
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);
2226 unlock:
2227 if (!err)
2228 azx_dev->prepared = 1;
2229 dsp_unlock(azx_dev);
2230 return err;
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;
2240 int nwait, timeout;
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)
2246 return -EPIPE;
2248 switch (cmd) {
2249 case SNDRV_PCM_TRIGGER_START:
2250 rstart = 1;
2251 case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
2252 case SNDRV_PCM_TRIGGER_RESUME:
2253 start = 1;
2254 break;
2255 case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
2256 case SNDRV_PCM_TRIGGER_SUSPEND:
2257 case SNDRV_PCM_TRIGGER_STOP:
2258 start = 0;
2259 break;
2260 default:
2261 return -EINVAL;
2264 snd_pcm_group_for_each_entry(s, substream) {
2265 if (s->pcm->card != substream->pcm->card)
2266 continue;
2267 azx_dev = get_azx_dev(s);
2268 sbits |= 1 << azx_dev->index;
2269 nsync++;
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);
2279 else
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)
2284 continue;
2285 azx_dev = get_azx_dev(s);
2286 if (start) {
2287 azx_dev->start_wallclk = azx_readl(chip, WALLCLK);
2288 if (!rstart)
2289 azx_dev->start_wallclk -=
2290 azx_dev->period_wallclk;
2291 azx_stream_start(chip, azx_dev);
2292 } else {
2293 azx_stream_stop(chip, azx_dev);
2295 azx_dev->running = start;
2297 spin_unlock(&chip->reg_lock);
2298 if (start) {
2299 /* wait until all FIFOs get ready */
2300 for (timeout = 5000; timeout; timeout--) {
2301 nwait = 0;
2302 snd_pcm_group_for_each_entry(s, substream) {
2303 if (s->pcm->card != substream->pcm->card)
2304 continue;
2305 azx_dev = get_azx_dev(s);
2306 if (!(azx_sd_readb(azx_dev, SD_STS) &
2307 SD_STS_FIFO_READY))
2308 nwait++;
2310 if (!nwait)
2311 break;
2312 cpu_relax();
2314 } else {
2315 /* wait until all RUN bits are cleared */
2316 for (timeout = 5000; timeout; timeout--) {
2317 nwait = 0;
2318 snd_pcm_group_for_each_entry(s, substream) {
2319 if (s->pcm->card != substream->pcm->card)
2320 continue;
2321 azx_dev = get_azx_dev(s);
2322 if (azx_sd_readb(azx_dev, SD_CTL) &
2323 SD_CTL_DMA_START)
2324 nwait++;
2326 if (!nwait)
2327 break;
2328 cpu_relax();
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);
2336 else
2337 azx_writel(chip, SSYNC, azx_readl(chip, SSYNC) & ~sbits);
2338 if (start) {
2339 azx_timecounter_init(substream, 0, 0);
2340 if (nsync > 1) {
2341 cycle_t cycle_last;
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)
2349 continue;
2350 azx_timecounter_init(s, 1, cycle_last);
2354 spin_unlock(&chip->reg_lock);
2355 return 0;
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 */
2369 return link_pos;
2372 /* Capture */
2373 /* For new chipset,
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)
2387 return 0;
2389 azx_dev->insufficient = 0;
2392 if (link_pos <= fifo_size)
2393 mini_pos = azx_dev->bufsize + link_pos - fifo_size;
2394 else
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;
2404 else {
2405 bound_pos = mini_pos - mod_mini_pos + azx_dev->period_bytes;
2406 if (bound_pos >= azx_dev->bufsize)
2407 bound_pos = 0;
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,
2416 bool with_check)
2418 struct snd_pcm_substream *substream = azx_dev->substream;
2419 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
2420 unsigned int pos;
2421 int stream = substream->stream;
2422 struct hda_pcm_stream *hinfo = apcm->hinfo[stream];
2423 int delay = 0;
2425 switch (chip->position_fix[stream]) {
2426 case POS_FIX_LPIB:
2427 /* read LPIB */
2428 pos = azx_sd_readl(azx_dev, SD_LPIB);
2429 break;
2430 case POS_FIX_VIACOMBO:
2431 pos = azx_via_get_position(chip, azx_dev);
2432 break;
2433 default:
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) {
2438 printk(KERN_WARNING
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);
2443 } else
2444 chip->position_fix[stream] = POS_FIX_POSBUF;
2446 break;
2449 if (pos >= azx_dev->bufsize)
2450 pos = 0;
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;
2459 else
2460 delay = lpib_pos - pos;
2461 if (delay < 0) {
2462 if (delay >= azx_dev->delay_negative_threshold)
2463 delay = 0;
2464 else
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);
2472 delay = 0;
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,
2481 substream);
2482 substream->runtime->delay = delay;
2485 trace_azx_get_position(chip, azx_dev, pos, delay);
2486 return pos;
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
2505 * workqueue.
2507 static int azx_position_ok(struct azx *chip, struct azx_dev *azx_dev)
2509 u32 wallclk;
2510 unsigned int pos;
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);
2535 int i, pending, ok;
2537 if (!chip->irq_pending_warned) {
2538 printk(KERN_WARNING
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;
2545 for (;;) {
2546 pending = 0;
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 ||
2552 !azx_dev->running)
2553 continue;
2554 ok = azx_position_ok(chip, azx_dev);
2555 if (ok > 0) {
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 */
2562 } else
2563 pending++;
2565 spin_unlock_irq(&chip->reg_lock);
2566 if (!pending)
2567 return;
2568 msleep(1);
2572 /* clear irq_pending flags and assure no on-going workq */
2573 static void azx_clear_irq_pending(struct azx *chip)
2575 int i;
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);
2583 #ifdef CONFIG_X86
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);
2593 #else
2594 #define azx_pcm_mmap NULL
2595 #endif
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;
2614 if (apcm) {
2615 list_del(&apcm->list);
2616 kfree(apcm);
2620 #define MAX_PREALLOC_SIZE (32 * 1024 * 1024)
2622 static int
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;
2630 unsigned int size;
2631 int s, err;
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);
2637 return -EBUSY;
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,
2643 &pcm);
2644 if (err < 0)
2645 return err;
2646 strlcpy(pcm->name, cpcm->name, sizeof(pcm->name));
2647 apcm = kzalloc(sizeof(*apcm), GFP_KERNEL);
2648 if (apcm == NULL)
2649 return -ENOMEM;
2650 apcm->chip = chip;
2651 apcm->pcm = pcm;
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);
2658 cpcm->pcm = pcm;
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);
2671 return 0;
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)
2688 int i;
2690 /* initialize each stream (aka device)
2691 * assign the starting bdl address to each stream (device)
2692 * and initialize
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 */
2702 azx_dev->index = i;
2703 azx_dev->stream_tag = i + 1;
2706 return 0;
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);
2716 if (do_disconnect)
2717 snd_card_disconnect(chip->card);
2718 return -1;
2720 chip->irq = chip->pci->irq;
2721 pci_intx(chip->pci, !chip->msi);
2722 return 0;
2726 static void azx_stop_chip(struct azx *chip)
2728 if (!chip->initialized)
2729 return;
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)
2761 u32 *bdl;
2762 struct azx *chip = bus->private_data;
2763 struct azx_dev *azx_dev;
2764 int err;
2766 azx_dev = azx_get_dsp_loader_dev(chip);
2768 dsp_lock(azx_dev);
2769 spin_lock_irq(&chip->reg_lock);
2770 if (azx_dev->running || azx_dev->locked) {
2771 spin_unlock_irq(&chip->reg_lock);
2772 err = -EBUSY;
2773 goto unlock;
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),
2782 byte_size, bufp);
2783 if (err < 0)
2784 goto err_alloc;
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);
2797 azx_dev->frags = 0;
2798 bdl = (u32 *)azx_dev->bdl.area;
2799 err = setup_bdle(chip, bufp, azx_dev, &bdl, 0, byte_size, 0);
2800 if (err < 0)
2801 goto error;
2803 azx_setup_controller(chip, azx_dev);
2804 dsp_unlock(azx_dev);
2805 return azx_dev->stream_tag;
2807 error:
2808 mark_pages_wc(chip, bufp, false);
2809 snd_dma_free_pages(bufp);
2810 err_alloc:
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);
2816 unlock:
2817 dsp_unlock(azx_dev);
2818 return err;
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);
2826 if (start)
2827 azx_stream_start(chip, azx_dev);
2828 else
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)
2840 return;
2842 dsp_lock(azx_dev);
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);
2853 dmab->area = NULL;
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 */
2864 #ifdef CONFIG_PM
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))
2871 return;
2873 if (power_up)
2874 pm_runtime_get_sync(&chip->pci->dev);
2875 else
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)
2899 struct azx *chip;
2900 struct hda_codec *c;
2901 int prev = power_save;
2902 int ret = param_set_int(val, kp);
2904 if (ret || prev == power_save)
2905 return ret;
2907 mutex_lock(&card_list_lock);
2908 list_for_each_entry(chip, &card_list, list) {
2909 if (!chip->bus || chip->disabled)
2910 continue;
2911 list_for_each_entry(c, &chip->bus->codec_list, list)
2912 snd_hda_power_sync(c);
2914 mutex_unlock(&card_list_lock);
2915 return 0;
2917 #else
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)
2924 * power management
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;
2931 struct azx_pcm *p;
2933 if (chip->disabled)
2934 return 0;
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);
2946 chip->irq = -1;
2948 if (chip->msi)
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);
2955 return 0;
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;
2964 if (chip->disabled)
2965 return 0;
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);
2975 return -EIO;
2977 pci_set_master(pci);
2978 if (chip->msi)
2979 if (pci_enable_msi(pci) < 0)
2980 chip->msi = 0;
2981 if (azx_acquire_irq(chip, 1) < 0)
2982 return -EIO;
2983 azx_init_pci(chip);
2985 azx_init_chip(chip, 1);
2987 snd_hda_resume(chip->bus);
2988 snd_power_change_state(card, SNDRV_CTL_POWER_D0);
2989 return 0;
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;
2999 if (chip->disabled)
3000 return 0;
3002 if (!(chip->driver_caps & AZX_DCAPS_PM_RUNTIME))
3003 return 0;
3005 /* enable controller wake up event */
3006 azx_writew(chip, WAKEEN, azx_readw(chip, WAKEEN) |
3007 STATESTS_INT_MASK);
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);
3014 return 0;
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;
3023 int status;
3025 if (chip->disabled)
3026 return 0;
3028 if (!(chip->driver_caps & AZX_DCAPS_PM_RUNTIME))
3029 return 0;
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);
3037 azx_init_pci(chip);
3038 azx_init_chip(chip, 1);
3040 bus = chip->bus;
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);
3052 return 0;
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;
3060 if (chip->disabled)
3061 return 0;
3063 if (!power_save_controller ||
3064 !(chip->driver_caps & AZX_DCAPS_PM_RUNTIME))
3065 return -EBUSY;
3067 return 0;
3070 #endif /* CONFIG_PM_RUNTIME */
3072 #ifdef CONFIG_PM
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
3079 #else
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);
3092 return NOTIFY_OK;
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;
3117 bool disabled;
3119 wait_for_completion(&chip->probe_wait);
3120 if (chip->init_failed)
3121 return;
3123 disabled = (state == VGA_SWITCHEROO_OFF);
3124 if (chip->disabled == disabled)
3125 return;
3127 if (!chip->bus) {
3128 chip->disabled = disabled;
3129 if (!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;
3140 } else {
3141 snd_printk(KERN_INFO SFX
3142 "%s: %s via VGA-switcheroo\n", pci_name(chip->pci),
3143 disabled ? "Disabling" : "Enabling");
3144 if (disabled) {
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));
3155 } else {
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)
3171 return false;
3172 if (chip->disabled || !chip->bus)
3173 return true;
3174 if (snd_hda_lock_devices(chip->bus))
3175 return false;
3176 snd_hda_unlock_devices(chip->bus);
3177 return true;
3180 static void init_vga_switcheroo(struct azx *chip)
3182 struct pci_dev *p = get_bound_vga(chip->pci);
3183 if (p) {
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;
3188 pci_dev_put(p);
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)
3199 int err;
3201 if (!chip->use_vga_switcheroo)
3202 return 0;
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,
3207 VGA_SWITCHEROO_DIS,
3208 chip->bus != NULL);
3209 if (err < 0)
3210 return err;
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);
3215 return 0;
3217 #else
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 */
3224 * destructor
3226 static int azx_free(struct azx *chip)
3228 struct pci_dev *pci = chip->pci;
3229 int i;
3231 if ((chip->driver_caps & AZX_DCAPS_PM_RUNTIME)
3232 && chip->running)
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);
3256 if (chip->irq >= 0)
3257 free_irq(chip->irq, (void*)chip);
3258 if (chip->msi)
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
3283 if (chip->fw)
3284 release_firmware(chip->fw);
3285 #endif
3286 if (chip->driver_caps & AZX_DCAPS_I915_POWERWELL) {
3287 hda_display_power(false);
3288 hda_i915_exit();
3290 kfree(chip);
3292 return 0;
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)
3306 struct pci_dev *p;
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);
3316 if (p) {
3317 if ((p->class >> 8) == PCI_CLASS_DISPLAY_VGA)
3318 return p;
3319 pci_dev_put(p);
3322 break;
3324 return NULL;
3327 static bool check_hdmi_disabled(struct pci_dev *pci)
3329 bool vga_inactive = false;
3330 struct pci_dev *p = get_bound_vga(pci);
3332 if (p) {
3333 if (vga_switcheroo_get_client_state(p) == VGA_SWITCHEROO_OFF)
3334 vga_inactive = true;
3335 pci_dev_put(p);
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;
3366 switch (fix) {
3367 case POS_FIX_AUTO:
3368 case POS_FIX_LPIB:
3369 case POS_FIX_POSBUF:
3370 case POS_FIX_VIACOMBO:
3371 case POS_FIX_COMBO:
3372 return fix;
3375 q = snd_pci_quirk_lookup(chip->pci, position_fix_list);
3376 if (q) {
3377 printk(KERN_INFO
3378 "hda_intel: position_fix set to %d "
3379 "for device %04x:%04x\n",
3380 q->value, q->subvendor, q->subdevice);
3381 return q->value;
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),
3406 /* broken BIOS */
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);
3427 if (q) {
3428 printk(KERN_INFO
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",
3441 chip->codec_mask);
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;
3468 return;
3470 chip->msi = 1; /* enable MSI as default */
3471 q = snd_pci_quirk_lookup(chip->pci, msi_black_list);
3472 if (q) {
3473 printk(KERN_INFO
3474 "hda_intel: msi for device %04x:%04x set to %d\n",
3475 q->subvendor, q->subdevice, q->value);
3476 chip->msi = q->value;
3477 return;
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");
3483 chip->msi = 0;
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
3495 * when BIOS is set
3497 if (snoop) {
3498 u8 val;
3499 pci_read_config_byte(chip->pci, 0x42, &val);
3500 if (!(val & 0x80) && chip->pci->revision == 0x30)
3501 snoop = false;
3503 break;
3504 case AZX_DRIVER_ATIHDMI_NS:
3505 /* new ATI HDMI requires non-snoop */
3506 snoop = false;
3507 break;
3508 case AZX_DRIVER_CTHDA:
3509 snoop = false;
3510 break;
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));
3526 * constructor
3528 static int azx_create(struct snd_card *card, struct pci_dev *pci,
3529 int dev, unsigned int driver_caps,
3530 struct azx **rchip)
3532 static struct snd_device_ops ops = {
3533 .dev_free = azx_dev_free,
3535 struct azx *chip;
3536 int err;
3538 *rchip = NULL;
3540 err = pci_enable_device(pci);
3541 if (err < 0)
3542 return err;
3544 chip = kzalloc(sizeof(*chip), GFP_KERNEL);
3545 if (!chip) {
3546 snd_printk(KERN_ERR SFX "%s: Cannot allocate chip\n", pci_name(pci));
3547 pci_disable_device(pci);
3548 return -ENOMEM;
3551 spin_lock_init(&chip->reg_lock);
3552 mutex_init(&chip->open_mutex);
3553 chip->card = card;
3554 chip->pci = pci;
3555 chip->irq = -1;
3556 chip->driver_caps = driver_caps;
3557 chip->driver_type = driver_caps & 0xff;
3558 check_msi(chip);
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;
3585 break;
3586 default:
3587 bdl_pos_adj[dev] = 32;
3588 break;
3592 err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops);
3593 if (err < 0) {
3594 snd_printk(KERN_ERR SFX "%s: Error creating device [card]!\n",
3595 pci_name(chip->pci));
3596 azx_free(chip);
3597 return err;
3600 /* continue probing in work context as may trigger request module */
3601 INIT_WORK(&chip->probe_work, azx_probe_work);
3603 *rchip = chip;
3605 return 0;
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;
3613 int i, err;
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) {
3619 u16 tmp3;
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);
3624 #endif
3626 err = pci_request_regions(pci, "ICH HD audio");
3627 if (err < 0)
3628 return err;
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));
3635 return -ENXIO;
3638 if (chip->msi)
3639 if (pci_enable_msi(pci) < 0)
3640 chip->msi = 0;
3642 if (azx_acquire_irq(chip, 0) < 0)
3643 return -EBUSY;
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,
3656 NULL);
3657 if (p_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;
3673 else {
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;
3678 else
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));
3685 else {
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
3691 * hardcoded value
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;
3702 break;
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;
3707 break;
3708 case AZX_DRIVER_GENERIC:
3709 default:
3710 chip->playback_streams = ICH6_NUM_PLAYBACK;
3711 chip->capture_streams = ICH6_NUM_CAPTURE;
3712 break;
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),
3719 GFP_KERNEL);
3720 if (!chip->azx_dev) {
3721 snd_printk(KERN_ERR SFX "%s: cannot malloc azx_dev\n", pci_name(chip->pci));
3722 return -ENOMEM;
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);
3731 if (err < 0) {
3732 snd_printk(KERN_ERR SFX "%s: cannot allocate BDL\n", pci_name(chip->pci));
3733 return -ENOMEM;
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);
3741 if (err < 0) {
3742 snd_printk(KERN_ERR SFX "%s: cannot allocate posbuf\n", pci_name(chip->pci));
3743 return -ENOMEM;
3745 mark_pages_wc(chip, &chip->posbuf, true);
3746 /* allocate CORB/RIRB */
3747 err = azx_alloc_cmd_io(chip);
3748 if (err < 0)
3749 return err;
3751 /* initialize streams */
3752 azx_init_stream(chip);
3754 /* initialize chip */
3755 azx_init_pci(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));
3761 return -ENODEV;
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);
3771 return 0;
3774 static void power_down_all_codecs(struct azx *chip)
3776 #ifdef CONFIG_PM
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);
3784 #endif
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;
3795 if (!fw) {
3796 snd_printk(KERN_ERR SFX "%s: Cannot load firmware, aborting\n",
3797 pci_name(chip->pci));
3798 goto error;
3801 chip->fw = fw;
3802 if (!chip->disabled) {
3803 /* continue probing */
3804 if (azx_probe_continue(chip))
3805 goto error;
3807 return; /* OK */
3809 error:
3810 snd_card_free(card);
3811 pci_set_drvdata(pci, NULL);
3813 #endif
3815 static int azx_probe(struct pci_dev *pci,
3816 const struct pci_device_id *pci_id)
3818 static int dev;
3819 struct snd_card *card;
3820 struct azx *chip;
3821 bool schedule_probe;
3822 int err;
3824 if (dev >= SNDRV_CARDS)
3825 return -ENODEV;
3826 if (!enable[dev]) {
3827 dev++;
3828 return -ENOENT;
3831 err = snd_card_create(index[dev], id[dev], THIS_MODULE, 0, &card);
3832 if (err < 0) {
3833 snd_printk(KERN_ERR "hda-intel: Error creating card!\n");
3834 return err;
3837 snd_card_set_dev(card, &pci->dev);
3839 err = azx_create(card, pci, dev, pci_id->driver_data, &chip);
3840 if (err < 0)
3841 goto out_free;
3842 card->private_data = chip;
3844 pci_set_drvdata(pci, card);
3846 err = register_vga_switcheroo(chip);
3847 if (err < 0) {
3848 snd_printk(KERN_ERR SFX
3849 "%s: Error registering VGA-switcheroo client\n", pci_name(pci));
3850 goto out_free;
3853 if (check_hdmi_disabled(pci)) {
3854 snd_printk(KERN_INFO SFX "%s: VGA controller is disabled\n",
3855 pci_name(pci));
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,
3868 azx_firmware_cb);
3869 if (err < 0)
3870 goto out_free;
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");
3878 #endif
3880 if (schedule_probe)
3881 schedule_work(&chip->probe_work);
3883 dev++;
3884 if (chip->disabled)
3885 complete_all(&chip->probe_wait);
3886 return 0;
3888 out_free:
3889 snd_card_free(card);
3890 return err;
3893 static int azx_probe_continue(struct azx *chip)
3895 struct pci_dev *pci = chip->pci;
3896 int dev = chip->dev_index;
3897 int err;
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();
3903 if (err < 0) {
3904 snd_printk(KERN_ERR SFX "Error request power-well from i915\n");
3905 goto out_free;
3907 #endif
3908 hda_display_power(true);
3911 err = azx_first_init(chip);
3912 if (err < 0)
3913 goto out_free;
3915 #ifdef CONFIG_SND_HDA_INPUT_BEEP
3916 chip->beep_mode = beep_mode[dev];
3917 #endif
3919 /* create codec instances */
3920 err = azx_codec_create(chip, model[dev]);
3921 if (err < 0)
3922 goto out_free;
3923 #ifdef CONFIG_SND_HDA_PATCH_LOADER
3924 if (chip->fw) {
3925 err = snd_hda_load_patch(chip->bus, chip->fw->size,
3926 chip->fw->data);
3927 if (err < 0)
3928 goto out_free;
3929 #ifndef CONFIG_PM
3930 release_firmware(chip->fw); /* no longer needed */
3931 chip->fw = NULL;
3932 #endif
3934 #endif
3935 if ((probe_only[dev] & 1) == 0) {
3936 err = azx_codec_configure(chip);
3937 if (err < 0)
3938 goto out_free;
3941 /* create PCM streams */
3942 err = snd_hda_build_pcms(chip->bus);
3943 if (err < 0)
3944 goto out_free;
3946 /* create mixer controls */
3947 err = azx_mixer_create(chip);
3948 if (err < 0)
3949 goto out_free;
3951 err = snd_card_register(chip->card);
3952 if (err < 0)
3953 goto out_free;
3955 chip->running = 1;
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);
3962 out_free:
3963 if (err < 0)
3964 chip->init_failed = 1;
3965 complete_all(&chip->probe_wait);
3966 return err;
3969 static void azx_remove(struct pci_dev *pci)
3971 struct snd_card *card = pci_get_drvdata(pci);
3973 if (card)
3974 snd_card_free(card);
3977 /* PCI IDs */
3978 static DEFINE_PCI_DEVICE_TABLE(azx_ids) = {
3979 /* CPT */
3980 { PCI_DEVICE(0x8086, 0x1c20),
3981 .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH_NOPM },
3982 /* PBG */
3983 { PCI_DEVICE(0x8086, 0x1d20),
3984 .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH_NOPM },
3985 /* Panther Point */
3986 { PCI_DEVICE(0x8086, 0x1e20),
3987 .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
3988 /* Lynx Point */
3989 { PCI_DEVICE(0x8086, 0x8c20),
3990 .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
3991 /* Wellsburg */
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 },
3996 /* Lynx Point-LP */
3997 { PCI_DEVICE(0x8086, 0x9c20),
3998 .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
3999 /* Lynx Point-LP */
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 },
4005 /* Haswell */
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 },
4012 /* Broadwell */
4013 { PCI_DEVICE(0x8086, 0x160c),
4014 .driver_data = AZX_DRIVER_HDMI | AZX_DCAPS_INTEL_HASWELL },
4015 /* 5 Series/3400 */
4016 { PCI_DEVICE(0x8086, 0x3b56),
4017 .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH_NOPM },
4018 /* Poulsbo */
4019 { PCI_DEVICE(0x8086, 0x811b),
4020 .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH_NOPM },
4021 /* Oaktrail */
4022 { PCI_DEVICE(0x8086, 0x080a),
4023 .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH_NOPM },
4024 /* BayTrail */
4025 { PCI_DEVICE(0x8086, 0x0f04),
4026 .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH_NOPM },
4027 /* ICH */
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 */
4052 /* Generic Intel */
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 },
4062 /* AMD Hudson */
4063 { PCI_DEVICE(0x1022, 0x780d),
4064 .driver_data = AZX_DRIVER_GENERIC | AZX_DCAPS_PRESET_ATI_SB },
4065 /* ATI HDMI */
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 },
4125 /* SIS966 */
4126 { PCI_DEVICE(0x1039, 0x7502), .driver_data = AZX_DRIVER_SIS },
4127 /* ULI M5461 */
4128 { PCI_DEVICE(0x10b9, 0x5461), .driver_data = AZX_DRIVER_ULI },
4129 /* NVIDIA MCP */
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 },
4134 /* Teradici */
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) */
4140 /* CTHDA chips */
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 },
4155 #else
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 },
4160 #endif
4161 /* Vortex86MX */
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 },
4174 { 0, }
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,
4182 .probe = azx_probe,
4183 .remove = azx_remove,
4184 .driver = {
4185 .pm = AZX_PM_OPS,
4189 module_pci_driver(azx_driver);