aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2012-11-22 02:16:31 -0500
committerTakashi Iwai <tiwai@suse.de>2012-11-22 11:45:45 -0500
commit3fdf1469ee7af4367de8f563f69681920844ec95 (patch)
tree913fe305782c927d600a791b07a7a49fd36f00b3 /sound/pci
parente15f1b43e1dbb24c91f1434700e4ba876f8e6734 (diff)
ALSA: hda - Don't overwrite the pin default configs
Since we keep the pin default config values anyway internally, we don't have to set the values in the codec. This patch removes the code writing the pincfg values. As a gratis bonus, we can remove also the code restoring the original pincfg values at PM resume or module free. This will give us more benefit, as it can reduce the unnecessary power-up of codecs. This won't change the driver functionality. The only difference would be that the codec proc file will show the original pincfg values instead of the actually referred values. The actually referred values can be determined from sysfs *_pin_configs files. (Also hda-emu was updated to follow this change.) Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci')
-rw-r--r--sound/pci/hda/hda_codec.c45
1 files changed, 3 insertions, 42 deletions
diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
index d9fd439209df..c8f6c3bcb4f3 100644
--- a/sound/pci/hda/hda_codec.c
+++ b/sound/pci/hda/hda_codec.c
@@ -991,19 +991,6 @@ static struct hda_pincfg *look_up_pincfg(struct hda_codec *codec,
991 return NULL; 991 return NULL;
992} 992}
993 993
994/* write a config value for the given NID */
995static void set_pincfg(struct hda_codec *codec, hda_nid_t nid,
996 unsigned int cfg)
997{
998 int i;
999 for (i = 0; i < 4; i++) {
1000 snd_hda_codec_write(codec, nid, 0,
1001 AC_VERB_SET_CONFIG_DEFAULT_BYTES_0 + i,
1002 cfg & 0xff);
1003 cfg >>= 8;
1004 }
1005}
1006
1007/* set the current pin config value for the given NID. 994/* set the current pin config value for the given NID.
1008 * the value is cached, and read via snd_hda_codec_get_pincfg() 995 * the value is cached, and read via snd_hda_codec_get_pincfg()
1009 */ 996 */
@@ -1011,12 +998,10 @@ int snd_hda_add_pincfg(struct hda_codec *codec, struct snd_array *list,
1011 hda_nid_t nid, unsigned int cfg) 998 hda_nid_t nid, unsigned int cfg)
1012{ 999{
1013 struct hda_pincfg *pin; 1000 struct hda_pincfg *pin;
1014 unsigned int oldcfg;
1015 1001
1016 if (get_wcaps_type(get_wcaps(codec, nid)) != AC_WID_PIN) 1002 if (get_wcaps_type(get_wcaps(codec, nid)) != AC_WID_PIN)
1017 return -EINVAL; 1003 return -EINVAL;
1018 1004
1019 oldcfg = snd_hda_codec_get_pincfg(codec, nid);
1020 pin = look_up_pincfg(codec, list, nid); 1005 pin = look_up_pincfg(codec, list, nid);
1021 if (!pin) { 1006 if (!pin) {
1022 pin = snd_array_new(list); 1007 pin = snd_array_new(list);
@@ -1025,13 +1010,6 @@ int snd_hda_add_pincfg(struct hda_codec *codec, struct snd_array *list,
1025 pin->nid = nid; 1010 pin->nid = nid;
1026 } 1011 }
1027 pin->cfg = cfg; 1012 pin->cfg = cfg;
1028
1029 /* change only when needed; e.g. if the pincfg is already present
1030 * in user_pins[], don't write it
1031 */
1032 cfg = snd_hda_codec_get_pincfg(codec, nid);
1033 if (oldcfg != cfg)
1034 set_pincfg(codec, nid, cfg);
1035 return 0; 1013 return 0;
1036} 1014}
1037 1015
@@ -1080,17 +1058,6 @@ unsigned int snd_hda_codec_get_pincfg(struct hda_codec *codec, hda_nid_t nid)
1080} 1058}
1081EXPORT_SYMBOL_HDA(snd_hda_codec_get_pincfg); 1059EXPORT_SYMBOL_HDA(snd_hda_codec_get_pincfg);
1082 1060
1083/* restore all current pin configs */
1084static void restore_pincfgs(struct hda_codec *codec)
1085{
1086 int i;
1087 for (i = 0; i < codec->init_pins.used; i++) {
1088 struct hda_pincfg *pin = snd_array_elem(&codec->init_pins, i);
1089 set_pincfg(codec, pin->nid,
1090 snd_hda_codec_get_pincfg(codec, pin->nid));
1091 }
1092}
1093
1094/** 1061/**
1095 * snd_hda_shutup_pins - Shut up all pins 1062 * snd_hda_shutup_pins - Shut up all pins
1096 * @codec: the HDA codec 1063 * @codec: the HDA codec
@@ -1152,17 +1119,13 @@ static void init_hda_cache(struct hda_cache_rec *cache,
1152 unsigned int record_size); 1119 unsigned int record_size);
1153static void free_hda_cache(struct hda_cache_rec *cache); 1120static void free_hda_cache(struct hda_cache_rec *cache);
1154 1121
1155/* restore the initial pin cfgs and release all pincfg lists */ 1122/* release all pincfg lists */
1156static void restore_init_pincfgs(struct hda_codec *codec) 1123static void free_init_pincfgs(struct hda_codec *codec)
1157{ 1124{
1158 /* first free driver_pins and user_pins, then call restore_pincfg
1159 * so that only the values in init_pins are restored
1160 */
1161 snd_array_free(&codec->driver_pins); 1125 snd_array_free(&codec->driver_pins);
1162#ifdef CONFIG_SND_HDA_HWDEP 1126#ifdef CONFIG_SND_HDA_HWDEP
1163 snd_array_free(&codec->user_pins); 1127 snd_array_free(&codec->user_pins);
1164#endif 1128#endif
1165 restore_pincfgs(codec);
1166 snd_array_free(&codec->init_pins); 1129 snd_array_free(&codec->init_pins);
1167} 1130}
1168 1131
@@ -1205,7 +1168,7 @@ static void snd_hda_codec_free(struct hda_codec *codec)
1205 return; 1168 return;
1206 cancel_delayed_work_sync(&codec->jackpoll_work); 1169 cancel_delayed_work_sync(&codec->jackpoll_work);
1207 snd_hda_jack_tbl_clear(codec); 1170 snd_hda_jack_tbl_clear(codec);
1208 restore_init_pincfgs(codec); 1171 free_init_pincfgs(codec);
1209#ifdef CONFIG_PM 1172#ifdef CONFIG_PM
1210 cancel_delayed_work(&codec->power_work); 1173 cancel_delayed_work(&codec->power_work);
1211 flush_workqueue(codec->bus->workq); 1174 flush_workqueue(codec->bus->workq);
@@ -2394,7 +2357,6 @@ int snd_hda_codec_reset(struct hda_codec *codec)
2394 init_hda_cache(&codec->cmd_cache, sizeof(struct hda_cache_head)); 2357 init_hda_cache(&codec->cmd_cache, sizeof(struct hda_cache_head));
2395 /* free only driver_pins so that init_pins + user_pins are restored */ 2358 /* free only driver_pins so that init_pins + user_pins are restored */
2396 snd_array_free(&codec->driver_pins); 2359 snd_array_free(&codec->driver_pins);
2397 restore_pincfgs(codec);
2398 snd_array_free(&codec->cvt_setups); 2360 snd_array_free(&codec->cvt_setups);
2399 snd_array_free(&codec->spdif_out); 2361 snd_array_free(&codec->spdif_out);
2400 codec->num_pcms = 0; 2362 codec->num_pcms = 0;
@@ -3687,7 +3649,6 @@ static void hda_call_codec_resume(struct hda_codec *codec)
3687 */ 3649 */
3688 hda_keep_power_on(codec); 3650 hda_keep_power_on(codec);
3689 hda_set_power_state(codec, AC_PWRST_D0); 3651 hda_set_power_state(codec, AC_PWRST_D0);
3690 restore_pincfgs(codec); /* restore all current pin configs */
3691 restore_shutup_pins(codec); 3652 restore_shutup_pins(codec);
3692 hda_exec_init_verbs(codec); 3653 hda_exec_init_verbs(codec);
3693 if (codec->patch_ops.resume) 3654 if (codec->patch_ops.resume)