2  * Universal Interface for Intel High Definition Audio Codec
 
   4  * Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
 
   7  *  This driver is free software; you can redistribute it and/or modify
 
   8  *  it under the terms of the GNU General Public License as published by
 
   9  *  the Free Software Foundation; either version 2 of the License, or
 
  10  *  (at your option) any later version.
 
  12  *  This driver is distributed in the hope that it will be useful,
 
  13  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  14  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  15  *  GNU General Public License for more details.
 
  17  *  You should have received a copy of the GNU General Public License
 
  18  *  along with this program; if not, write to the Free Software
 
  19  *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
 
  22 #include <linux/init.h>
 
  23 #include <linux/delay.h>
 
  24 #include <linux/slab.h>
 
  25 #include <linux/pci.h>
 
  26 #include <linux/mutex.h>
 
  27 #include <sound/core.h>
 
  28 #include "hda_codec.h"
 
  29 #include <sound/asoundef.h>
 
  30 #include <sound/tlv.h>
 
  31 #include <sound/initval.h>
 
  32 #include "hda_local.h"
 
  33 #include <sound/hda_hwdep.h>
 
  34 #include "hda_patch.h"  /* codec presets */
 
  36 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
  37 /* define this option here to hide as static */
 
  38 static int power_save = CONFIG_SND_HDA_POWER_SAVE_DEFAULT;
 
  39 module_param(power_save, int, 0644);
 
  40 MODULE_PARM_DESC(power_save, "Automatic power-saving timeout "
 
  41                  "(in second, 0 = disable).");
 
  45  * vendor / preset table
 
  48 struct hda_vendor_id {
 
  53 /* codec vendor labels */
 
  54 static struct hda_vendor_id hda_vendor_ids[] = {
 
  56         { 0x1057, "Motorola" },
 
  57         { 0x1095, "Silicon Image" },
 
  58         { 0x10ec, "Realtek" },
 
  62         { 0x11d4, "Analog Devices" },
 
  63         { 0x13f6, "C-Media" },
 
  64         { 0x14f1, "Conexant" },
 
  65         { 0x17e8, "Chrontel" },
 
  67         { 0x434d, "C-Media" },
 
  68         { 0x8384, "SigmaTel" },
 
  72 static const struct hda_codec_preset *hda_preset_tables[] = {
 
  73 #ifdef CONFIG_SND_HDA_CODEC_REALTEK
 
  74         snd_hda_preset_realtek,
 
  76 #ifdef CONFIG_SND_HDA_CODEC_CMEDIA
 
  77         snd_hda_preset_cmedia,
 
  79 #ifdef CONFIG_SND_HDA_CODEC_ANALOG
 
  80         snd_hda_preset_analog,
 
  82 #ifdef CONFIG_SND_HDA_CODEC_SIGMATEL
 
  83         snd_hda_preset_sigmatel,
 
  85 #ifdef CONFIG_SND_HDA_CODEC_SI3054
 
  86         snd_hda_preset_si3054,
 
  88 #ifdef CONFIG_SND_HDA_CODEC_ATIHDMI
 
  89         snd_hda_preset_atihdmi,
 
  91 #ifdef CONFIG_SND_HDA_CODEC_CONEXANT
 
  92         snd_hda_preset_conexant,
 
  94 #ifdef CONFIG_SND_HDA_CODEC_VIA
 
 100 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
 101 static void hda_power_work(struct work_struct *work);
 
 102 static void hda_keep_power_on(struct hda_codec *codec);
 
 104 static inline void hda_keep_power_on(struct hda_codec *codec) {}
 
 108  * snd_hda_codec_read - send a command and get the response
 
 109  * @codec: the HDA codec
 
 110  * @nid: NID to send the command
 
 111  * @direct: direct flag
 
 112  * @verb: the verb to send
 
 113  * @parm: the parameter for the verb
 
 115  * Send a single command and read the corresponding response.
 
 117  * Returns the obtained response value, or -1 for an error.
 
 119 unsigned int snd_hda_codec_read(struct hda_codec *codec, hda_nid_t nid,
 
 121                                 unsigned int verb, unsigned int parm)
 
 124         snd_hda_power_up(codec);
 
 125         mutex_lock(&codec->bus->cmd_mutex);
 
 126         if (!codec->bus->ops.command(codec, nid, direct, verb, parm))
 
 127                 res = codec->bus->ops.get_response(codec);
 
 129                 res = (unsigned int)-1;
 
 130         mutex_unlock(&codec->bus->cmd_mutex);
 
 131         snd_hda_power_down(codec);
 
 136  * snd_hda_codec_write - send a single command without waiting for response
 
 137  * @codec: the HDA codec
 
 138  * @nid: NID to send the command
 
 139  * @direct: direct flag
 
 140  * @verb: the verb to send
 
 141  * @parm: the parameter for the verb
 
 143  * Send a single command without waiting for response.
 
 145  * Returns 0 if successful, or a negative error code.
 
 147 int snd_hda_codec_write(struct hda_codec *codec, hda_nid_t nid, int direct,
 
 148                          unsigned int verb, unsigned int parm)
 
 151         snd_hda_power_up(codec);
 
 152         mutex_lock(&codec->bus->cmd_mutex);
 
 153         err = codec->bus->ops.command(codec, nid, direct, verb, parm);
 
 154         mutex_unlock(&codec->bus->cmd_mutex);
 
 155         snd_hda_power_down(codec);
 
 160  * snd_hda_sequence_write - sequence writes
 
 161  * @codec: the HDA codec
 
 162  * @seq: VERB array to send
 
 164  * Send the commands sequentially from the given array.
 
 165  * The array must be terminated with NID=0.
 
 167 void snd_hda_sequence_write(struct hda_codec *codec, const struct hda_verb *seq)
 
 169         for (; seq->nid; seq++)
 
 170                 snd_hda_codec_write(codec, seq->nid, 0, seq->verb, seq->param);
 
 174  * snd_hda_get_sub_nodes - get the range of sub nodes
 
 175  * @codec: the HDA codec
 
 177  * @start_id: the pointer to store the start NID
 
 179  * Parse the NID and store the start NID of its sub-nodes.
 
 180  * Returns the number of sub-nodes.
 
 182 int snd_hda_get_sub_nodes(struct hda_codec *codec, hda_nid_t nid,
 
 187         parm = snd_hda_param_read(codec, nid, AC_PAR_NODE_COUNT);
 
 190         *start_id = (parm >> 16) & 0x7fff;
 
 191         return (int)(parm & 0x7fff);
 
 195  * snd_hda_get_connections - get connection list
 
 196  * @codec: the HDA codec
 
 198  * @conn_list: connection list array
 
 199  * @max_conns: max. number of connections to store
 
 201  * Parses the connection list of the given widget and stores the list
 
 204  * Returns the number of connections, or a negative error code.
 
 206 int snd_hda_get_connections(struct hda_codec *codec, hda_nid_t nid,
 
 207                             hda_nid_t *conn_list, int max_conns)
 
 210         int i, conn_len, conns;
 
 211         unsigned int shift, num_elems, mask;
 
 214         snd_assert(conn_list && max_conns > 0, return -EINVAL);
 
 216         parm = snd_hda_param_read(codec, nid, AC_PAR_CONNLIST_LEN);
 
 217         if (parm & AC_CLIST_LONG) {
 
 226         conn_len = parm & AC_CLIST_LENGTH;
 
 227         mask = (1 << (shift-1)) - 1;
 
 230                 return 0; /* no connection */
 
 233                 /* single connection */
 
 234                 parm = snd_hda_codec_read(codec, nid, 0,
 
 235                                           AC_VERB_GET_CONNECT_LIST, 0);
 
 236                 conn_list[0] = parm & mask;
 
 240         /* multi connection */
 
 243         for (i = 0; i < conn_len; i++) {
 
 247                 if (i % num_elems == 0)
 
 248                         parm = snd_hda_codec_read(codec, nid, 0,
 
 249                                                   AC_VERB_GET_CONNECT_LIST, i);
 
 250                 range_val = !!(parm & (1 << (shift-1))); /* ranges */
 
 254                         /* ranges between the previous and this one */
 
 255                         if (!prev_nid || prev_nid >= val) {
 
 256                                 snd_printk(KERN_WARNING "hda_codec: "
 
 257                                            "invalid dep_range_val %x:%x\n",
 
 261                         for (n = prev_nid + 1; n <= val; n++) {
 
 262                                 if (conns >= max_conns) {
 
 264                                                    "Too many connections\n");
 
 267                                 conn_list[conns++] = n;
 
 270                         if (conns >= max_conns) {
 
 271                                 snd_printk(KERN_ERR "Too many connections\n");
 
 274                         conn_list[conns++] = val;
 
 283  * snd_hda_queue_unsol_event - add an unsolicited event to queue
 
 285  * @res: unsolicited event (lower 32bit of RIRB entry)
 
 286  * @res_ex: codec addr and flags (upper 32bit or RIRB entry)
 
 288  * Adds the given event to the queue.  The events are processed in
 
 289  * the workqueue asynchronously.  Call this function in the interrupt
 
 290  * hanlder when RIRB receives an unsolicited event.
 
 292  * Returns 0 if successful, or a negative error code.
 
 294 int snd_hda_queue_unsol_event(struct hda_bus *bus, u32 res, u32 res_ex)
 
 296         struct hda_bus_unsolicited *unsol;
 
 303         wp = (unsol->wp + 1) % HDA_UNSOL_QUEUE_SIZE;
 
 307         unsol->queue[wp] = res;
 
 308         unsol->queue[wp + 1] = res_ex;
 
 310         schedule_work(&unsol->work);
 
 316  * process queueud unsolicited events
 
 318 static void process_unsol_events(struct work_struct *work)
 
 320         struct hda_bus_unsolicited *unsol =
 
 321                 container_of(work, struct hda_bus_unsolicited, work);
 
 322         struct hda_bus *bus = unsol->bus;
 
 323         struct hda_codec *codec;
 
 324         unsigned int rp, caddr, res;
 
 326         while (unsol->rp != unsol->wp) {
 
 327                 rp = (unsol->rp + 1) % HDA_UNSOL_QUEUE_SIZE;
 
 330                 res = unsol->queue[rp];
 
 331                 caddr = unsol->queue[rp + 1];
 
 332                 if (!(caddr & (1 << 4))) /* no unsolicited event? */
 
 334                 codec = bus->caddr_tbl[caddr & 0x0f];
 
 335                 if (codec && codec->patch_ops.unsol_event)
 
 336                         codec->patch_ops.unsol_event(codec, res);
 
 341  * initialize unsolicited queue
 
 343 static int __devinit init_unsol_queue(struct hda_bus *bus)
 
 345         struct hda_bus_unsolicited *unsol;
 
 347         if (bus->unsol) /* already initialized */
 
 350         unsol = kzalloc(sizeof(*unsol), GFP_KERNEL);
 
 352                 snd_printk(KERN_ERR "hda_codec: "
 
 353                            "can't allocate unsolicited queue\n");
 
 356         INIT_WORK(&unsol->work, process_unsol_events);
 
 365 static void snd_hda_codec_free(struct hda_codec *codec);
 
 367 static int snd_hda_bus_free(struct hda_bus *bus)
 
 369         struct hda_codec *codec, *n;
 
 374                 flush_scheduled_work();
 
 377         list_for_each_entry_safe(codec, n, &bus->codec_list, list) {
 
 378                 snd_hda_codec_free(codec);
 
 380         if (bus->ops.private_free)
 
 381                 bus->ops.private_free(bus);
 
 386 static int snd_hda_bus_dev_free(struct snd_device *device)
 
 388         struct hda_bus *bus = device->device_data;
 
 389         return snd_hda_bus_free(bus);
 
 393  * snd_hda_bus_new - create a HDA bus
 
 394  * @card: the card entry
 
 395  * @temp: the template for hda_bus information
 
 396  * @busp: the pointer to store the created bus instance
 
 398  * Returns 0 if successful, or a negative error code.
 
 400 int __devinit snd_hda_bus_new(struct snd_card *card,
 
 401                               const struct hda_bus_template *temp,
 
 402                               struct hda_bus **busp)
 
 406         static struct snd_device_ops dev_ops = {
 
 407                 .dev_free = snd_hda_bus_dev_free,
 
 410         snd_assert(temp, return -EINVAL);
 
 411         snd_assert(temp->ops.command && temp->ops.get_response, return -EINVAL);
 
 416         bus = kzalloc(sizeof(*bus), GFP_KERNEL);
 
 418                 snd_printk(KERN_ERR "can't allocate struct hda_bus\n");
 
 423         bus->private_data = temp->private_data;
 
 424         bus->pci = temp->pci;
 
 425         bus->modelname = temp->modelname;
 
 426         bus->ops = temp->ops;
 
 428         mutex_init(&bus->cmd_mutex);
 
 429         INIT_LIST_HEAD(&bus->codec_list);
 
 431         err = snd_device_new(card, SNDRV_DEV_BUS, bus, &dev_ops);
 
 433                 snd_hda_bus_free(bus);
 
 441 #ifdef CONFIG_SND_HDA_GENERIC
 
 442 #define is_generic_config(codec) \
 
 443         (codec->bus->modelname && !strcmp(codec->bus->modelname, "generic"))
 
 445 #define is_generic_config(codec)        0
 
 449  * find a matching codec preset
 
 451 static const struct hda_codec_preset __devinit *
 
 452 find_codec_preset(struct hda_codec *codec)
 
 454         const struct hda_codec_preset **tbl, *preset;
 
 456         if (is_generic_config(codec))
 
 457                 return NULL; /* use the generic parser */
 
 459         for (tbl = hda_preset_tables; *tbl; tbl++) {
 
 460                 for (preset = *tbl; preset->id; preset++) {
 
 461                         u32 mask = preset->mask;
 
 462                         if (preset->afg && preset->afg != codec->afg)
 
 464                         if (preset->mfg && preset->mfg != codec->mfg)
 
 468                         if (preset->id == (codec->vendor_id & mask) &&
 
 470                              preset->rev == codec->revision_id))
 
 478  * snd_hda_get_codec_name - store the codec name
 
 480 void snd_hda_get_codec_name(struct hda_codec *codec,
 
 481                             char *name, int namelen)
 
 483         const struct hda_vendor_id *c;
 
 484         const char *vendor = NULL;
 
 485         u16 vendor_id = codec->vendor_id >> 16;
 
 488         for (c = hda_vendor_ids; c->id; c++) {
 
 489                 if (c->id == vendor_id) {
 
 495                 sprintf(tmp, "Generic %04x", vendor_id);
 
 498         if (codec->preset && codec->preset->name)
 
 499                 snprintf(name, namelen, "%s %s", vendor, codec->preset->name);
 
 501                 snprintf(name, namelen, "%s ID %x", vendor,
 
 502                          codec->vendor_id & 0xffff);
 
 506  * look for an AFG and MFG nodes
 
 508 static void __devinit setup_fg_nodes(struct hda_codec *codec)
 
 513         total_nodes = snd_hda_get_sub_nodes(codec, AC_NODE_ROOT, &nid);
 
 514         for (i = 0; i < total_nodes; i++, nid++) {
 
 516                 func = snd_hda_param_read(codec, nid, AC_PAR_FUNCTION_TYPE);
 
 517                 switch (func & 0xff) {
 
 518                 case AC_GRP_AUDIO_FUNCTION:
 
 521                 case AC_GRP_MODEM_FUNCTION:
 
 531  * read widget caps for each widget and store in cache
 
 533 static int read_widget_caps(struct hda_codec *codec, hda_nid_t fg_node)
 
 538         codec->num_nodes = snd_hda_get_sub_nodes(codec, fg_node,
 
 540         codec->wcaps = kmalloc(codec->num_nodes * 4, GFP_KERNEL);
 
 543         nid = codec->start_nid;
 
 544         for (i = 0; i < codec->num_nodes; i++, nid++)
 
 545                 codec->wcaps[i] = snd_hda_param_read(codec, nid,
 
 546                                                      AC_PAR_AUDIO_WIDGET_CAP);
 
 551 static void init_hda_cache(struct hda_cache_rec *cache,
 
 552                            unsigned int record_size);
 
 553 static void free_hda_cache(struct hda_cache_rec *cache);
 
 558 static void snd_hda_codec_free(struct hda_codec *codec)
 
 562 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
 563         cancel_delayed_work(&codec->power_work);
 
 564         flush_scheduled_work();
 
 566         list_del(&codec->list);
 
 567         codec->bus->caddr_tbl[codec->addr] = NULL;
 
 568         if (codec->patch_ops.free)
 
 569                 codec->patch_ops.free(codec);
 
 570         free_hda_cache(&codec->amp_cache);
 
 571         free_hda_cache(&codec->cmd_cache);
 
 577  * snd_hda_codec_new - create a HDA codec
 
 578  * @bus: the bus to assign
 
 579  * @codec_addr: the codec address
 
 580  * @codecp: the pointer to store the generated codec
 
 582  * Returns 0 if successful, or a negative error code.
 
 584 int __devinit snd_hda_codec_new(struct hda_bus *bus, unsigned int codec_addr,
 
 585                                 struct hda_codec **codecp)
 
 587         struct hda_codec *codec;
 
 591         snd_assert(bus, return -EINVAL);
 
 592         snd_assert(codec_addr <= HDA_MAX_CODEC_ADDRESS, return -EINVAL);
 
 594         if (bus->caddr_tbl[codec_addr]) {
 
 595                 snd_printk(KERN_ERR "hda_codec: "
 
 596                            "address 0x%x is already occupied\n", codec_addr);
 
 600         codec = kzalloc(sizeof(*codec), GFP_KERNEL);
 
 602                 snd_printk(KERN_ERR "can't allocate struct hda_codec\n");
 
 607         codec->addr = codec_addr;
 
 608         mutex_init(&codec->spdif_mutex);
 
 609         init_hda_cache(&codec->amp_cache, sizeof(struct hda_amp_info));
 
 610         init_hda_cache(&codec->cmd_cache, sizeof(struct hda_cache_head));
 
 612 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
 613         INIT_DELAYED_WORK(&codec->power_work, hda_power_work);
 
 614         /* snd_hda_codec_new() marks the codec as power-up, and leave it as is.
 
 615          * the caller has to power down appropriatley after initialization
 
 618         hda_keep_power_on(codec);
 
 621         list_add_tail(&codec->list, &bus->codec_list);
 
 622         bus->caddr_tbl[codec_addr] = codec;
 
 624         codec->vendor_id = snd_hda_param_read(codec, AC_NODE_ROOT,
 
 626         if (codec->vendor_id == -1)
 
 627                 /* read again, hopefully the access method was corrected
 
 628                  * in the last read...
 
 630                 codec->vendor_id = snd_hda_param_read(codec, AC_NODE_ROOT,
 
 632         codec->subsystem_id = snd_hda_param_read(codec, AC_NODE_ROOT,
 
 633                                                  AC_PAR_SUBSYSTEM_ID);
 
 634         codec->revision_id = snd_hda_param_read(codec, AC_NODE_ROOT,
 
 637         setup_fg_nodes(codec);
 
 638         if (!codec->afg && !codec->mfg) {
 
 639                 snd_printdd("hda_codec: no AFG or MFG node found\n");
 
 640                 snd_hda_codec_free(codec);
 
 644         if (read_widget_caps(codec, codec->afg ? codec->afg : codec->mfg) < 0) {
 
 645                 snd_printk(KERN_ERR "hda_codec: cannot malloc\n");
 
 646                 snd_hda_codec_free(codec);
 
 650         if (!codec->subsystem_id) {
 
 651                 hda_nid_t nid = codec->afg ? codec->afg : codec->mfg;
 
 652                 codec->subsystem_id =
 
 653                         snd_hda_codec_read(codec, nid, 0,
 
 654                                            AC_VERB_GET_SUBSYSTEM_ID, 0);
 
 657         codec->preset = find_codec_preset(codec);
 
 658         /* audio codec should override the mixer name */
 
 659         if (codec->afg || !*bus->card->mixername)
 
 660                 snd_hda_get_codec_name(codec, bus->card->mixername,
 
 661                                        sizeof(bus->card->mixername));
 
 663         if (is_generic_config(codec)) {
 
 664                 err = snd_hda_parse_generic_codec(codec);
 
 667         if (codec->preset && codec->preset->patch) {
 
 668                 err = codec->preset->patch(codec);
 
 672         /* call the default parser */
 
 673         err = snd_hda_parse_generic_codec(codec);
 
 675                 printk(KERN_ERR "hda-codec: No codec parser is available\n");
 
 679                 snd_hda_codec_free(codec);
 
 683         if (codec->patch_ops.unsol_event)
 
 684                 init_unsol_queue(bus);
 
 686         snd_hda_codec_proc_new(codec);
 
 687 #ifdef CONFIG_SND_HDA_HWDEP
 
 688         snd_hda_create_hwdep(codec);
 
 691         sprintf(component, "HDA:%08x", codec->vendor_id);
 
 692         snd_component_add(codec->bus->card, component);
 
 700  * snd_hda_codec_setup_stream - set up the codec for streaming
 
 701  * @codec: the CODEC to set up
 
 702  * @nid: the NID to set up
 
 703  * @stream_tag: stream tag to pass, it's between 0x1 and 0xf.
 
 704  * @channel_id: channel id to pass, zero based.
 
 705  * @format: stream format.
 
 707 void snd_hda_codec_setup_stream(struct hda_codec *codec, hda_nid_t nid,
 
 709                                 int channel_id, int format)
 
 714         snd_printdd("hda_codec_setup_stream: "
 
 715                     "NID=0x%x, stream=0x%x, channel=%d, format=0x%x\n",
 
 716                     nid, stream_tag, channel_id, format);
 
 717         snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CHANNEL_STREAMID,
 
 718                             (stream_tag << 4) | channel_id);
 
 720         snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_STREAM_FORMAT, format);
 
 723 void snd_hda_codec_cleanup_stream(struct hda_codec *codec, hda_nid_t nid)
 
 728         snd_printdd("hda_codec_cleanup_stream: NID=0x%x\n", nid);
 
 729         snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CHANNEL_STREAMID, 0);
 
 730 #if 0 /* keep the format */
 
 732         snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_STREAM_FORMAT, 0);
 
 737  * amp access functions
 
 740 /* FIXME: more better hash key? */
 
 741 #define HDA_HASH_KEY(nid,dir,idx) (u32)((nid) + ((idx) << 16) + ((dir) << 24))
 
 742 #define INFO_AMP_CAPS   (1<<0)
 
 743 #define INFO_AMP_VOL(ch)        (1 << (1 + (ch)))
 
 745 /* initialize the hash table */
 
 746 static void __devinit init_hda_cache(struct hda_cache_rec *cache,
 
 747                                      unsigned int record_size)
 
 749         memset(cache, 0, sizeof(*cache));
 
 750         memset(cache->hash, 0xff, sizeof(cache->hash));
 
 751         cache->record_size = record_size;
 
 754 static void free_hda_cache(struct hda_cache_rec *cache)
 
 756         kfree(cache->buffer);
 
 759 /* query the hash.  allocate an entry if not found. */
 
 760 static struct hda_cache_head  *get_alloc_hash(struct hda_cache_rec *cache,
 
 763         u16 idx = key % (u16)ARRAY_SIZE(cache->hash);
 
 764         u16 cur = cache->hash[idx];
 
 765         struct hda_cache_head *info;
 
 767         while (cur != 0xffff) {
 
 768                 info = (struct hda_cache_head *)(cache->buffer +
 
 769                                                  cur * cache->record_size);
 
 770                 if (info->key == key)
 
 775         /* add a new hash entry */
 
 776         if (cache->num_entries >= cache->size) {
 
 777                 /* reallocate the array */
 
 778                 unsigned int new_size = cache->size + 64;
 
 780                 new_buffer = kcalloc(new_size, cache->record_size, GFP_KERNEL);
 
 782                         snd_printk(KERN_ERR "hda_codec: "
 
 783                                    "can't malloc amp_info\n");
 
 787                         memcpy(new_buffer, cache->buffer,
 
 788                                cache->size * cache->record_size);
 
 789                         kfree(cache->buffer);
 
 791                 cache->size = new_size;
 
 792                 cache->buffer = new_buffer;
 
 794         cur = cache->num_entries++;
 
 795         info = (struct hda_cache_head *)(cache->buffer +
 
 796                                          cur * cache->record_size);
 
 799         info->next = cache->hash[idx];
 
 800         cache->hash[idx] = cur;
 
 805 /* query and allocate an amp hash entry */
 
 806 static inline struct hda_amp_info *
 
 807 get_alloc_amp_hash(struct hda_codec *codec, u32 key)
 
 809         return (struct hda_amp_info *)get_alloc_hash(&codec->amp_cache, key);
 
 813  * query AMP capabilities for the given widget and direction
 
 815 u32 query_amp_caps(struct hda_codec *codec, hda_nid_t nid, int direction)
 
 817         struct hda_amp_info *info;
 
 819         info = get_alloc_amp_hash(codec, HDA_HASH_KEY(nid, direction, 0));
 
 822         if (!(info->head.val & INFO_AMP_CAPS)) {
 
 823                 if (!(get_wcaps(codec, nid) & AC_WCAP_AMP_OVRD))
 
 825                 info->amp_caps = snd_hda_param_read(codec, nid,
 
 826                                                     direction == HDA_OUTPUT ?
 
 830                         info->head.val |= INFO_AMP_CAPS;
 
 832         return info->amp_caps;
 
 835 int snd_hda_override_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir,
 
 838         struct hda_amp_info *info;
 
 840         info = get_alloc_amp_hash(codec, HDA_HASH_KEY(nid, dir, 0));
 
 843         info->amp_caps = caps;
 
 844         info->head.val |= INFO_AMP_CAPS;
 
 849  * read the current volume to info
 
 850  * if the cache exists, read the cache value.
 
 852 static unsigned int get_vol_mute(struct hda_codec *codec,
 
 853                                  struct hda_amp_info *info, hda_nid_t nid,
 
 854                                  int ch, int direction, int index)
 
 858         if (info->head.val & INFO_AMP_VOL(ch))
 
 859                 return info->vol[ch];
 
 861         parm = ch ? AC_AMP_GET_RIGHT : AC_AMP_GET_LEFT;
 
 862         parm |= direction == HDA_OUTPUT ? AC_AMP_GET_OUTPUT : AC_AMP_GET_INPUT;
 
 864         val = snd_hda_codec_read(codec, nid, 0,
 
 865                                  AC_VERB_GET_AMP_GAIN_MUTE, parm);
 
 866         info->vol[ch] = val & 0xff;
 
 867         info->head.val |= INFO_AMP_VOL(ch);
 
 868         return info->vol[ch];
 
 872  * write the current volume in info to the h/w and update the cache
 
 874 static void put_vol_mute(struct hda_codec *codec, struct hda_amp_info *info,
 
 875                          hda_nid_t nid, int ch, int direction, int index,
 
 880         parm = ch ? AC_AMP_SET_RIGHT : AC_AMP_SET_LEFT;
 
 881         parm |= direction == HDA_OUTPUT ? AC_AMP_SET_OUTPUT : AC_AMP_SET_INPUT;
 
 882         parm |= index << AC_AMP_SET_INDEX_SHIFT;
 
 884         snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE, parm);
 
 889  * read AMP value.  The volume is between 0 to 0x7f, 0x80 = mute bit.
 
 891 int snd_hda_codec_amp_read(struct hda_codec *codec, hda_nid_t nid, int ch,
 
 892                            int direction, int index)
 
 894         struct hda_amp_info *info;
 
 895         info = get_alloc_amp_hash(codec, HDA_HASH_KEY(nid, direction, index));
 
 898         return get_vol_mute(codec, info, nid, ch, direction, index);
 
 902  * update the AMP value, mask = bit mask to set, val = the value
 
 904 int snd_hda_codec_amp_update(struct hda_codec *codec, hda_nid_t nid, int ch,
 
 905                              int direction, int idx, int mask, int val)
 
 907         struct hda_amp_info *info;
 
 909         info = get_alloc_amp_hash(codec, HDA_HASH_KEY(nid, direction, idx));
 
 913         val |= get_vol_mute(codec, info, nid, ch, direction, idx) & ~mask;
 
 914         if (info->vol[ch] == val)
 
 916         put_vol_mute(codec, info, nid, ch, direction, idx, val);
 
 921  * update the AMP stereo with the same mask and value
 
 923 int snd_hda_codec_amp_stereo(struct hda_codec *codec, hda_nid_t nid,
 
 924                              int direction, int idx, int mask, int val)
 
 927         for (ch = 0; ch < 2; ch++)
 
 928                 ret |= snd_hda_codec_amp_update(codec, nid, ch, direction,
 
 933 #ifdef SND_HDA_NEEDS_RESUME
 
 934 /* resume the all amp commands from the cache */
 
 935 void snd_hda_codec_resume_amp(struct hda_codec *codec)
 
 937         struct hda_amp_info *buffer = codec->amp_cache.buffer;
 
 940         for (i = 0; i < codec->amp_cache.size; i++, buffer++) {
 
 941                 u32 key = buffer->head.key;
 
 943                 unsigned int idx, dir, ch;
 
 947                 idx = (key >> 16) & 0xff;
 
 948                 dir = (key >> 24) & 0xff;
 
 949                 for (ch = 0; ch < 2; ch++) {
 
 950                         if (!(buffer->head.val & INFO_AMP_VOL(ch)))
 
 952                         put_vol_mute(codec, buffer, nid, ch, dir, idx,
 
 957 #endif /* SND_HDA_NEEDS_RESUME */
 
 960  * AMP control callbacks
 
 962 /* retrieve parameters from private_value */
 
 963 #define get_amp_nid(kc)         ((kc)->private_value & 0xffff)
 
 964 #define get_amp_channels(kc)    (((kc)->private_value >> 16) & 0x3)
 
 965 #define get_amp_direction(kc)   (((kc)->private_value >> 18) & 0x1)
 
 966 #define get_amp_index(kc)       (((kc)->private_value >> 19) & 0xf)
 
 969 int snd_hda_mixer_amp_volume_info(struct snd_kcontrol *kcontrol,
 
 970                                   struct snd_ctl_elem_info *uinfo)
 
 972         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
 973         u16 nid = get_amp_nid(kcontrol);
 
 974         u8 chs = get_amp_channels(kcontrol);
 
 975         int dir = get_amp_direction(kcontrol);
 
 978         caps = query_amp_caps(codec, nid, dir);
 
 980         caps = (caps & AC_AMPCAP_NUM_STEPS) >> AC_AMPCAP_NUM_STEPS_SHIFT;
 
 982                 printk(KERN_WARNING "hda_codec: "
 
 983                        "num_steps = 0 for NID=0x%x (ctl = %s)\n", nid,
 
 987         uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
 
 988         uinfo->count = chs == 3 ? 2 : 1;
 
 989         uinfo->value.integer.min = 0;
 
 990         uinfo->value.integer.max = caps;
 
 994 int snd_hda_mixer_amp_volume_get(struct snd_kcontrol *kcontrol,
 
 995                                  struct snd_ctl_elem_value *ucontrol)
 
 997         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
 998         hda_nid_t nid = get_amp_nid(kcontrol);
 
 999         int chs = get_amp_channels(kcontrol);
 
1000         int dir = get_amp_direction(kcontrol);
 
1001         int idx = get_amp_index(kcontrol);
 
1002         long *valp = ucontrol->value.integer.value;
 
1005                 *valp++ = snd_hda_codec_amp_read(codec, nid, 0, dir, idx)
 
1008                 *valp = snd_hda_codec_amp_read(codec, nid, 1, dir, idx)
 
1013 int snd_hda_mixer_amp_volume_put(struct snd_kcontrol *kcontrol,
 
1014                                  struct snd_ctl_elem_value *ucontrol)
 
1016         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1017         hda_nid_t nid = get_amp_nid(kcontrol);
 
1018         int chs = get_amp_channels(kcontrol);
 
1019         int dir = get_amp_direction(kcontrol);
 
1020         int idx = get_amp_index(kcontrol);
 
1021         long *valp = ucontrol->value.integer.value;
 
1024         snd_hda_power_up(codec);
 
1026                 change = snd_hda_codec_amp_update(codec, nid, 0, dir, idx,
 
1031                 change |= snd_hda_codec_amp_update(codec, nid, 1, dir, idx,
 
1033         snd_hda_power_down(codec);
 
1037 int snd_hda_mixer_amp_tlv(struct snd_kcontrol *kcontrol, int op_flag,
 
1038                           unsigned int size, unsigned int __user *_tlv)
 
1040         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1041         hda_nid_t nid = get_amp_nid(kcontrol);
 
1042         int dir = get_amp_direction(kcontrol);
 
1043         u32 caps, val1, val2;
 
1045         if (size < 4 * sizeof(unsigned int))
 
1047         caps = query_amp_caps(codec, nid, dir);
 
1048         val2 = (caps & AC_AMPCAP_STEP_SIZE) >> AC_AMPCAP_STEP_SIZE_SHIFT;
 
1049         val2 = (val2 + 1) * 25;
 
1050         val1 = -((caps & AC_AMPCAP_OFFSET) >> AC_AMPCAP_OFFSET_SHIFT);
 
1051         val1 = ((int)val1) * ((int)val2);
 
1052         if (put_user(SNDRV_CTL_TLVT_DB_SCALE, _tlv))
 
1054         if (put_user(2 * sizeof(unsigned int), _tlv + 1))
 
1056         if (put_user(val1, _tlv + 2))
 
1058         if (put_user(val2, _tlv + 3))
 
1064  * set (static) TLV for virtual master volume; recalculated as max 0dB
 
1066 void snd_hda_set_vmaster_tlv(struct hda_codec *codec, hda_nid_t nid, int dir,
 
1072         caps = query_amp_caps(codec, nid, dir);
 
1073         nums = (caps & AC_AMPCAP_NUM_STEPS) >> AC_AMPCAP_NUM_STEPS_SHIFT;
 
1074         step = (caps & AC_AMPCAP_STEP_SIZE) >> AC_AMPCAP_STEP_SIZE_SHIFT;
 
1075         step = (step + 1) * 25;
 
1076         tlv[0] = SNDRV_CTL_TLVT_DB_SCALE;
 
1077         tlv[1] = 2 * sizeof(unsigned int);
 
1078         tlv[2] = -nums * step;
 
1082 /* find a mixer control element with the given name */
 
1083 static struct snd_kcontrol *
 
1084 _snd_hda_find_mixer_ctl(struct hda_codec *codec,
 
1085                         const char *name, int idx)
 
1087         struct snd_ctl_elem_id id;
 
1088         memset(&id, 0, sizeof(id));
 
1089         id.iface = SNDRV_CTL_ELEM_IFACE_MIXER;
 
1091         strcpy(id.name, name);
 
1092         return snd_ctl_find_id(codec->bus->card, &id);
 
1095 struct snd_kcontrol *snd_hda_find_mixer_ctl(struct hda_codec *codec,
 
1098         return _snd_hda_find_mixer_ctl(codec, name, 0);
 
1101 /* create a virtual master control and add slaves */
 
1102 int snd_hda_add_vmaster(struct hda_codec *codec, char *name,
 
1103                         unsigned int *tlv, const char **slaves)
 
1105         struct snd_kcontrol *kctl;
 
1109         for (s = slaves; *s && !snd_hda_find_mixer_ctl(codec, *s); s++)
 
1112                 snd_printdd("No slave found for %s\n", name);
 
1115         kctl = snd_ctl_make_virtual_master(name, tlv);
 
1118         err = snd_ctl_add(codec->bus->card, kctl);
 
1122         for (s = slaves; *s; s++) {
 
1123                 struct snd_kcontrol *sctl;
 
1125                 sctl = snd_hda_find_mixer_ctl(codec, *s);
 
1127                         snd_printdd("Cannot find slave %s, skipped\n", *s);
 
1130                 err = snd_ctl_add_slave(kctl, sctl);
 
1138 int snd_hda_mixer_amp_switch_info(struct snd_kcontrol *kcontrol,
 
1139                                   struct snd_ctl_elem_info *uinfo)
 
1141         int chs = get_amp_channels(kcontrol);
 
1143         uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
 
1144         uinfo->count = chs == 3 ? 2 : 1;
 
1145         uinfo->value.integer.min = 0;
 
1146         uinfo->value.integer.max = 1;
 
1150 int snd_hda_mixer_amp_switch_get(struct snd_kcontrol *kcontrol,
 
1151                                  struct snd_ctl_elem_value *ucontrol)
 
1153         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1154         hda_nid_t nid = get_amp_nid(kcontrol);
 
1155         int chs = get_amp_channels(kcontrol);
 
1156         int dir = get_amp_direction(kcontrol);
 
1157         int idx = get_amp_index(kcontrol);
 
1158         long *valp = ucontrol->value.integer.value;
 
1161                 *valp++ = (snd_hda_codec_amp_read(codec, nid, 0, dir, idx) &
 
1162                            HDA_AMP_MUTE) ? 0 : 1;
 
1164                 *valp = (snd_hda_codec_amp_read(codec, nid, 1, dir, idx) &
 
1165                          HDA_AMP_MUTE) ? 0 : 1;
 
1169 int snd_hda_mixer_amp_switch_put(struct snd_kcontrol *kcontrol,
 
1170                                  struct snd_ctl_elem_value *ucontrol)
 
1172         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1173         hda_nid_t nid = get_amp_nid(kcontrol);
 
1174         int chs = get_amp_channels(kcontrol);
 
1175         int dir = get_amp_direction(kcontrol);
 
1176         int idx = get_amp_index(kcontrol);
 
1177         long *valp = ucontrol->value.integer.value;
 
1180         snd_hda_power_up(codec);
 
1182                 change = snd_hda_codec_amp_update(codec, nid, 0, dir, idx,
 
1184                                                   *valp ? 0 : HDA_AMP_MUTE);
 
1188                 change |= snd_hda_codec_amp_update(codec, nid, 1, dir, idx,
 
1190                                                    *valp ? 0 : HDA_AMP_MUTE);
 
1191 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
1192         if (codec->patch_ops.check_power_status)
 
1193                 codec->patch_ops.check_power_status(codec, nid);
 
1195         snd_hda_power_down(codec);
 
1200  * bound volume controls
 
1202  * bind multiple volumes (# indices, from 0)
 
1205 #define AMP_VAL_IDX_SHIFT       19
 
1206 #define AMP_VAL_IDX_MASK        (0x0f<<19)
 
1208 int snd_hda_mixer_bind_switch_get(struct snd_kcontrol *kcontrol,
 
1209                                   struct snd_ctl_elem_value *ucontrol)
 
1211         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1215         mutex_lock(&codec->spdif_mutex); /* reuse spdif_mutex */
 
1216         pval = kcontrol->private_value;
 
1217         kcontrol->private_value = pval & ~AMP_VAL_IDX_MASK; /* index 0 */
 
1218         err = snd_hda_mixer_amp_switch_get(kcontrol, ucontrol);
 
1219         kcontrol->private_value = pval;
 
1220         mutex_unlock(&codec->spdif_mutex);
 
1224 int snd_hda_mixer_bind_switch_put(struct snd_kcontrol *kcontrol,
 
1225                                   struct snd_ctl_elem_value *ucontrol)
 
1227         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1229         int i, indices, err = 0, change = 0;
 
1231         mutex_lock(&codec->spdif_mutex); /* reuse spdif_mutex */
 
1232         pval = kcontrol->private_value;
 
1233         indices = (pval & AMP_VAL_IDX_MASK) >> AMP_VAL_IDX_SHIFT;
 
1234         for (i = 0; i < indices; i++) {
 
1235                 kcontrol->private_value = (pval & ~AMP_VAL_IDX_MASK) |
 
1236                         (i << AMP_VAL_IDX_SHIFT);
 
1237                 err = snd_hda_mixer_amp_switch_put(kcontrol, ucontrol);
 
1242         kcontrol->private_value = pval;
 
1243         mutex_unlock(&codec->spdif_mutex);
 
1244         return err < 0 ? err : change;
 
1248  * generic bound volume/swtich controls
 
1250 int snd_hda_mixer_bind_ctls_info(struct snd_kcontrol *kcontrol,
 
1251                                  struct snd_ctl_elem_info *uinfo)
 
1253         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1254         struct hda_bind_ctls *c;
 
1257         mutex_lock(&codec->spdif_mutex); /* reuse spdif_mutex */
 
1258         c = (struct hda_bind_ctls *)kcontrol->private_value;
 
1259         kcontrol->private_value = *c->values;
 
1260         err = c->ops->info(kcontrol, uinfo);
 
1261         kcontrol->private_value = (long)c;
 
1262         mutex_unlock(&codec->spdif_mutex);
 
1266 int snd_hda_mixer_bind_ctls_get(struct snd_kcontrol *kcontrol,
 
1267                                 struct snd_ctl_elem_value *ucontrol)
 
1269         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1270         struct hda_bind_ctls *c;
 
1273         mutex_lock(&codec->spdif_mutex); /* reuse spdif_mutex */
 
1274         c = (struct hda_bind_ctls *)kcontrol->private_value;
 
1275         kcontrol->private_value = *c->values;
 
1276         err = c->ops->get(kcontrol, ucontrol);
 
1277         kcontrol->private_value = (long)c;
 
1278         mutex_unlock(&codec->spdif_mutex);
 
1282 int snd_hda_mixer_bind_ctls_put(struct snd_kcontrol *kcontrol,
 
1283                                 struct snd_ctl_elem_value *ucontrol)
 
1285         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1286         struct hda_bind_ctls *c;
 
1287         unsigned long *vals;
 
1288         int err = 0, change = 0;
 
1290         mutex_lock(&codec->spdif_mutex); /* reuse spdif_mutex */
 
1291         c = (struct hda_bind_ctls *)kcontrol->private_value;
 
1292         for (vals = c->values; *vals; vals++) {
 
1293                 kcontrol->private_value = *vals;
 
1294                 err = c->ops->put(kcontrol, ucontrol);
 
1299         kcontrol->private_value = (long)c;
 
1300         mutex_unlock(&codec->spdif_mutex);
 
1301         return err < 0 ? err : change;
 
1304 int snd_hda_mixer_bind_tlv(struct snd_kcontrol *kcontrol, int op_flag,
 
1305                            unsigned int size, unsigned int __user *tlv)
 
1307         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1308         struct hda_bind_ctls *c;
 
1311         mutex_lock(&codec->spdif_mutex); /* reuse spdif_mutex */
 
1312         c = (struct hda_bind_ctls *)kcontrol->private_value;
 
1313         kcontrol->private_value = *c->values;
 
1314         err = c->ops->tlv(kcontrol, op_flag, size, tlv);
 
1315         kcontrol->private_value = (long)c;
 
1316         mutex_unlock(&codec->spdif_mutex);
 
1320 struct hda_ctl_ops snd_hda_bind_vol = {
 
1321         .info = snd_hda_mixer_amp_volume_info,
 
1322         .get = snd_hda_mixer_amp_volume_get,
 
1323         .put = snd_hda_mixer_amp_volume_put,
 
1324         .tlv = snd_hda_mixer_amp_tlv
 
1327 struct hda_ctl_ops snd_hda_bind_sw = {
 
1328         .info = snd_hda_mixer_amp_switch_info,
 
1329         .get = snd_hda_mixer_amp_switch_get,
 
1330         .put = snd_hda_mixer_amp_switch_put,
 
1331         .tlv = snd_hda_mixer_amp_tlv
 
1335  * SPDIF out controls
 
1338 static int snd_hda_spdif_mask_info(struct snd_kcontrol *kcontrol,
 
1339                                    struct snd_ctl_elem_info *uinfo)
 
1341         uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958;
 
1346 static int snd_hda_spdif_cmask_get(struct snd_kcontrol *kcontrol,
 
1347                                    struct snd_ctl_elem_value *ucontrol)
 
1349         ucontrol->value.iec958.status[0] = IEC958_AES0_PROFESSIONAL |
 
1350                                            IEC958_AES0_NONAUDIO |
 
1351                                            IEC958_AES0_CON_EMPHASIS_5015 |
 
1352                                            IEC958_AES0_CON_NOT_COPYRIGHT;
 
1353         ucontrol->value.iec958.status[1] = IEC958_AES1_CON_CATEGORY |
 
1354                                            IEC958_AES1_CON_ORIGINAL;
 
1358 static int snd_hda_spdif_pmask_get(struct snd_kcontrol *kcontrol,
 
1359                                    struct snd_ctl_elem_value *ucontrol)
 
1361         ucontrol->value.iec958.status[0] = IEC958_AES0_PROFESSIONAL |
 
1362                                            IEC958_AES0_NONAUDIO |
 
1363                                            IEC958_AES0_PRO_EMPHASIS_5015;
 
1367 static int snd_hda_spdif_default_get(struct snd_kcontrol *kcontrol,
 
1368                                      struct snd_ctl_elem_value *ucontrol)
 
1370         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1372         ucontrol->value.iec958.status[0] = codec->spdif_status & 0xff;
 
1373         ucontrol->value.iec958.status[1] = (codec->spdif_status >> 8) & 0xff;
 
1374         ucontrol->value.iec958.status[2] = (codec->spdif_status >> 16) & 0xff;
 
1375         ucontrol->value.iec958.status[3] = (codec->spdif_status >> 24) & 0xff;
 
1380 /* convert from SPDIF status bits to HDA SPDIF bits
 
1381  * bit 0 (DigEn) is always set zero (to be filled later)
 
1383 static unsigned short convert_from_spdif_status(unsigned int sbits)
 
1385         unsigned short val = 0;
 
1387         if (sbits & IEC958_AES0_PROFESSIONAL)
 
1388                 val |= AC_DIG1_PROFESSIONAL;
 
1389         if (sbits & IEC958_AES0_NONAUDIO)
 
1390                 val |= AC_DIG1_NONAUDIO;
 
1391         if (sbits & IEC958_AES0_PROFESSIONAL) {
 
1392                 if ((sbits & IEC958_AES0_PRO_EMPHASIS) ==
 
1393                     IEC958_AES0_PRO_EMPHASIS_5015)
 
1394                         val |= AC_DIG1_EMPHASIS;
 
1396                 if ((sbits & IEC958_AES0_CON_EMPHASIS) ==
 
1397                     IEC958_AES0_CON_EMPHASIS_5015)
 
1398                         val |= AC_DIG1_EMPHASIS;
 
1399                 if (!(sbits & IEC958_AES0_CON_NOT_COPYRIGHT))
 
1400                         val |= AC_DIG1_COPYRIGHT;
 
1401                 if (sbits & (IEC958_AES1_CON_ORIGINAL << 8))
 
1402                         val |= AC_DIG1_LEVEL;
 
1403                 val |= sbits & (IEC958_AES1_CON_CATEGORY << 8);
 
1408 /* convert to SPDIF status bits from HDA SPDIF bits
 
1410 static unsigned int convert_to_spdif_status(unsigned short val)
 
1412         unsigned int sbits = 0;
 
1414         if (val & AC_DIG1_NONAUDIO)
 
1415                 sbits |= IEC958_AES0_NONAUDIO;
 
1416         if (val & AC_DIG1_PROFESSIONAL)
 
1417                 sbits |= IEC958_AES0_PROFESSIONAL;
 
1418         if (sbits & IEC958_AES0_PROFESSIONAL) {
 
1419                 if (sbits & AC_DIG1_EMPHASIS)
 
1420                         sbits |= IEC958_AES0_PRO_EMPHASIS_5015;
 
1422                 if (val & AC_DIG1_EMPHASIS)
 
1423                         sbits |= IEC958_AES0_CON_EMPHASIS_5015;
 
1424                 if (!(val & AC_DIG1_COPYRIGHT))
 
1425                         sbits |= IEC958_AES0_CON_NOT_COPYRIGHT;
 
1426                 if (val & AC_DIG1_LEVEL)
 
1427                         sbits |= (IEC958_AES1_CON_ORIGINAL << 8);
 
1428                 sbits |= val & (0x7f << 8);
 
1433 static int snd_hda_spdif_default_put(struct snd_kcontrol *kcontrol,
 
1434                                      struct snd_ctl_elem_value *ucontrol)
 
1436         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1437         hda_nid_t nid = kcontrol->private_value;
 
1441         mutex_lock(&codec->spdif_mutex);
 
1442         codec->spdif_status = ucontrol->value.iec958.status[0] |
 
1443                 ((unsigned int)ucontrol->value.iec958.status[1] << 8) |
 
1444                 ((unsigned int)ucontrol->value.iec958.status[2] << 16) |
 
1445                 ((unsigned int)ucontrol->value.iec958.status[3] << 24);
 
1446         val = convert_from_spdif_status(codec->spdif_status);
 
1447         val |= codec->spdif_ctls & 1;
 
1448         change = codec->spdif_ctls != val;
 
1449         codec->spdif_ctls = val;
 
1452                 snd_hda_codec_write_cache(codec, nid, 0,
 
1453                                           AC_VERB_SET_DIGI_CONVERT_1,
 
1455                 snd_hda_codec_write_cache(codec, nid, 0,
 
1456                                           AC_VERB_SET_DIGI_CONVERT_2,
 
1460         mutex_unlock(&codec->spdif_mutex);
 
1464 #define snd_hda_spdif_out_switch_info   snd_ctl_boolean_mono_info
 
1466 static int snd_hda_spdif_out_switch_get(struct snd_kcontrol *kcontrol,
 
1467                                         struct snd_ctl_elem_value *ucontrol)
 
1469         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1471         ucontrol->value.integer.value[0] = codec->spdif_ctls & AC_DIG1_ENABLE;
 
1475 static int snd_hda_spdif_out_switch_put(struct snd_kcontrol *kcontrol,
 
1476                                         struct snd_ctl_elem_value *ucontrol)
 
1478         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1479         hda_nid_t nid = kcontrol->private_value;
 
1483         mutex_lock(&codec->spdif_mutex);
 
1484         val = codec->spdif_ctls & ~AC_DIG1_ENABLE;
 
1485         if (ucontrol->value.integer.value[0])
 
1486                 val |= AC_DIG1_ENABLE;
 
1487         change = codec->spdif_ctls != val;
 
1489                 codec->spdif_ctls = val;
 
1490                 snd_hda_codec_write_cache(codec, nid, 0,
 
1491                                           AC_VERB_SET_DIGI_CONVERT_1,
 
1493                 /* unmute amp switch (if any) */
 
1494                 if ((get_wcaps(codec, nid) & AC_WCAP_OUT_AMP) &&
 
1495                     (val & AC_DIG1_ENABLE))
 
1496                         snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0,
 
1499         mutex_unlock(&codec->spdif_mutex);
 
1503 static struct snd_kcontrol_new dig_mixes[] = {
 
1505                 .access = SNDRV_CTL_ELEM_ACCESS_READ,
 
1506                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 
1507                 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,CON_MASK),
 
1508                 .info = snd_hda_spdif_mask_info,
 
1509                 .get = snd_hda_spdif_cmask_get,
 
1512                 .access = SNDRV_CTL_ELEM_ACCESS_READ,
 
1513                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 
1514                 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,PRO_MASK),
 
1515                 .info = snd_hda_spdif_mask_info,
 
1516                 .get = snd_hda_spdif_pmask_get,
 
1519                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 
1520                 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,DEFAULT),
 
1521                 .info = snd_hda_spdif_mask_info,
 
1522                 .get = snd_hda_spdif_default_get,
 
1523                 .put = snd_hda_spdif_default_put,
 
1526                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 
1527                 .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,SWITCH),
 
1528                 .info = snd_hda_spdif_out_switch_info,
 
1529                 .get = snd_hda_spdif_out_switch_get,
 
1530                 .put = snd_hda_spdif_out_switch_put,
 
1535 #define SPDIF_MAX_IDX   4       /* 4 instances should be enough to probe */
 
1538  * snd_hda_create_spdif_out_ctls - create Output SPDIF-related controls
 
1539  * @codec: the HDA codec
 
1540  * @nid: audio out widget NID
 
1542  * Creates controls related with the SPDIF output.
 
1543  * Called from each patch supporting the SPDIF out.
 
1545  * Returns 0 if successful, or a negative error code.
 
1547 int snd_hda_create_spdif_out_ctls(struct hda_codec *codec, hda_nid_t nid)
 
1550         struct snd_kcontrol *kctl;
 
1551         struct snd_kcontrol_new *dig_mix;
 
1554         for (idx = 0; idx < SPDIF_MAX_IDX; idx++) {
 
1555                 if (!_snd_hda_find_mixer_ctl(codec, "IEC958 Playback Switch",
 
1559         if (idx >= SPDIF_MAX_IDX) {
 
1560                 printk(KERN_ERR "hda_codec: too many IEC958 outputs\n");
 
1563         for (dig_mix = dig_mixes; dig_mix->name; dig_mix++) {
 
1564                 kctl = snd_ctl_new1(dig_mix, codec);
 
1565                 kctl->id.index = idx;
 
1566                 kctl->private_value = nid;
 
1567                 err = snd_ctl_add(codec->bus->card, kctl);
 
1572                 snd_hda_codec_read(codec, nid, 0,
 
1573                                    AC_VERB_GET_DIGI_CONVERT_1, 0);
 
1574         codec->spdif_status = convert_to_spdif_status(codec->spdif_ctls);
 
1579  * SPDIF sharing with analog output
 
1581 static int spdif_share_sw_get(struct snd_kcontrol *kcontrol,
 
1582                               struct snd_ctl_elem_value *ucontrol)
 
1584         struct hda_multi_out *mout = snd_kcontrol_chip(kcontrol);
 
1585         ucontrol->value.integer.value[0] = mout->share_spdif;
 
1589 static int spdif_share_sw_put(struct snd_kcontrol *kcontrol,
 
1590                               struct snd_ctl_elem_value *ucontrol)
 
1592         struct hda_multi_out *mout = snd_kcontrol_chip(kcontrol);
 
1593         mout->share_spdif = !!ucontrol->value.integer.value[0];
 
1597 static struct snd_kcontrol_new spdif_share_sw = {
 
1598         .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 
1599         .name = "IEC958 Default PCM Playback Switch",
 
1600         .info = snd_ctl_boolean_mono_info,
 
1601         .get = spdif_share_sw_get,
 
1602         .put = spdif_share_sw_put,
 
1605 int snd_hda_create_spdif_share_sw(struct hda_codec *codec,
 
1606                                   struct hda_multi_out *mout)
 
1608         if (!mout->dig_out_nid)
 
1610         /* ATTENTION: here mout is passed as private_data, instead of codec */
 
1611         return snd_ctl_add(codec->bus->card,
 
1612                            snd_ctl_new1(&spdif_share_sw, mout));
 
1619 #define snd_hda_spdif_in_switch_info    snd_hda_spdif_out_switch_info
 
1621 static int snd_hda_spdif_in_switch_get(struct snd_kcontrol *kcontrol,
 
1622                                        struct snd_ctl_elem_value *ucontrol)
 
1624         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1626         ucontrol->value.integer.value[0] = codec->spdif_in_enable;
 
1630 static int snd_hda_spdif_in_switch_put(struct snd_kcontrol *kcontrol,
 
1631                                        struct snd_ctl_elem_value *ucontrol)
 
1633         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1634         hda_nid_t nid = kcontrol->private_value;
 
1635         unsigned int val = !!ucontrol->value.integer.value[0];
 
1638         mutex_lock(&codec->spdif_mutex);
 
1639         change = codec->spdif_in_enable != val;
 
1641                 codec->spdif_in_enable = val;
 
1642                 snd_hda_codec_write_cache(codec, nid, 0,
 
1643                                           AC_VERB_SET_DIGI_CONVERT_1, val);
 
1645         mutex_unlock(&codec->spdif_mutex);
 
1649 static int snd_hda_spdif_in_status_get(struct snd_kcontrol *kcontrol,
 
1650                                        struct snd_ctl_elem_value *ucontrol)
 
1652         struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
1653         hda_nid_t nid = kcontrol->private_value;
 
1657         val = snd_hda_codec_read(codec, nid, 0, AC_VERB_GET_DIGI_CONVERT_1, 0);
 
1658         sbits = convert_to_spdif_status(val);
 
1659         ucontrol->value.iec958.status[0] = sbits;
 
1660         ucontrol->value.iec958.status[1] = sbits >> 8;
 
1661         ucontrol->value.iec958.status[2] = sbits >> 16;
 
1662         ucontrol->value.iec958.status[3] = sbits >> 24;
 
1666 static struct snd_kcontrol_new dig_in_ctls[] = {
 
1668                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 
1669                 .name = SNDRV_CTL_NAME_IEC958("",CAPTURE,SWITCH),
 
1670                 .info = snd_hda_spdif_in_switch_info,
 
1671                 .get = snd_hda_spdif_in_switch_get,
 
1672                 .put = snd_hda_spdif_in_switch_put,
 
1675                 .access = SNDRV_CTL_ELEM_ACCESS_READ,
 
1676                 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 
1677                 .name = SNDRV_CTL_NAME_IEC958("",CAPTURE,DEFAULT),
 
1678                 .info = snd_hda_spdif_mask_info,
 
1679                 .get = snd_hda_spdif_in_status_get,
 
1685  * snd_hda_create_spdif_in_ctls - create Input SPDIF-related controls
 
1686  * @codec: the HDA codec
 
1687  * @nid: audio in widget NID
 
1689  * Creates controls related with the SPDIF input.
 
1690  * Called from each patch supporting the SPDIF in.
 
1692  * Returns 0 if successful, or a negative error code.
 
1694 int snd_hda_create_spdif_in_ctls(struct hda_codec *codec, hda_nid_t nid)
 
1697         struct snd_kcontrol *kctl;
 
1698         struct snd_kcontrol_new *dig_mix;
 
1701         for (idx = 0; idx < SPDIF_MAX_IDX; idx++) {
 
1702                 if (!_snd_hda_find_mixer_ctl(codec, "IEC958 Capture Switch",
 
1706         if (idx >= SPDIF_MAX_IDX) {
 
1707                 printk(KERN_ERR "hda_codec: too many IEC958 inputs\n");
 
1710         for (dig_mix = dig_in_ctls; dig_mix->name; dig_mix++) {
 
1711                 kctl = snd_ctl_new1(dig_mix, codec);
 
1712                 kctl->private_value = nid;
 
1713                 err = snd_ctl_add(codec->bus->card, kctl);
 
1717         codec->spdif_in_enable =
 
1718                 snd_hda_codec_read(codec, nid, 0,
 
1719                                    AC_VERB_GET_DIGI_CONVERT_1, 0) &
 
1724 #ifdef SND_HDA_NEEDS_RESUME
 
1729 /* build a 32bit cache key with the widget id and the command parameter */
 
1730 #define build_cmd_cache_key(nid, verb)  ((verb << 8) | nid)
 
1731 #define get_cmd_cache_nid(key)          ((key) & 0xff)
 
1732 #define get_cmd_cache_cmd(key)          (((key) >> 8) & 0xffff)
 
1735  * snd_hda_codec_write_cache - send a single command with caching
 
1736  * @codec: the HDA codec
 
1737  * @nid: NID to send the command
 
1738  * @direct: direct flag
 
1739  * @verb: the verb to send
 
1740  * @parm: the parameter for the verb
 
1742  * Send a single command without waiting for response.
 
1744  * Returns 0 if successful, or a negative error code.
 
1746 int snd_hda_codec_write_cache(struct hda_codec *codec, hda_nid_t nid,
 
1747                               int direct, unsigned int verb, unsigned int parm)
 
1750         snd_hda_power_up(codec);
 
1751         mutex_lock(&codec->bus->cmd_mutex);
 
1752         err = codec->bus->ops.command(codec, nid, direct, verb, parm);
 
1754                 struct hda_cache_head *c;
 
1755                 u32 key = build_cmd_cache_key(nid, verb);
 
1756                 c = get_alloc_hash(&codec->cmd_cache, key);
 
1760         mutex_unlock(&codec->bus->cmd_mutex);
 
1761         snd_hda_power_down(codec);
 
1765 /* resume the all commands from the cache */
 
1766 void snd_hda_codec_resume_cache(struct hda_codec *codec)
 
1768         struct hda_cache_head *buffer = codec->cmd_cache.buffer;
 
1771         for (i = 0; i < codec->cmd_cache.size; i++, buffer++) {
 
1772                 u32 key = buffer->key;
 
1775                 snd_hda_codec_write(codec, get_cmd_cache_nid(key), 0,
 
1776                                     get_cmd_cache_cmd(key), buffer->val);
 
1781  * snd_hda_sequence_write_cache - sequence writes with caching
 
1782  * @codec: the HDA codec
 
1783  * @seq: VERB array to send
 
1785  * Send the commands sequentially from the given array.
 
1786  * Thte commands are recorded on cache for power-save and resume.
 
1787  * The array must be terminated with NID=0.
 
1789 void snd_hda_sequence_write_cache(struct hda_codec *codec,
 
1790                                   const struct hda_verb *seq)
 
1792         for (; seq->nid; seq++)
 
1793                 snd_hda_codec_write_cache(codec, seq->nid, 0, seq->verb,
 
1796 #endif /* SND_HDA_NEEDS_RESUME */
 
1799  * set power state of the codec
 
1801 static void hda_set_power_state(struct hda_codec *codec, hda_nid_t fg,
 
1802                                 unsigned int power_state)
 
1807         snd_hda_codec_write(codec, fg, 0, AC_VERB_SET_POWER_STATE,
 
1809         msleep(10); /* partial workaround for "azx_get_response timeout" */
 
1811         nid = codec->start_nid;
 
1812         for (i = 0; i < codec->num_nodes; i++, nid++) {
 
1813                 unsigned int wcaps = get_wcaps(codec, nid);
 
1814                 if (wcaps & AC_WCAP_POWER) {
 
1815                         unsigned int wid_type = (wcaps & AC_WCAP_TYPE) >>
 
1817                         if (wid_type == AC_WID_PIN) {
 
1818                                 unsigned int pincap;
 
1820                                  * don't power down the widget if it controls
 
1821                                  * eapd and EAPD_BTLENABLE is set.
 
1823                                 pincap = snd_hda_param_read(codec, nid,
 
1825                                 if (pincap & AC_PINCAP_EAPD) {
 
1826                                         int eapd = snd_hda_codec_read(codec,
 
1828                                                 AC_VERB_GET_EAPD_BTLENABLE, 0);
 
1830                                         if (power_state == AC_PWRST_D3 && eapd)
 
1834                         snd_hda_codec_write(codec, nid, 0,
 
1835                                             AC_VERB_SET_POWER_STATE,
 
1840         if (power_state == AC_PWRST_D0) {
 
1841                 unsigned long end_time;
 
1844                 /* wait until the codec reachs to D0 */
 
1845                 end_time = jiffies + msecs_to_jiffies(500);
 
1847                         state = snd_hda_codec_read(codec, fg, 0,
 
1848                                                    AC_VERB_GET_POWER_STATE, 0);
 
1849                         if (state == power_state)
 
1852                 } while (time_after_eq(end_time, jiffies));
 
1856 #ifdef SND_HDA_NEEDS_RESUME
 
1858  * call suspend and power-down; used both from PM and power-save
 
1860 static void hda_call_codec_suspend(struct hda_codec *codec)
 
1862         if (codec->patch_ops.suspend)
 
1863                 codec->patch_ops.suspend(codec, PMSG_SUSPEND);
 
1864         hda_set_power_state(codec,
 
1865                             codec->afg ? codec->afg : codec->mfg,
 
1867 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
1868         cancel_delayed_work(&codec->power_work);
 
1869         codec->power_on = 0;
 
1870         codec->power_transition = 0;
 
1875  * kick up codec; used both from PM and power-save
 
1877 static void hda_call_codec_resume(struct hda_codec *codec)
 
1879         hda_set_power_state(codec,
 
1880                             codec->afg ? codec->afg : codec->mfg,
 
1882         if (codec->patch_ops.resume)
 
1883                 codec->patch_ops.resume(codec);
 
1885                 if (codec->patch_ops.init)
 
1886                         codec->patch_ops.init(codec);
 
1887                 snd_hda_codec_resume_amp(codec);
 
1888                 snd_hda_codec_resume_cache(codec);
 
1891 #endif /* SND_HDA_NEEDS_RESUME */
 
1895  * snd_hda_build_controls - build mixer controls
 
1898  * Creates mixer controls for each codec included in the bus.
 
1900  * Returns 0 if successful, otherwise a negative error code.
 
1902 int __devinit snd_hda_build_controls(struct hda_bus *bus)
 
1904         struct hda_codec *codec;
 
1906         list_for_each_entry(codec, &bus->codec_list, list) {
 
1908                 /* fake as if already powered-on */
 
1909                 hda_keep_power_on(codec);
 
1911                 hda_set_power_state(codec,
 
1912                                     codec->afg ? codec->afg : codec->mfg,
 
1914                 /* continue to initialize... */
 
1915                 if (codec->patch_ops.init)
 
1916                         err = codec->patch_ops.init(codec);
 
1917                 if (!err && codec->patch_ops.build_controls)
 
1918                         err = codec->patch_ops.build_controls(codec);
 
1919                 snd_hda_power_down(codec);
 
1930 struct hda_rate_tbl {
 
1932         unsigned int alsa_bits;
 
1933         unsigned int hda_fmt;
 
1936 static struct hda_rate_tbl rate_bits[] = {
 
1937         /* rate in Hz, ALSA rate bitmask, HDA format value */
 
1939         /* autodetected value used in snd_hda_query_supported_pcm */
 
1940         { 8000, SNDRV_PCM_RATE_8000, 0x0500 }, /* 1/6 x 48 */
 
1941         { 11025, SNDRV_PCM_RATE_11025, 0x4300 }, /* 1/4 x 44 */
 
1942         { 16000, SNDRV_PCM_RATE_16000, 0x0200 }, /* 1/3 x 48 */
 
1943         { 22050, SNDRV_PCM_RATE_22050, 0x4100 }, /* 1/2 x 44 */
 
1944         { 32000, SNDRV_PCM_RATE_32000, 0x0a00 }, /* 2/3 x 48 */
 
1945         { 44100, SNDRV_PCM_RATE_44100, 0x4000 }, /* 44 */
 
1946         { 48000, SNDRV_PCM_RATE_48000, 0x0000 }, /* 48 */
 
1947         { 88200, SNDRV_PCM_RATE_88200, 0x4800 }, /* 2 x 44 */
 
1948         { 96000, SNDRV_PCM_RATE_96000, 0x0800 }, /* 2 x 48 */
 
1949         { 176400, SNDRV_PCM_RATE_176400, 0x5800 },/* 4 x 44 */
 
1950         { 192000, SNDRV_PCM_RATE_192000, 0x1800 }, /* 4 x 48 */
 
1951 #define AC_PAR_PCM_RATE_BITS    11
 
1952         /* up to bits 10, 384kHZ isn't supported properly */
 
1954         /* not autodetected value */
 
1955         { 9600, SNDRV_PCM_RATE_KNOT, 0x0400 }, /* 1/5 x 48 */
 
1957         { 0 } /* terminator */
 
1961  * snd_hda_calc_stream_format - calculate format bitset
 
1962  * @rate: the sample rate
 
1963  * @channels: the number of channels
 
1964  * @format: the PCM format (SNDRV_PCM_FORMAT_XXX)
 
1965  * @maxbps: the max. bps
 
1967  * Calculate the format bitset from the given rate, channels and th PCM format.
 
1969  * Return zero if invalid.
 
1971 unsigned int snd_hda_calc_stream_format(unsigned int rate,
 
1972                                         unsigned int channels,
 
1973                                         unsigned int format,
 
1974                                         unsigned int maxbps)
 
1977         unsigned int val = 0;
 
1979         for (i = 0; rate_bits[i].hz; i++)
 
1980                 if (rate_bits[i].hz == rate) {
 
1981                         val = rate_bits[i].hda_fmt;
 
1984         if (!rate_bits[i].hz) {
 
1985                 snd_printdd("invalid rate %d\n", rate);
 
1989         if (channels == 0 || channels > 8) {
 
1990                 snd_printdd("invalid channels %d\n", channels);
 
1993         val |= channels - 1;
 
1995         switch (snd_pcm_format_width(format)) {
 
1996         case 8:  val |= 0x00; break;
 
1997         case 16: val |= 0x10; break;
 
2003                 else if (maxbps >= 24)
 
2009                 snd_printdd("invalid format width %d\n",
 
2010                             snd_pcm_format_width(format));
 
2018  * snd_hda_query_supported_pcm - query the supported PCM rates and formats
 
2019  * @codec: the HDA codec
 
2020  * @nid: NID to query
 
2021  * @ratesp: the pointer to store the detected rate bitflags
 
2022  * @formatsp: the pointer to store the detected formats
 
2023  * @bpsp: the pointer to store the detected format widths
 
2025  * Queries the supported PCM rates and formats.  The NULL @ratesp, @formatsp
 
2026  * or @bsps argument is ignored.
 
2028  * Returns 0 if successful, otherwise a negative error code.
 
2030 int snd_hda_query_supported_pcm(struct hda_codec *codec, hda_nid_t nid,
 
2031                                 u32 *ratesp, u64 *formatsp, unsigned int *bpsp)
 
2034         unsigned int val, streams;
 
2037         if (nid != codec->afg &&
 
2038             (get_wcaps(codec, nid) & AC_WCAP_FORMAT_OVRD)) {
 
2039                 val = snd_hda_param_read(codec, nid, AC_PAR_PCM);
 
2044                 val = snd_hda_param_read(codec, codec->afg, AC_PAR_PCM);
 
2048                 for (i = 0; i < AC_PAR_PCM_RATE_BITS; i++) {
 
2050                                 rates |= rate_bits[i].alsa_bits;
 
2055         if (formatsp || bpsp) {
 
2060                 wcaps = get_wcaps(codec, nid);
 
2061                 streams = snd_hda_param_read(codec, nid, AC_PAR_STREAM);
 
2065                         streams = snd_hda_param_read(codec, codec->afg,
 
2072                 if (streams & AC_SUPFMT_PCM) {
 
2073                         if (val & AC_SUPPCM_BITS_8) {
 
2074                                 formats |= SNDRV_PCM_FMTBIT_U8;
 
2077                         if (val & AC_SUPPCM_BITS_16) {
 
2078                                 formats |= SNDRV_PCM_FMTBIT_S16_LE;
 
2081                         if (wcaps & AC_WCAP_DIGITAL) {
 
2082                                 if (val & AC_SUPPCM_BITS_32)
 
2083                                         formats |= SNDRV_PCM_FMTBIT_IEC958_SUBFRAME_LE;
 
2084                                 if (val & (AC_SUPPCM_BITS_20|AC_SUPPCM_BITS_24))
 
2085                                         formats |= SNDRV_PCM_FMTBIT_S32_LE;
 
2086                                 if (val & AC_SUPPCM_BITS_24)
 
2088                                 else if (val & AC_SUPPCM_BITS_20)
 
2090                         } else if (val & (AC_SUPPCM_BITS_20|AC_SUPPCM_BITS_24|
 
2091                                           AC_SUPPCM_BITS_32)) {
 
2092                                 formats |= SNDRV_PCM_FMTBIT_S32_LE;
 
2093                                 if (val & AC_SUPPCM_BITS_32)
 
2095                                 else if (val & AC_SUPPCM_BITS_24)
 
2097                                 else if (val & AC_SUPPCM_BITS_20)
 
2101                 else if (streams == AC_SUPFMT_FLOAT32) {
 
2102                         /* should be exclusive */
 
2103                         formats |= SNDRV_PCM_FMTBIT_FLOAT_LE;
 
2105                 } else if (streams == AC_SUPFMT_AC3) {
 
2106                         /* should be exclusive */
 
2107                         /* temporary hack: we have still no proper support
 
2108                          * for the direct AC3 stream...
 
2110                         formats |= SNDRV_PCM_FMTBIT_U8;
 
2114                         *formatsp = formats;
 
2123  * snd_hda_is_supported_format - check whether the given node supports
 
2126  * Returns 1 if supported, 0 if not.
 
2128 int snd_hda_is_supported_format(struct hda_codec *codec, hda_nid_t nid,
 
2129                                 unsigned int format)
 
2132         unsigned int val = 0, rate, stream;
 
2134         if (nid != codec->afg &&
 
2135             (get_wcaps(codec, nid) & AC_WCAP_FORMAT_OVRD)) {
 
2136                 val = snd_hda_param_read(codec, nid, AC_PAR_PCM);
 
2141                 val = snd_hda_param_read(codec, codec->afg, AC_PAR_PCM);
 
2146         rate = format & 0xff00;
 
2147         for (i = 0; i < AC_PAR_PCM_RATE_BITS; i++)
 
2148                 if (rate_bits[i].hda_fmt == rate) {
 
2153         if (i >= AC_PAR_PCM_RATE_BITS)
 
2156         stream = snd_hda_param_read(codec, nid, AC_PAR_STREAM);
 
2159         if (!stream && nid != codec->afg)
 
2160                 stream = snd_hda_param_read(codec, codec->afg, AC_PAR_STREAM);
 
2161         if (!stream || stream == -1)
 
2164         if (stream & AC_SUPFMT_PCM) {
 
2165                 switch (format & 0xf0) {
 
2167                         if (!(val & AC_SUPPCM_BITS_8))
 
2171                         if (!(val & AC_SUPPCM_BITS_16))
 
2175                         if (!(val & AC_SUPPCM_BITS_20))
 
2179                         if (!(val & AC_SUPPCM_BITS_24))
 
2183                         if (!(val & AC_SUPPCM_BITS_32))
 
2190                 /* FIXME: check for float32 and AC3? */
 
2199 static int hda_pcm_default_open_close(struct hda_pcm_stream *hinfo,
 
2200                                       struct hda_codec *codec,
 
2201                                       struct snd_pcm_substream *substream)
 
2206 static int hda_pcm_default_prepare(struct hda_pcm_stream *hinfo,
 
2207                                    struct hda_codec *codec,
 
2208                                    unsigned int stream_tag,
 
2209                                    unsigned int format,
 
2210                                    struct snd_pcm_substream *substream)
 
2212         snd_hda_codec_setup_stream(codec, hinfo->nid, stream_tag, 0, format);
 
2216 static int hda_pcm_default_cleanup(struct hda_pcm_stream *hinfo,
 
2217                                    struct hda_codec *codec,
 
2218                                    struct snd_pcm_substream *substream)
 
2220         snd_hda_codec_cleanup_stream(codec, hinfo->nid);
 
2224 static int __devinit set_pcm_default_values(struct hda_codec *codec,
 
2225                                             struct hda_pcm_stream *info)
 
2227         /* query support PCM information from the given NID */
 
2228         if (info->nid && (!info->rates || !info->formats)) {
 
2229                 snd_hda_query_supported_pcm(codec, info->nid,
 
2230                                 info->rates ? NULL : &info->rates,
 
2231                                 info->formats ? NULL : &info->formats,
 
2232                                 info->maxbps ? NULL : &info->maxbps);
 
2234         if (info->ops.open == NULL)
 
2235                 info->ops.open = hda_pcm_default_open_close;
 
2236         if (info->ops.close == NULL)
 
2237                 info->ops.close = hda_pcm_default_open_close;
 
2238         if (info->ops.prepare == NULL) {
 
2239                 snd_assert(info->nid, return -EINVAL);
 
2240                 info->ops.prepare = hda_pcm_default_prepare;
 
2242         if (info->ops.cleanup == NULL) {
 
2243                 snd_assert(info->nid, return -EINVAL);
 
2244                 info->ops.cleanup = hda_pcm_default_cleanup;
 
2250  * snd_hda_build_pcms - build PCM information
 
2253  * Create PCM information for each codec included in the bus.
 
2255  * The build_pcms codec patch is requested to set up codec->num_pcms and
 
2256  * codec->pcm_info properly.  The array is referred by the top-level driver
 
2257  * to create its PCM instances.
 
2258  * The allocated codec->pcm_info should be released in codec->patch_ops.free
 
2261  * At least, substreams, channels_min and channels_max must be filled for
 
2262  * each stream.  substreams = 0 indicates that the stream doesn't exist.
 
2263  * When rates and/or formats are zero, the supported values are queried
 
2264  * from the given nid.  The nid is used also by the default ops.prepare
 
2265  * and ops.cleanup callbacks.
 
2267  * The driver needs to call ops.open in its open callback.  Similarly,
 
2268  * ops.close is supposed to be called in the close callback.
 
2269  * ops.prepare should be called in the prepare or hw_params callback
 
2270  * with the proper parameters for set up.
 
2271  * ops.cleanup should be called in hw_free for clean up of streams.
 
2273  * This function returns 0 if successfull, or a negative error code.
 
2275 int __devinit snd_hda_build_pcms(struct hda_bus *bus)
 
2277         struct hda_codec *codec;
 
2279         list_for_each_entry(codec, &bus->codec_list, list) {
 
2280                 unsigned int pcm, s;
 
2282                 if (!codec->patch_ops.build_pcms)
 
2284                 err = codec->patch_ops.build_pcms(codec);
 
2287                 for (pcm = 0; pcm < codec->num_pcms; pcm++) {
 
2288                         for (s = 0; s < 2; s++) {
 
2289                                 struct hda_pcm_stream *info;
 
2290                                 info = &codec->pcm_info[pcm].stream[s];
 
2291                                 if (!info->substreams)
 
2293                                 err = set_pcm_default_values(codec, info);
 
2303  * snd_hda_check_board_config - compare the current codec with the config table
 
2304  * @codec: the HDA codec
 
2305  * @num_configs: number of config enums
 
2306  * @models: array of model name strings
 
2307  * @tbl: configuration table, terminated by null entries
 
2309  * Compares the modelname or PCI subsystem id of the current codec with the
 
2310  * given configuration table.  If a matching entry is found, returns its
 
2311  * config value (supposed to be 0 or positive).
 
2313  * If no entries are matching, the function returns a negative value.
 
2315 int snd_hda_check_board_config(struct hda_codec *codec,
 
2316                                int num_configs, const char **models,
 
2317                                const struct snd_pci_quirk *tbl)
 
2319         if (codec->bus->modelname && models) {
 
2321                 for (i = 0; i < num_configs; i++) {
 
2323                             !strcmp(codec->bus->modelname, models[i])) {
 
2324                                 snd_printd(KERN_INFO "hda_codec: model '%s' is "
 
2325                                            "selected\n", models[i]);
 
2331         if (!codec->bus->pci || !tbl)
 
2334         tbl = snd_pci_quirk_lookup(codec->bus->pci, tbl);
 
2337         if (tbl->value >= 0 && tbl->value < num_configs) {
 
2338 #ifdef CONFIG_SND_DEBUG_VERBOSE
 
2340                 const char *model = NULL;
 
2342                         model = models[tbl->value];
 
2344                         sprintf(tmp, "#%d", tbl->value);
 
2347                 snd_printdd(KERN_INFO "hda_codec: model '%s' is selected "
 
2348                             "for config %x:%x (%s)\n",
 
2349                             model, tbl->subvendor, tbl->subdevice,
 
2350                             (tbl->name ? tbl->name : "Unknown device"));
 
2358  * snd_hda_add_new_ctls - create controls from the array
 
2359  * @codec: the HDA codec
 
2360  * @knew: the array of struct snd_kcontrol_new
 
2362  * This helper function creates and add new controls in the given array.
 
2363  * The array must be terminated with an empty entry as terminator.
 
2365  * Returns 0 if successful, or a negative error code.
 
2367 int snd_hda_add_new_ctls(struct hda_codec *codec, struct snd_kcontrol_new *knew)
 
2371         for (; knew->name; knew++) {
 
2372                 struct snd_kcontrol *kctl;
 
2373                 kctl = snd_ctl_new1(knew, codec);
 
2376                 err = snd_ctl_add(codec->bus->card, kctl);
 
2380                         kctl = snd_ctl_new1(knew, codec);
 
2383                         kctl->id.device = codec->addr;
 
2384                         err = snd_ctl_add(codec->bus->card, kctl);
 
2392 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
2393 static void hda_set_power_state(struct hda_codec *codec, hda_nid_t fg,
 
2394                                 unsigned int power_state);
 
2396 static void hda_power_work(struct work_struct *work)
 
2398         struct hda_codec *codec =
 
2399                 container_of(work, struct hda_codec, power_work.work);
 
2401         if (!codec->power_on || codec->power_count) {
 
2402                 codec->power_transition = 0;
 
2406         hda_call_codec_suspend(codec);
 
2407         if (codec->bus->ops.pm_notify)
 
2408                 codec->bus->ops.pm_notify(codec);
 
2411 static void hda_keep_power_on(struct hda_codec *codec)
 
2413         codec->power_count++;
 
2414         codec->power_on = 1;
 
2417 void snd_hda_power_up(struct hda_codec *codec)
 
2419         codec->power_count++;
 
2420         if (codec->power_on || codec->power_transition)
 
2423         codec->power_on = 1;
 
2424         if (codec->bus->ops.pm_notify)
 
2425                 codec->bus->ops.pm_notify(codec);
 
2426         hda_call_codec_resume(codec);
 
2427         cancel_delayed_work(&codec->power_work);
 
2428         codec->power_transition = 0;
 
2431 void snd_hda_power_down(struct hda_codec *codec)
 
2433         --codec->power_count;
 
2434         if (!codec->power_on || codec->power_count || codec->power_transition)
 
2437                 codec->power_transition = 1; /* avoid reentrance */
 
2438                 schedule_delayed_work(&codec->power_work,
 
2439                                       msecs_to_jiffies(power_save * 1000));
 
2443 int snd_hda_check_amp_list_power(struct hda_codec *codec,
 
2444                                  struct hda_loopback_check *check,
 
2447         struct hda_amp_list *p;
 
2450         if (!check->amplist)
 
2452         for (p = check->amplist; p->nid; p++) {
 
2457                 return 0; /* nothing changed */
 
2459         for (p = check->amplist; p->nid; p++) {
 
2460                 for (ch = 0; ch < 2; ch++) {
 
2461                         v = snd_hda_codec_amp_read(codec, p->nid, ch, p->dir,
 
2463                         if (!(v & HDA_AMP_MUTE) && v > 0) {
 
2464                                 if (!check->power_on) {
 
2465                                         check->power_on = 1;
 
2466                                         snd_hda_power_up(codec);
 
2472         if (check->power_on) {
 
2473                 check->power_on = 0;
 
2474                 snd_hda_power_down(codec);
 
2481  * Channel mode helper
 
2483 int snd_hda_ch_mode_info(struct hda_codec *codec,
 
2484                          struct snd_ctl_elem_info *uinfo,
 
2485                          const struct hda_channel_mode *chmode,
 
2488         uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
 
2490         uinfo->value.enumerated.items = num_chmodes;
 
2491         if (uinfo->value.enumerated.item >= num_chmodes)
 
2492                 uinfo->value.enumerated.item = num_chmodes - 1;
 
2493         sprintf(uinfo->value.enumerated.name, "%dch",
 
2494                 chmode[uinfo->value.enumerated.item].channels);
 
2498 int snd_hda_ch_mode_get(struct hda_codec *codec,
 
2499                         struct snd_ctl_elem_value *ucontrol,
 
2500                         const struct hda_channel_mode *chmode,
 
2506         for (i = 0; i < num_chmodes; i++) {
 
2507                 if (max_channels == chmode[i].channels) {
 
2508                         ucontrol->value.enumerated.item[0] = i;
 
2515 int snd_hda_ch_mode_put(struct hda_codec *codec,
 
2516                         struct snd_ctl_elem_value *ucontrol,
 
2517                         const struct hda_channel_mode *chmode,
 
2523         mode = ucontrol->value.enumerated.item[0];
 
2524         if (mode >= num_chmodes)
 
2526         if (*max_channelsp == chmode[mode].channels)
 
2528         /* change the current channel setting */
 
2529         *max_channelsp = chmode[mode].channels;
 
2530         if (chmode[mode].sequence)
 
2531                 snd_hda_sequence_write_cache(codec, chmode[mode].sequence);
 
2538 int snd_hda_input_mux_info(const struct hda_input_mux *imux,
 
2539                            struct snd_ctl_elem_info *uinfo)
 
2543         uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
 
2545         uinfo->value.enumerated.items = imux->num_items;
 
2546         if (!imux->num_items)
 
2548         index = uinfo->value.enumerated.item;
 
2549         if (index >= imux->num_items)
 
2550                 index = imux->num_items - 1;
 
2551         strcpy(uinfo->value.enumerated.name, imux->items[index].label);
 
2555 int snd_hda_input_mux_put(struct hda_codec *codec,
 
2556                           const struct hda_input_mux *imux,
 
2557                           struct snd_ctl_elem_value *ucontrol,
 
2559                           unsigned int *cur_val)
 
2563         if (!imux->num_items)
 
2565         idx = ucontrol->value.enumerated.item[0];
 
2566         if (idx >= imux->num_items)
 
2567                 idx = imux->num_items - 1;
 
2568         if (*cur_val == idx)
 
2570         snd_hda_codec_write_cache(codec, nid, 0, AC_VERB_SET_CONNECT_SEL,
 
2571                                   imux->items[idx].index);
 
2578  * Multi-channel / digital-out PCM helper functions
 
2581 /* setup SPDIF output stream */
 
2582 static void setup_dig_out_stream(struct hda_codec *codec, hda_nid_t nid,
 
2583                                  unsigned int stream_tag, unsigned int format)
 
2585         /* turn off SPDIF once; otherwise the IEC958 bits won't be updated */
 
2586         if (codec->spdif_ctls & AC_DIG1_ENABLE)
 
2587                 snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_DIGI_CONVERT_1,
 
2588                                     codec->spdif_ctls & ~AC_DIG1_ENABLE & 0xff);
 
2589         snd_hda_codec_setup_stream(codec, nid, stream_tag, 0, format);
 
2590         /* turn on again (if needed) */
 
2591         if (codec->spdif_ctls & AC_DIG1_ENABLE)
 
2592                 snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_DIGI_CONVERT_1,
 
2593                                     codec->spdif_ctls & 0xff);
 
2597  * open the digital out in the exclusive mode
 
2599 int snd_hda_multi_out_dig_open(struct hda_codec *codec,
 
2600                                struct hda_multi_out *mout)
 
2602         mutex_lock(&codec->spdif_mutex);
 
2603         if (mout->dig_out_used == HDA_DIG_ANALOG_DUP)
 
2604                 /* already opened as analog dup; reset it once */
 
2605                 snd_hda_codec_cleanup_stream(codec, mout->dig_out_nid);
 
2606         mout->dig_out_used = HDA_DIG_EXCLUSIVE;
 
2607         mutex_unlock(&codec->spdif_mutex);
 
2611 int snd_hda_multi_out_dig_prepare(struct hda_codec *codec,
 
2612                                   struct hda_multi_out *mout,
 
2613                                   unsigned int stream_tag,
 
2614                                   unsigned int format,
 
2615                                   struct snd_pcm_substream *substream)
 
2617         mutex_lock(&codec->spdif_mutex);
 
2618         setup_dig_out_stream(codec, mout->dig_out_nid, stream_tag, format);
 
2619         mutex_unlock(&codec->spdif_mutex);
 
2624  * release the digital out
 
2626 int snd_hda_multi_out_dig_close(struct hda_codec *codec,
 
2627                                 struct hda_multi_out *mout)
 
2629         mutex_lock(&codec->spdif_mutex);
 
2630         mout->dig_out_used = 0;
 
2631         mutex_unlock(&codec->spdif_mutex);
 
2636  * set up more restrictions for analog out
 
2638 int snd_hda_multi_out_analog_open(struct hda_codec *codec,
 
2639                                   struct hda_multi_out *mout,
 
2640                                   struct snd_pcm_substream *substream,
 
2641                                   struct hda_pcm_stream *hinfo)
 
2643         struct snd_pcm_runtime *runtime = substream->runtime;
 
2644         runtime->hw.channels_max = mout->max_channels;
 
2645         if (mout->dig_out_nid) {
 
2646                 if (!mout->analog_rates) {
 
2647                         mout->analog_rates = hinfo->rates;
 
2648                         mout->analog_formats = hinfo->formats;
 
2649                         mout->analog_maxbps = hinfo->maxbps;
 
2651                         runtime->hw.rates = mout->analog_rates;
 
2652                         runtime->hw.formats = mout->analog_formats;
 
2653                         hinfo->maxbps = mout->analog_maxbps;
 
2655                 if (!mout->spdif_rates) {
 
2656                         snd_hda_query_supported_pcm(codec, mout->dig_out_nid,
 
2658                                                     &mout->spdif_formats,
 
2659                                                     &mout->spdif_maxbps);
 
2661                 mutex_lock(&codec->spdif_mutex);
 
2662                 if (mout->share_spdif) {
 
2663                         runtime->hw.rates &= mout->spdif_rates;
 
2664                         runtime->hw.formats &= mout->spdif_formats;
 
2665                         if (mout->spdif_maxbps < hinfo->maxbps)
 
2666                                 hinfo->maxbps = mout->spdif_maxbps;
 
2668                 mutex_unlock(&codec->spdif_mutex);
 
2670         return snd_pcm_hw_constraint_step(substream->runtime, 0,
 
2671                                           SNDRV_PCM_HW_PARAM_CHANNELS, 2);
 
2675  * set up the i/o for analog out
 
2676  * when the digital out is available, copy the front out to digital out, too.
 
2678 int snd_hda_multi_out_analog_prepare(struct hda_codec *codec,
 
2679                                      struct hda_multi_out *mout,
 
2680                                      unsigned int stream_tag,
 
2681                                      unsigned int format,
 
2682                                      struct snd_pcm_substream *substream)
 
2684         hda_nid_t *nids = mout->dac_nids;
 
2685         int chs = substream->runtime->channels;
 
2688         mutex_lock(&codec->spdif_mutex);
 
2689         if (mout->dig_out_nid && mout->share_spdif &&
 
2690             mout->dig_out_used != HDA_DIG_EXCLUSIVE) {
 
2692                     snd_hda_is_supported_format(codec, mout->dig_out_nid,
 
2694                     !(codec->spdif_status & IEC958_AES0_NONAUDIO)) {
 
2695                         mout->dig_out_used = HDA_DIG_ANALOG_DUP;
 
2696                         setup_dig_out_stream(codec, mout->dig_out_nid,
 
2697                                              stream_tag, format);
 
2699                         mout->dig_out_used = 0;
 
2700                         snd_hda_codec_cleanup_stream(codec, mout->dig_out_nid);
 
2703         mutex_unlock(&codec->spdif_mutex);
 
2706         snd_hda_codec_setup_stream(codec, nids[HDA_FRONT], stream_tag,
 
2708         if (!mout->no_share_stream &&
 
2709             mout->hp_nid && mout->hp_nid != nids[HDA_FRONT])
 
2710                 /* headphone out will just decode front left/right (stereo) */
 
2711                 snd_hda_codec_setup_stream(codec, mout->hp_nid, stream_tag,
 
2713         /* extra outputs copied from front */
 
2714         for (i = 0; i < ARRAY_SIZE(mout->extra_out_nid); i++)
 
2715                 if (!mout->no_share_stream && mout->extra_out_nid[i])
 
2716                         snd_hda_codec_setup_stream(codec,
 
2717                                                    mout->extra_out_nid[i],
 
2718                                                    stream_tag, 0, format);
 
2721         for (i = 1; i < mout->num_dacs; i++) {
 
2722                 if (chs >= (i + 1) * 2) /* independent out */
 
2723                         snd_hda_codec_setup_stream(codec, nids[i], stream_tag,
 
2725                 else if (!mout->no_share_stream) /* copy front */
 
2726                         snd_hda_codec_setup_stream(codec, nids[i], stream_tag,
 
2733  * clean up the setting for analog out
 
2735 int snd_hda_multi_out_analog_cleanup(struct hda_codec *codec,
 
2736                                      struct hda_multi_out *mout)
 
2738         hda_nid_t *nids = mout->dac_nids;
 
2741         for (i = 0; i < mout->num_dacs; i++)
 
2742                 snd_hda_codec_cleanup_stream(codec, nids[i]);
 
2744                 snd_hda_codec_cleanup_stream(codec, mout->hp_nid);
 
2745         for (i = 0; i < ARRAY_SIZE(mout->extra_out_nid); i++)
 
2746                 if (mout->extra_out_nid[i])
 
2747                         snd_hda_codec_cleanup_stream(codec,
 
2748                                                      mout->extra_out_nid[i]);
 
2749         mutex_lock(&codec->spdif_mutex);
 
2750         if (mout->dig_out_nid && mout->dig_out_used == HDA_DIG_ANALOG_DUP) {
 
2751                 snd_hda_codec_cleanup_stream(codec, mout->dig_out_nid);
 
2752                 mout->dig_out_used = 0;
 
2754         mutex_unlock(&codec->spdif_mutex);
 
2759  * Helper for automatic ping configuration
 
2762 static int is_in_nid_list(hda_nid_t nid, hda_nid_t *list)
 
2764         for (; *list; list++)
 
2772  * Sort an associated group of pins according to their sequence numbers.
 
2774 static void sort_pins_by_sequence(hda_nid_t * pins, short * sequences,
 
2781         for (i = 0; i < num_pins; i++) {
 
2782                 for (j = i + 1; j < num_pins; j++) {
 
2783                         if (sequences[i] > sequences[j]) {
 
2785                                 sequences[i] = sequences[j];
 
2797  * Parse all pin widgets and store the useful pin nids to cfg
 
2799  * The number of line-outs or any primary output is stored in line_outs,
 
2800  * and the corresponding output pins are assigned to line_out_pins[],
 
2801  * in the order of front, rear, CLFE, side, ...
 
2803  * If more extra outputs (speaker and headphone) are found, the pins are
 
2804  * assisnged to hp_pins[] and speaker_pins[], respectively.  If no line-out jack
 
2805  * is detected, one of speaker of HP pins is assigned as the primary
 
2806  * output, i.e. to line_out_pins[0].  So, line_outs is always positive
 
2807  * if any analog output exists.
 
2809  * The analog input pins are assigned to input_pins array.
 
2810  * The digital input/output pins are assigned to dig_in_pin and dig_out_pin,
 
2813 int snd_hda_parse_pin_def_config(struct hda_codec *codec,
 
2814                                  struct auto_pin_cfg *cfg,
 
2815                                  hda_nid_t *ignore_nids)
 
2817         hda_nid_t nid, end_nid;
 
2818         short seq, assoc_line_out, assoc_speaker;
 
2819         short sequences_line_out[ARRAY_SIZE(cfg->line_out_pins)];
 
2820         short sequences_speaker[ARRAY_SIZE(cfg->speaker_pins)];
 
2821         short sequences_hp[ARRAY_SIZE(cfg->hp_pins)];
 
2823         memset(cfg, 0, sizeof(*cfg));
 
2825         memset(sequences_line_out, 0, sizeof(sequences_line_out));
 
2826         memset(sequences_speaker, 0, sizeof(sequences_speaker));
 
2827         memset(sequences_hp, 0, sizeof(sequences_hp));
 
2828         assoc_line_out = assoc_speaker = 0;
 
2830         end_nid = codec->start_nid + codec->num_nodes;
 
2831         for (nid = codec->start_nid; nid < end_nid; nid++) {
 
2832                 unsigned int wid_caps = get_wcaps(codec, nid);
 
2833                 unsigned int wid_type =
 
2834                         (wid_caps & AC_WCAP_TYPE) >> AC_WCAP_TYPE_SHIFT;
 
2835                 unsigned int def_conf;
 
2838                 /* read all default configuration for pin complex */
 
2839                 if (wid_type != AC_WID_PIN)
 
2841                 /* ignore the given nids (e.g. pc-beep returns error) */
 
2842                 if (ignore_nids && is_in_nid_list(nid, ignore_nids))
 
2845                 def_conf = snd_hda_codec_read(codec, nid, 0,
 
2846                                               AC_VERB_GET_CONFIG_DEFAULT, 0);
 
2847                 if (get_defcfg_connect(def_conf) == AC_JACK_PORT_NONE)
 
2849                 loc = get_defcfg_location(def_conf);
 
2850                 switch (get_defcfg_device(def_conf)) {
 
2851                 case AC_JACK_LINE_OUT:
 
2852                         seq = get_defcfg_sequence(def_conf);
 
2853                         assoc = get_defcfg_association(def_conf);
 
2855                         if (!(wid_caps & AC_WCAP_STEREO))
 
2856                                 if (!cfg->mono_out_pin)
 
2857                                         cfg->mono_out_pin = nid;
 
2860                         if (!assoc_line_out)
 
2861                                 assoc_line_out = assoc;
 
2862                         else if (assoc_line_out != assoc)
 
2864                         if (cfg->line_outs >= ARRAY_SIZE(cfg->line_out_pins))
 
2866                         cfg->line_out_pins[cfg->line_outs] = nid;
 
2867                         sequences_line_out[cfg->line_outs] = seq;
 
2870                 case AC_JACK_SPEAKER:
 
2871                         seq = get_defcfg_sequence(def_conf);
 
2872                         assoc = get_defcfg_association(def_conf);
 
2875                         if (! assoc_speaker)
 
2876                                 assoc_speaker = assoc;
 
2877                         else if (assoc_speaker != assoc)
 
2879                         if (cfg->speaker_outs >= ARRAY_SIZE(cfg->speaker_pins))
 
2881                         cfg->speaker_pins[cfg->speaker_outs] = nid;
 
2882                         sequences_speaker[cfg->speaker_outs] = seq;
 
2883                         cfg->speaker_outs++;
 
2885                 case AC_JACK_HP_OUT:
 
2886                         seq = get_defcfg_sequence(def_conf);
 
2887                         assoc = get_defcfg_association(def_conf);
 
2888                         if (cfg->hp_outs >= ARRAY_SIZE(cfg->hp_pins))
 
2890                         cfg->hp_pins[cfg->hp_outs] = nid;
 
2891                         sequences_hp[cfg->hp_outs] = (assoc << 4) | seq;
 
2894                 case AC_JACK_MIC_IN: {
 
2896                         if (loc == AC_JACK_LOC_FRONT) {
 
2897                                 preferred = AUTO_PIN_FRONT_MIC;
 
2900                                 preferred = AUTO_PIN_MIC;
 
2901                                 alt = AUTO_PIN_FRONT_MIC;
 
2903                         if (!cfg->input_pins[preferred])
 
2904                                 cfg->input_pins[preferred] = nid;
 
2905                         else if (!cfg->input_pins[alt])
 
2906                                 cfg->input_pins[alt] = nid;
 
2909                 case AC_JACK_LINE_IN:
 
2910                         if (loc == AC_JACK_LOC_FRONT)
 
2911                                 cfg->input_pins[AUTO_PIN_FRONT_LINE] = nid;
 
2913                                 cfg->input_pins[AUTO_PIN_LINE] = nid;
 
2916                         cfg->input_pins[AUTO_PIN_CD] = nid;
 
2919                         cfg->input_pins[AUTO_PIN_AUX] = nid;
 
2921                 case AC_JACK_SPDIF_OUT:
 
2922                         cfg->dig_out_pin = nid;
 
2924                 case AC_JACK_SPDIF_IN:
 
2925                         cfg->dig_in_pin = nid;
 
2931          * If no line-out is defined but multiple HPs are found,
 
2932          * some of them might be the real line-outs.
 
2934         if (!cfg->line_outs && cfg->hp_outs > 1) {
 
2936                 while (i < cfg->hp_outs) {
 
2937                         /* The real HPs should have the sequence 0x0f */
 
2938                         if ((sequences_hp[i] & 0x0f) == 0x0f) {
 
2942                         /* Move it to the line-out table */
 
2943                         cfg->line_out_pins[cfg->line_outs] = cfg->hp_pins[i];
 
2944                         sequences_line_out[cfg->line_outs] = sequences_hp[i];
 
2947                         memmove(cfg->hp_pins + i, cfg->hp_pins + i + 1,
 
2948                                 sizeof(cfg->hp_pins[0]) * (cfg->hp_outs - i));
 
2949                         memmove(sequences_hp + i - 1, sequences_hp + i,
 
2950                                 sizeof(sequences_hp[0]) * (cfg->hp_outs - i));
 
2954         /* sort by sequence */
 
2955         sort_pins_by_sequence(cfg->line_out_pins, sequences_line_out,
 
2957         sort_pins_by_sequence(cfg->speaker_pins, sequences_speaker,
 
2959         sort_pins_by_sequence(cfg->hp_pins, sequences_hp,
 
2962         /* if we have only one mic, make it AUTO_PIN_MIC */
 
2963         if (!cfg->input_pins[AUTO_PIN_MIC] &&
 
2964             cfg->input_pins[AUTO_PIN_FRONT_MIC]) {
 
2965                 cfg->input_pins[AUTO_PIN_MIC] =
 
2966                         cfg->input_pins[AUTO_PIN_FRONT_MIC];
 
2967                 cfg->input_pins[AUTO_PIN_FRONT_MIC] = 0;
 
2969         /* ditto for line-in */
 
2970         if (!cfg->input_pins[AUTO_PIN_LINE] &&
 
2971             cfg->input_pins[AUTO_PIN_FRONT_LINE]) {
 
2972                 cfg->input_pins[AUTO_PIN_LINE] =
 
2973                         cfg->input_pins[AUTO_PIN_FRONT_LINE];
 
2974                 cfg->input_pins[AUTO_PIN_FRONT_LINE] = 0;
 
2978          * FIX-UP: if no line-outs are detected, try to use speaker or HP pin
 
2979          * as a primary output
 
2981         if (!cfg->line_outs) {
 
2982                 if (cfg->speaker_outs) {
 
2983                         cfg->line_outs = cfg->speaker_outs;
 
2984                         memcpy(cfg->line_out_pins, cfg->speaker_pins,
 
2985                                sizeof(cfg->speaker_pins));
 
2986                         cfg->speaker_outs = 0;
 
2987                         memset(cfg->speaker_pins, 0, sizeof(cfg->speaker_pins));
 
2988                         cfg->line_out_type = AUTO_PIN_SPEAKER_OUT;
 
2989                 } else if (cfg->hp_outs) {
 
2990                         cfg->line_outs = cfg->hp_outs;
 
2991                         memcpy(cfg->line_out_pins, cfg->hp_pins,
 
2992                                sizeof(cfg->hp_pins));
 
2994                         memset(cfg->hp_pins, 0, sizeof(cfg->hp_pins));
 
2995                         cfg->line_out_type = AUTO_PIN_HP_OUT;
 
2999         /* Reorder the surround channels
 
3000          * ALSA sequence is front/surr/clfe/side
 
3002          *    4-ch: front/surr  =>  OK as it is
 
3003          *    6-ch: front/clfe/surr
 
3004          *    8-ch: front/clfe/rear/side|fc
 
3006         switch (cfg->line_outs) {
 
3009                 nid = cfg->line_out_pins[1];
 
3010                 cfg->line_out_pins[1] = cfg->line_out_pins[2];
 
3011                 cfg->line_out_pins[2] = nid;
 
3016          * debug prints of the parsed results
 
3018         snd_printd("autoconfig: line_outs=%d (0x%x/0x%x/0x%x/0x%x/0x%x)\n",
 
3019                    cfg->line_outs, cfg->line_out_pins[0], cfg->line_out_pins[1],
 
3020                    cfg->line_out_pins[2], cfg->line_out_pins[3],
 
3021                    cfg->line_out_pins[4]);
 
3022         snd_printd("   speaker_outs=%d (0x%x/0x%x/0x%x/0x%x/0x%x)\n",
 
3023                    cfg->speaker_outs, cfg->speaker_pins[0],
 
3024                    cfg->speaker_pins[1], cfg->speaker_pins[2],
 
3025                    cfg->speaker_pins[3], cfg->speaker_pins[4]);
 
3026         snd_printd("   hp_outs=%d (0x%x/0x%x/0x%x/0x%x/0x%x)\n",
 
3027                    cfg->hp_outs, cfg->hp_pins[0],
 
3028                    cfg->hp_pins[1], cfg->hp_pins[2],
 
3029                    cfg->hp_pins[3], cfg->hp_pins[4]);
 
3030         snd_printd("   mono: mono_out=0x%x\n", cfg->mono_out_pin);
 
3031         snd_printd("   inputs: mic=0x%x, fmic=0x%x, line=0x%x, fline=0x%x,"
 
3032                    " cd=0x%x, aux=0x%x\n",
 
3033                    cfg->input_pins[AUTO_PIN_MIC],
 
3034                    cfg->input_pins[AUTO_PIN_FRONT_MIC],
 
3035                    cfg->input_pins[AUTO_PIN_LINE],
 
3036                    cfg->input_pins[AUTO_PIN_FRONT_LINE],
 
3037                    cfg->input_pins[AUTO_PIN_CD],
 
3038                    cfg->input_pins[AUTO_PIN_AUX]);
 
3043 /* labels for input pins */
 
3044 const char *auto_pin_cfg_labels[AUTO_PIN_LAST] = {
 
3045         "Mic", "Front Mic", "Line", "Front Line", "CD", "Aux"
 
3055  * snd_hda_suspend - suspend the codecs
 
3057  * @state: suspsend state
 
3059  * Returns 0 if successful.
 
3061 int snd_hda_suspend(struct hda_bus *bus, pm_message_t state)
 
3063         struct hda_codec *codec;
 
3065         list_for_each_entry(codec, &bus->codec_list, list) {
 
3066 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
3067                 if (!codec->power_on)
 
3070                 hda_call_codec_suspend(codec);
 
3076  * snd_hda_resume - resume the codecs
 
3078  * @state: resume state
 
3080  * Returns 0 if successful.
 
3082  * This fucntion is defined only when POWER_SAVE isn't set.
 
3083  * In the power-save mode, the codec is resumed dynamically.
 
3085 int snd_hda_resume(struct hda_bus *bus)
 
3087         struct hda_codec *codec;
 
3089         list_for_each_entry(codec, &bus->codec_list, list) {
 
3090                 if (snd_hda_codec_needs_resume(codec))
 
3091                         hda_call_codec_resume(codec);
 
3095 #ifdef CONFIG_SND_HDA_POWER_SAVE
 
3096 int snd_hda_codecs_inuse(struct hda_bus *bus)
 
3098         struct hda_codec *codec;
 
3100         list_for_each_entry(codec, &bus->codec_list, list) {
 
3101                 if (snd_hda_codec_needs_resume(codec))