hda_codec.h 20.6 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
/*
 * Universal Interface for Intel High Definition Audio Codec
 *
 * Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
 *
 *  This program is free software; you can redistribute it and/or modify it
 *  under the terms of the GNU General Public License as published by the Free
 *  Software Foundation; either version 2 of the License, or (at your option)
 *  any later version.
 *
 *  This program is distributed in the hope that it will be useful, but WITHOUT
 *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 *  more details.
 *
 *  You should have received a copy of the GNU General Public License along with
 *  this program; if not, write to the Free Software Foundation, Inc., 59
 *  Temple Place - Suite 330, Boston, MA  02111-1307, USA.
 */

#ifndef __SOUND_HDA_CODEC_H
#define __SOUND_HDA_CODEC_H

#include <sound/info.h>
#include <sound/control.h>
#include <sound/pcm.h>
27
#include <sound/hwdep.h>
28
#include <sound/hda_verbs.h>
L
Linus Torvalds 已提交
29

T
Takashi Iwai 已提交
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
/*
 * generic arrays
 */
struct snd_array {
	unsigned int used;
	unsigned int alloced;
	unsigned int elem_size;
	unsigned int alloc_align;
	void *list;
};

void *snd_array_new(struct snd_array *array);
void snd_array_free(struct snd_array *array);
static inline void snd_array_init(struct snd_array *array, unsigned int size,
				  unsigned int align)
{
	array->elem_size = size;
	array->alloc_align = align;
}

50 51 52 53 54 55 56 57 58 59
static inline void *snd_array_elem(struct snd_array *array, unsigned int idx)
{
	return array->list + idx * array->elem_size;
}

static inline unsigned int snd_array_index(struct snd_array *array, void *ptr)
{
	return (unsigned long)(ptr - array->list) / array->elem_size;
}

L
Linus Torvalds 已提交
60 61 62 63 64
/*
 * Structures
 */

struct hda_bus;
65
struct hda_beep;
L
Linus Torvalds 已提交
66 67 68 69 70 71 72 73 74 75
struct hda_codec;
struct hda_pcm;
struct hda_pcm_stream;

/* NID type */
typedef u16 hda_nid_t;

/* bus operators */
struct hda_bus_ops {
	/* send a single command */
76
	int (*command)(struct hda_bus *bus, unsigned int cmd);
L
Linus Torvalds 已提交
77
	/* get a response from the last command */
78
	unsigned int (*get_response)(struct hda_bus *bus, unsigned int addr);
L
Linus Torvalds 已提交
79 80
	/* free the private data */
	void (*private_free)(struct hda_bus *);
81
	/* attach a PCM stream */
82 83
	int (*attach_pcm)(struct hda_bus *bus, struct hda_codec *codec,
			  struct hda_pcm *pcm);
84 85
	/* reset bus for retry verb */
	void (*bus_reset)(struct hda_bus *bus);
86
#ifdef CONFIG_PM
J
Joe Perches 已提交
87
	/* notify power-up/down from codec to controller */
88
	void (*pm_notify)(struct hda_bus *bus, bool power_up);
89
#endif
90 91 92 93 94 95 96 97 98 99 100
#ifdef CONFIG_SND_HDA_DSP_LOADER
	/* prepare DSP transfer */
	int (*load_dsp_prepare)(struct hda_bus *bus, unsigned int format,
				unsigned int byte_size,
				struct snd_dma_buffer *bufp);
	/* start/stop DSP transfer */
	void (*load_dsp_trigger)(struct hda_bus *bus, bool start);
	/* clean up DSP transfer */
	void (*load_dsp_cleanup)(struct hda_bus *bus,
				 struct snd_dma_buffer *dmab);
#endif
L
Linus Torvalds 已提交
101 102
};

103 104 105 106 107 108 109 110 111 112
/* unsolicited event handler */
#define HDA_UNSOL_QUEUE_SIZE	64
struct hda_bus_unsolicited {
	/* ring buffer */
	u32 queue[HDA_UNSOL_QUEUE_SIZE * 2];
	unsigned int rp, wp;
	/* workqueue */
	struct work_struct work;
};

L
Linus Torvalds 已提交
113 114 115 116 117 118 119
/*
 * codec bus
 *
 * each controller needs to creata a hda_bus to assign the accessor.
 * A hda_bus contains several codecs in the list codec_list.
 */
struct hda_bus {
120
	struct snd_card *card;
L
Linus Torvalds 已提交
121 122 123 124

	void *private_data;
	struct pci_dev *pci;
	const char *modelname;
125
	int *power_save;
L
Linus Torvalds 已提交
126 127 128 129
	struct hda_bus_ops ops;

	/* codec linked list */
	struct list_head codec_list;
130
	unsigned int num_codecs;
131 132
	/* link caddr -> codec */
	struct hda_codec *caddr_tbl[HDA_MAX_CODEC_ADDRESS + 1];
L
Linus Torvalds 已提交
133

134
	struct mutex cmd_mutex;
135
	struct mutex prepare_mutex;
L
Linus Torvalds 已提交
136 137

	/* unsolicited event queue */
138
	struct hda_bus_unsolicited unsol;
139
	char workq_name[16];
T
Takashi Iwai 已提交
140
	struct workqueue_struct *workq;	/* common workqueue for codecs */
L
Linus Torvalds 已提交
141

T
Takashi Iwai 已提交
142 143 144
	/* assigned PCMs */
	DECLARE_BITMAP(pcm_dev_bits, SNDRV_PCM_DEVICES);

145 146
	/* misc op flags */
	unsigned int needs_damn_long_delay :1;
147 148 149
	unsigned int allow_bus_reset:1;	/* allow bus reset at fatal error */
	unsigned int sync_write:1;	/* sync after verb write */
	/* status for codec/controller */
150
	unsigned int shutdown :1;	/* being unloaded */
151
	unsigned int rirb_error:1;	/* error in codec communication */
152 153
	unsigned int response_reset:1;	/* controller was reset */
	unsigned int in_reset:1;	/* during reset operation */
W
Wu Fengguang 已提交
154
	unsigned int power_keep_link_on:1; /* don't power off HDA link */
155
	unsigned int no_response_fallback:1; /* don't fallback at RIRB error */
156 157

	int primary_dig_out_type;	/* primary digital out PCM type */
L
Linus Torvalds 已提交
158 159 160 161 162 163 164 165 166 167 168 169 170 171
};

/*
 * codec preset
 *
 * Known codecs have the patch to build and set up the controls/PCMs
 * better than the generic parser.
 */
struct hda_codec_preset {
	unsigned int id;
	unsigned int mask;
	unsigned int subs;
	unsigned int subs_mask;
	unsigned int rev;
172
	hda_nid_t afg, mfg;
L
Linus Torvalds 已提交
173 174 175 176
	const char *name;
	int (*patch)(struct hda_codec *codec);
};
	
177 178 179 180 181 182 183 184 185 186
struct hda_codec_preset_list {
	const struct hda_codec_preset *preset;
	struct module *owner;
	struct list_head list;
};

/* initial hook */
int snd_hda_add_codec_preset(struct hda_codec_preset_list *preset);
int snd_hda_delete_codec_preset(struct hda_codec_preset_list *preset);

L
Linus Torvalds 已提交
187 188 189 190 191 192 193
/* ops set by the preset patch */
struct hda_codec_ops {
	int (*build_controls)(struct hda_codec *codec);
	int (*build_pcms)(struct hda_codec *codec);
	int (*init)(struct hda_codec *codec);
	void (*free)(struct hda_codec *codec);
	void (*unsol_event)(struct hda_codec *codec, unsigned int res);
194 195
	void (*set_power_state)(struct hda_codec *codec, hda_nid_t fg,
				unsigned int power_state);
196
#ifdef CONFIG_PM
197
	int (*suspend)(struct hda_codec *codec);
L
Linus Torvalds 已提交
198
	int (*resume)(struct hda_codec *codec);
199 200
	int (*check_power_status)(struct hda_codec *codec, hda_nid_t nid);
#endif
201
	void (*reboot_notify)(struct hda_codec *codec);
L
Linus Torvalds 已提交
202 203 204
};

/* record for amp information cache */
205
struct hda_cache_head {
206 207
	u32 key:31;		/* hash key */
	u32 dirty:1;
208
	u16 val;		/* assigned value */
209
	u16 next;
210 211 212 213
};

struct hda_amp_info {
	struct hda_cache_head head;
L
Linus Torvalds 已提交
214
	u32 amp_caps;		/* amp capabilities */
215
	u16 vol[2];		/* current volume & mute */
216 217 218 219
};

struct hda_cache_rec {
	u16 hash[64];			/* hash table for index */
220
	struct snd_array buf;		/* record entries */
L
Linus Torvalds 已提交
221 222 223 224 225
};

/* PCM callbacks */
struct hda_pcm_ops {
	int (*open)(struct hda_pcm_stream *info, struct hda_codec *codec,
226
		    struct snd_pcm_substream *substream);
L
Linus Torvalds 已提交
227
	int (*close)(struct hda_pcm_stream *info, struct hda_codec *codec,
228
		     struct snd_pcm_substream *substream);
L
Linus Torvalds 已提交
229 230
	int (*prepare)(struct hda_pcm_stream *info, struct hda_codec *codec,
		       unsigned int stream_tag, unsigned int format,
231
		       struct snd_pcm_substream *substream);
L
Linus Torvalds 已提交
232
	int (*cleanup)(struct hda_pcm_stream *info, struct hda_codec *codec,
233
		       struct snd_pcm_substream *substream);
234 235 236
	unsigned int (*get_delay)(struct hda_pcm_stream *info,
				  struct hda_codec *codec,
				  struct snd_pcm_substream *substream);
L
Linus Torvalds 已提交
237 238 239 240
};

/* PCM information for each substream */
struct hda_pcm_stream {
241
	unsigned int substreams;	/* number of substreams, 0 = not exist*/
L
Linus Torvalds 已提交
242 243 244 245 246 247
	unsigned int channels_min;	/* min. number of channels */
	unsigned int channels_max;	/* max. number of channels */
	hda_nid_t nid;	/* default NID to query rates/formats/bps, or set up */
	u32 rates;	/* supported rates */
	u64 formats;	/* supported formats (SNDRV_PCM_FMTBIT_) */
	unsigned int maxbps;	/* supported max. bit per sample */
248
	const struct snd_pcm_chmap_elem *chmap; /* chmap to override */
L
Linus Torvalds 已提交
249 250 251
	struct hda_pcm_ops ops;
};

252 253 254 255 256 257 258 259 260
/* PCM types */
enum {
	HDA_PCM_TYPE_AUDIO,
	HDA_PCM_TYPE_SPDIF,
	HDA_PCM_TYPE_HDMI,
	HDA_PCM_TYPE_MODEM,
	HDA_PCM_NTYPES
};

L
Linus Torvalds 已提交
261 262 263 264
/* for PCM creation */
struct hda_pcm {
	char *name;
	struct hda_pcm_stream stream[2];
265
	unsigned int pcm_type;	/* HDA_PCM_TYPE_XXX */
266 267
	int device;		/* device number to assign */
	struct snd_pcm *pcm;	/* assigned PCM instance */
268
	bool own_chmap;		/* codec driver provides own channel maps */
L
Linus Torvalds 已提交
269 270 271 272
};

/* codec information */
struct hda_codec {
273
	struct device dev;
L
Linus Torvalds 已提交
274 275 276 277 278
	struct hda_bus *bus;
	unsigned int addr;	/* codec addr*/
	struct list_head list;	/* list point */

	hda_nid_t afg;	/* AFG node id */
S
Sasha Khapyorsky 已提交
279
	hda_nid_t mfg;	/* MFG node id */
L
Linus Torvalds 已提交
280 281

	/* ids */
282 283 284 285
	u8 afg_function_id;
	u8 mfg_function_id;
	u8 afg_unsol;
	u8 mfg_unsol;
L
Linus Torvalds 已提交
286 287 288 289 290 291
	u32 vendor_id;
	u32 subsystem_id;
	u32 revision_id;

	/* detected preset */
	const struct hda_codec_preset *preset;
292
	struct module *owner;
293
	int (*parser)(struct hda_codec *codec);
294 295
	const char *vendor_name;	/* codec vendor name */
	const char *chip_name;		/* codec chip name */
296
	const char *modelname;	/* model name for preset */
L
Linus Torvalds 已提交
297 298 299 300 301 302 303 304 305 306 307

	/* set by patch */
	struct hda_codec_ops patch_ops;

	/* PCM to create, set by patch_ops.build_pcms callback */
	unsigned int num_pcms;
	struct hda_pcm *pcm_info;

	/* codec specific info */
	void *spec;

308 309
	/* beep device */
	struct hda_beep *beep;
310
	unsigned int beep_mode;
311

312 313 314 315 316
	/* widget capabilities cache */
	unsigned int num_nodes;
	hda_nid_t start_nid;
	u32 *wcaps;

T
Takashi Iwai 已提交
317
	struct snd_array mixers;	/* list of assigned mixer elements */
318
	struct snd_array nids;		/* list of mapped mixer elements */
T
Takashi Iwai 已提交
319

320
	struct hda_cache_rec amp_cache;	/* cache for amp access */
321
	struct hda_cache_rec cmd_cache;	/* cache for other commands */
L
Linus Torvalds 已提交
322

323
	struct list_head conn_list;	/* linked-list of connection-list */
324

325
	struct mutex spdif_mutex;
326
	struct mutex control_mutex;
327
	struct mutex hash_mutex;
328
	struct snd_array spdif_out;
L
Linus Torvalds 已提交
329
	unsigned int spdif_in_enable;	/* SPDIF input enable? */
330
	const hda_nid_t *slave_dig_outs; /* optional digital out slave widgets */
331
	struct snd_array init_pins;	/* initial (BIOS) pin configurations */
332
	struct snd_array driver_pins;	/* pin configs set by codec parser */
333
	struct snd_array cvt_setups;	/* audio convert setups */
334

335
	struct mutex user_mutex;
336
#ifdef CONFIG_SND_HDA_RECONFIG
T
Takashi Iwai 已提交
337
	struct snd_array init_verbs;	/* additional init verbs */
T
Takashi Iwai 已提交
338
	struct snd_array hints;		/* additional hints */
339
	struct snd_array user_pins;	/* default pin configs to override */
T
Takashi Iwai 已提交
340
#endif
341

342 343 344 345
#ifdef CONFIG_SND_HDA_HWDEP
	struct snd_hwdep *hwdep;	/* assigned hwdep device */
#endif

346 347 348 349 350
	/* misc flags */
	unsigned int spdif_status_reset :1; /* needs to toggle SPDIF for each
					     * status change
					     * (e.g. Realtek codecs)
					     */
351 352 353
	unsigned int pin_amp_workaround:1; /* pin out-amp takes index
					    * (e.g. Conexant codecs)
					    */
354 355 356
	unsigned int single_adc_amp:1; /* adc in-amp takes no index
					* (e.g. CX20549 codec)
					*/
357
	unsigned int no_sticky_stream:1; /* no sticky-PCM stream assignment */
358
	unsigned int pins_shutup:1;	/* pins are shut up */
359
	unsigned int no_trigger_sense:1; /* don't trigger at pin-sensing */
360
	unsigned int no_jack_detect:1;	/* Machine has no jack-detection */
361
	unsigned int inv_eapd:1; /* broken h/w: inverted EAPD control */
362
	unsigned int inv_jack_detect:1;	/* broken h/w: inverted detection bit */
363
	unsigned int pcm_format_first:1; /* PCM format must be set first */
364
	unsigned int epss:1;		/* supporting EPSS? */
365
	unsigned int cached_write:1;	/* write only to caches */
366
	unsigned int dp_mst:1; /* support DP1.2 Multi-stream transport */
367
	unsigned int dump_coef:1; /* dump processing coefs in codec proc file */
368
#ifdef CONFIG_PM
369
	unsigned int power_on :1;	/* current (global) power-state */
370
	unsigned int d3_stop_clk:1;	/* support D3 operation without BCLK */
371
	unsigned int pm_up_notified:1;	/* PM notified to controller */
372
	unsigned int in_pm:1;		/* suspend/resume being performed */
373
	int power_transition;	/* power-state in transition */
374 375
	int power_count;	/* current (global) power refcount */
	struct delayed_work power_work; /* delayed task for powerdown */
376 377 378
	unsigned long power_on_acct;
	unsigned long power_off_acct;
	unsigned long power_jiffies;
379
	spinlock_t power_lock;
380
#endif
381

382 383 384 385
	/* filter the requested power state per nid */
	unsigned int (*power_filter)(struct hda_codec *codec, hda_nid_t nid,
				     unsigned int power_state);

386 387 388
	/* codec-specific additional proc output */
	void (*proc_widget_hook)(struct snd_info_buffer *buffer,
				 struct hda_codec *codec, hda_nid_t nid);
389

390 391
	/* jack detection */
	struct snd_array jacktbl;
392 393
	unsigned long jackpoll_interval; /* In jiffies. Zero means no poll, rely on unsol events */
	struct delayed_work jackpoll_work;
394

395 396 397 398
#ifdef CONFIG_SND_HDA_INPUT_JACK
	/* jack detection */
	struct snd_array jacks;
#endif
399

400 401
	int depop_delay; /* depop delay in ms, -1 for default delay time */

402 403 404 405 406 407 408
	/* fix-up list */
	int fixup_id;
	const struct hda_fixup *fixup_list;
	const char *fixup_name;

	/* additional init verbs */
	struct snd_array verbs;
L
Linus Torvalds 已提交
409 410 411 412 413 414 415
};

/* direction */
enum {
	HDA_INPUT, HDA_OUTPUT
};

416 417
/* snd_hda_codec_read/write optional flags */
#define HDA_RW_NO_RESPONSE_FALLBACK	(1 << 0)
L
Linus Torvalds 已提交
418 419 420 421

/*
 * constructors
 */
422
int snd_hda_bus_new(struct snd_card *card, struct hda_bus **busp);
L
Linus Torvalds 已提交
423
int snd_hda_codec_new(struct hda_bus *bus, unsigned int codec_addr,
424 425
		      struct hda_codec **codecp);
int snd_hda_codec_configure(struct hda_codec *codec);
426
int snd_hda_codec_update_widgets(struct hda_codec *codec);
L
Linus Torvalds 已提交
427 428 429 430

/*
 * low level functions
 */
431
unsigned int snd_hda_codec_read(struct hda_codec *codec, hda_nid_t nid,
432
				int flags,
L
Linus Torvalds 已提交
433
				unsigned int verb, unsigned int parm);
434
int snd_hda_codec_write(struct hda_codec *codec, hda_nid_t nid, int flags,
L
Linus Torvalds 已提交
435
			unsigned int verb, unsigned int parm);
436 437 438 439 440 441
#define snd_hda_param_read(codec, nid, param) \
	snd_hda_codec_read(codec, nid, 0, AC_VERB_PARAMETERS, param)
int snd_hda_get_sub_nodes(struct hda_codec *codec, hda_nid_t nid,
			  hda_nid_t *start_id);
int snd_hda_get_connections(struct hda_codec *codec, hda_nid_t nid,
			    hda_nid_t *conn_list, int max_conns);
442 443 444 445 446
static inline int
snd_hda_get_num_conns(struct hda_codec *codec, hda_nid_t nid)
{
	return snd_hda_get_connections(codec, nid, NULL, 0);
}
447
int snd_hda_get_num_raw_conns(struct hda_codec *codec, hda_nid_t nid);
448 449
int snd_hda_get_raw_connections(struct hda_codec *codec, hda_nid_t nid,
			    hda_nid_t *conn_list, int max_conns);
450 451
int snd_hda_get_conn_list(struct hda_codec *codec, hda_nid_t nid,
			  const hda_nid_t **listp);
452 453
int snd_hda_override_conn_list(struct hda_codec *codec, hda_nid_t nid, int nums,
			  const hda_nid_t *list);
454 455
int snd_hda_get_conn_index(struct hda_codec *codec, hda_nid_t mux,
			   hda_nid_t nid, int recursive);
456 457
int snd_hda_get_devices(struct hda_codec *codec, hda_nid_t nid,
			u8 *dev_list, int max_devices);
458 459
int snd_hda_query_supported_pcm(struct hda_codec *codec, hda_nid_t nid,
				u32 *ratesp, u64 *formatsp, unsigned int *bpsp);
L
Linus Torvalds 已提交
460 461 462 463 464 465 466

struct hda_verb {
	hda_nid_t nid;
	u32 verb;
	u32 param;
};

467 468
void snd_hda_sequence_write(struct hda_codec *codec,
			    const struct hda_verb *seq);
L
Linus Torvalds 已提交
469 470 471 472

/* unsolicited event */
int snd_hda_queue_unsol_event(struct hda_bus *bus, u32 res, u32 res_ex);

473 474
/* cached write */
int snd_hda_codec_write_cache(struct hda_codec *codec, hda_nid_t nid,
475
			      int flags, unsigned int verb, unsigned int parm);
476 477
void snd_hda_sequence_write_cache(struct hda_codec *codec,
				  const struct hda_verb *seq);
478
int snd_hda_codec_update_cache(struct hda_codec *codec, hda_nid_t nid,
479
			      int flags, unsigned int verb, unsigned int parm);
480
void snd_hda_codec_resume_cache(struct hda_codec *codec);
481 482
/* both for cmd & amp caches */
void snd_hda_codec_flush_cache(struct hda_codec *codec);
483

484 485 486
/* the struct for codec->pin_configs */
struct hda_pincfg {
	hda_nid_t nid;
487 488
	unsigned char ctrl;	/* original pin control value */
	unsigned char target;	/* target pin control value */
489
	unsigned int cfg;	/* default configuration */
490 491 492 493 494 495 496
};

unsigned int snd_hda_codec_get_pincfg(struct hda_codec *codec, hda_nid_t nid);
int snd_hda_codec_set_pincfg(struct hda_codec *codec, hda_nid_t nid,
			     unsigned int cfg);
int snd_hda_add_pincfg(struct hda_codec *codec, struct snd_array *list,
		       hda_nid_t nid, unsigned int cfg); /* for hwdep */
497
void snd_hda_shutup_pins(struct hda_codec *codec);
498

499 500 501 502 503 504 505 506
/* SPDIF controls */
struct hda_spdif_out {
	hda_nid_t nid;		/* Converter nid values relate to */
	unsigned int status;	/* IEC958 status bits */
	unsigned short ctls;	/* SPDIF control bits */
};
struct hda_spdif_out *snd_hda_spdif_out_of_nid(struct hda_codec *codec,
					       hda_nid_t nid);
507 508
void snd_hda_spdif_ctls_unassign(struct hda_codec *codec, int idx);
void snd_hda_spdif_ctls_assign(struct hda_codec *codec, int idx, hda_nid_t nid);
509

L
Linus Torvalds 已提交
510 511 512 513
/*
 * Mixer
 */
int snd_hda_build_controls(struct hda_bus *bus);
514
int snd_hda_codec_build_controls(struct hda_codec *codec);
L
Linus Torvalds 已提交
515 516 517 518 519

/*
 * PCM
 */
int snd_hda_build_pcms(struct hda_bus *bus);
T
Takashi Iwai 已提交
520
int snd_hda_codec_build_pcms(struct hda_codec *codec);
521 522 523 524 525 526 527 528 529 530

int snd_hda_codec_prepare(struct hda_codec *codec,
			  struct hda_pcm_stream *hinfo,
			  unsigned int stream,
			  unsigned int format,
			  struct snd_pcm_substream *substream);
void snd_hda_codec_cleanup(struct hda_codec *codec,
			   struct hda_pcm_stream *hinfo,
			   struct snd_pcm_substream *substream);

531 532
void snd_hda_codec_setup_stream(struct hda_codec *codec, hda_nid_t nid,
				u32 stream_tag,
L
Linus Torvalds 已提交
533
				int channel_id, int format);
534 535 536 537
void __snd_hda_codec_cleanup_stream(struct hda_codec *codec, hda_nid_t nid,
				    int do_now);
#define snd_hda_codec_cleanup_stream(codec, nid) \
	__snd_hda_codec_cleanup_stream(codec, nid, 0)
538 539
unsigned int snd_hda_calc_stream_format(struct hda_codec *codec,
					unsigned int rate,
540 541
					unsigned int channels,
					unsigned int format,
542 543
					unsigned int maxbps,
					unsigned short spdif_ctls);
L
Linus Torvalds 已提交
544 545 546
int snd_hda_is_supported_format(struct hda_codec *codec, hda_nid_t nid,
				unsigned int format);

547 548
extern const struct snd_pcm_chmap_elem snd_pcm_2_1_chmaps[];

L
Linus Torvalds 已提交
549 550 551 552
/*
 * Misc
 */
void snd_hda_get_codec_name(struct hda_codec *codec, char *name, int namelen);
553
void snd_hda_bus_reboot_notify(struct hda_bus *bus);
554
void snd_hda_codec_set_power_to_all(struct hda_codec *codec, hda_nid_t fg,
555
				    unsigned int power_state);
L
Linus Torvalds 已提交
556

557 558 559
int snd_hda_lock_devices(struct hda_bus *bus);
void snd_hda_unlock_devices(struct hda_bus *bus);

L
Linus Torvalds 已提交
560 561 562 563
/*
 * power management
 */
#ifdef CONFIG_PM
564
int snd_hda_suspend(struct hda_bus *bus);
L
Linus Torvalds 已提交
565 566 567
int snd_hda_resume(struct hda_bus *bus);
#endif

568 569 570
static inline
int hda_call_check_power_status(struct hda_codec *codec, hda_nid_t nid)
{
571
#ifdef CONFIG_PM
572 573
	if (codec->patch_ops.check_power_status)
		return codec->patch_ops.check_power_status(codec, nid);
574
#endif
575 576 577
	return 0;
}

578 579 580 581 582 583 584
/*
 * get widget information
 */
const char *snd_hda_get_jack_connectivity(u32 cfg);
const char *snd_hda_get_jack_type(u32 cfg);
const char *snd_hda_get_jack_location(u32 cfg);

585 586 587
/*
 * power saving
 */
588
#ifdef CONFIG_PM
589
void snd_hda_power_save(struct hda_codec *codec, int delta, bool d3wait);
590
void snd_hda_update_power_acct(struct hda_codec *codec);
591
#else
592 593
static inline void snd_hda_power_save(struct hda_codec *codec, int delta,
				      bool d3wait) {}
594 595
#endif

596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646
/**
 * snd_hda_power_up - Power-up the codec
 * @codec: HD-audio codec
 *
 * Increment the power-up counter and power up the hardware really when
 * not turned on yet.
 */
static inline void snd_hda_power_up(struct hda_codec *codec)
{
	snd_hda_power_save(codec, 1, false);
}

/**
 * snd_hda_power_up_d3wait - Power-up the codec after waiting for any pending
 *   D3 transition to complete.  This differs from snd_hda_power_up() when
 *   power_transition == -1.  snd_hda_power_up sees this case as a nop,
 *   snd_hda_power_up_d3wait waits for the D3 transition to complete then powers
 *   back up.
 * @codec: HD-audio codec
 *
 * Cancel any power down operation hapenning on the work queue, then power up.
 */
static inline void snd_hda_power_up_d3wait(struct hda_codec *codec)
{
	snd_hda_power_save(codec, 1, true);
}

/**
 * snd_hda_power_down - Power-down the codec
 * @codec: HD-audio codec
 *
 * Decrement the power-up counter and schedules the power-off work if
 * the counter rearches to zero.
 */
static inline void snd_hda_power_down(struct hda_codec *codec)
{
	snd_hda_power_save(codec, -1, false);
}

/**
 * snd_hda_power_sync - Synchronize the power-save status
 * @codec: HD-audio codec
 *
 * Synchronize the actual power state with the power account;
 * called when power_save parameter is changed
 */
static inline void snd_hda_power_sync(struct hda_codec *codec)
{
	snd_hda_power_save(codec, 0, false);
}

647 648 649 650
#ifdef CONFIG_SND_HDA_PATCH_LOADER
/*
 * patch firmware
 */
651
int snd_hda_load_patch(struct hda_bus *bus, size_t size, const void *buf);
652 653
#endif

654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678
#ifdef CONFIG_SND_HDA_DSP_LOADER
static inline int
snd_hda_codec_load_dsp_prepare(struct hda_codec *codec, unsigned int format,
				unsigned int size,
				struct snd_dma_buffer *bufp)
{
	return codec->bus->ops.load_dsp_prepare(codec->bus, format, size, bufp);
}
static inline void
snd_hda_codec_load_dsp_trigger(struct hda_codec *codec, bool start)
{
	return codec->bus->ops.load_dsp_trigger(codec->bus, start);
}
static inline void
snd_hda_codec_load_dsp_cleanup(struct hda_codec *codec,
				struct snd_dma_buffer *dmab)
{
	return codec->bus->ops.load_dsp_cleanup(codec->bus, dmab);
}
#else
static inline int
snd_hda_codec_load_dsp_prepare(struct hda_codec *codec, unsigned int format,
				unsigned int size,
				struct snd_dma_buffer *bufp)
{
679
	return -ENOSYS;
680 681 682 683 684 685 686 687
}
static inline void
snd_hda_codec_load_dsp_trigger(struct hda_codec *codec, bool start) {}
static inline void
snd_hda_codec_load_dsp_cleanup(struct hda_codec *codec,
				struct snd_dma_buffer *dmab) {}
#endif

L
Linus Torvalds 已提交
688
#endif /* __SOUND_HDA_CODEC_H */