Commit c7072f5f authored by Takashi Iwai's avatar Takashi Iwai

Merge branch 'topic/hda-pm-refactor' into for-next

Pull refactoring / fixes of HD-audio PM and display power management
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parents a91f6760 46594d33
...@@ -236,6 +236,7 @@ struct hda_codec { ...@@ -236,6 +236,7 @@ struct hda_codec {
/* misc flags */ /* misc flags */
unsigned int in_freeing:1; /* being released */ unsigned int in_freeing:1; /* being released */
unsigned int registered:1; /* codec was registered */ unsigned int registered:1; /* codec was registered */
unsigned int display_power_control:1; /* needs display power */
unsigned int spdif_status_reset :1; /* needs to toggle SPDIF for each unsigned int spdif_status_reset :1; /* needs to toggle SPDIF for each
* status change * status change
* (e.g. Realtek codecs) * (e.g. Realtek codecs)
......
...@@ -5,10 +5,15 @@ ...@@ -5,10 +5,15 @@
#define __SOUND_HDA_COMPONENT_H #define __SOUND_HDA_COMPONENT_H
#include <drm/drm_audio_component.h> #include <drm/drm_audio_component.h>
#include <sound/hdaudio.h>
/* virtual idx for controller */
#define HDA_CODEC_IDX_CONTROLLER HDA_MAX_CODECS
#ifdef CONFIG_SND_HDA_COMPONENT #ifdef CONFIG_SND_HDA_COMPONENT
int snd_hdac_set_codec_wakeup(struct hdac_bus *bus, bool enable); int snd_hdac_set_codec_wakeup(struct hdac_bus *bus, bool enable);
int snd_hdac_display_power(struct hdac_bus *bus, bool enable); void snd_hdac_display_power(struct hdac_bus *bus, unsigned int idx,
bool enable);
int snd_hdac_sync_audio_rate(struct hdac_device *codec, hda_nid_t nid, int snd_hdac_sync_audio_rate(struct hdac_device *codec, hda_nid_t nid,
int dev_id, int rate); int dev_id, int rate);
int snd_hdac_acomp_get_eld(struct hdac_device *codec, hda_nid_t nid, int dev_id, int snd_hdac_acomp_get_eld(struct hdac_device *codec, hda_nid_t nid, int dev_id,
...@@ -25,9 +30,9 @@ static inline int snd_hdac_set_codec_wakeup(struct hdac_bus *bus, bool enable) ...@@ -25,9 +30,9 @@ static inline int snd_hdac_set_codec_wakeup(struct hdac_bus *bus, bool enable)
{ {
return 0; return 0;
} }
static inline int snd_hdac_display_power(struct hdac_bus *bus, bool enable) static inline void snd_hdac_display_power(struct hdac_bus *bus,
unsigned int idx, bool enable)
{ {
return 0;
} }
static inline int snd_hdac_sync_audio_rate(struct hdac_device *codec, static inline int snd_hdac_sync_audio_rate(struct hdac_device *codec,
hda_nid_t nid, int dev_id, int rate) hda_nid_t nid, int dev_id, int rate)
......
...@@ -79,7 +79,6 @@ struct hdac_device { ...@@ -79,7 +79,6 @@ struct hdac_device {
/* misc flags */ /* misc flags */
atomic_t in_pm; /* suspend/resume being performed */ atomic_t in_pm; /* suspend/resume being performed */
bool link_power_control:1;
/* sysfs */ /* sysfs */
struct hdac_widget_tree *widgets; struct hdac_widget_tree *widgets;
...@@ -237,8 +236,6 @@ struct hdac_bus_ops { ...@@ -237,8 +236,6 @@ struct hdac_bus_ops {
/* get a response from the last command */ /* get a response from the last command */
int (*get_response)(struct hdac_bus *bus, unsigned int addr, int (*get_response)(struct hdac_bus *bus, unsigned int addr,
unsigned int *res); unsigned int *res);
/* control the link power */
int (*link_power)(struct hdac_bus *bus, bool enable);
}; };
/* /*
...@@ -363,7 +360,8 @@ struct hdac_bus { ...@@ -363,7 +360,8 @@ struct hdac_bus {
/* DRM component interface */ /* DRM component interface */
struct drm_audio_component *audio_component; struct drm_audio_component *audio_component;
int drm_power_refcount; long display_power_status;
bool display_power_active;
/* parameters required for enhanced capabilities */ /* parameters required for enhanced capabilities */
int num_streams; int num_streams;
...@@ -404,7 +402,6 @@ int snd_hdac_bus_send_cmd(struct hdac_bus *bus, unsigned int val); ...@@ -404,7 +402,6 @@ int snd_hdac_bus_send_cmd(struct hdac_bus *bus, unsigned int val);
int snd_hdac_bus_get_response(struct hdac_bus *bus, unsigned int addr, int snd_hdac_bus_get_response(struct hdac_bus *bus, unsigned int addr,
unsigned int *res); unsigned int *res);
int snd_hdac_bus_parse_capabilities(struct hdac_bus *bus); int snd_hdac_bus_parse_capabilities(struct hdac_bus *bus);
int snd_hdac_link_power(struct hdac_device *codec, bool enable);
bool snd_hdac_bus_init_chip(struct hdac_bus *bus, bool full_reset); bool snd_hdac_bus_init_chip(struct hdac_bus *bus, bool full_reset);
void snd_hdac_bus_stop_chip(struct hdac_bus *bus); void snd_hdac_bus_stop_chip(struct hdac_bus *bus);
......
...@@ -54,41 +54,44 @@ EXPORT_SYMBOL_GPL(snd_hdac_set_codec_wakeup); ...@@ -54,41 +54,44 @@ EXPORT_SYMBOL_GPL(snd_hdac_set_codec_wakeup);
/** /**
* snd_hdac_display_power - Power up / down the power refcount * snd_hdac_display_power - Power up / down the power refcount
* @bus: HDA core bus * @bus: HDA core bus
* @idx: HDA codec address, pass HDA_CODEC_IDX_CONTROLLER for controller
* @enable: power up or down * @enable: power up or down
* *
* This function is supposed to be used only by a HD-audio controller * This function is used by either HD-audio controller or codec driver that
* driver that needs the interaction with graphics driver. * needs the interaction with graphics driver.
* *
* This function manages a refcount and calls the get_power() and * This function updates the power status, and calls the get_power() and
* put_power() ops accordingly, toggling the codec wakeup, too. * put_power() ops accordingly, toggling the codec wakeup, too.
*
* Returns zero for success or a negative error code.
*/ */
int snd_hdac_display_power(struct hdac_bus *bus, bool enable) void snd_hdac_display_power(struct hdac_bus *bus, unsigned int idx, bool enable)
{ {
struct drm_audio_component *acomp = bus->audio_component; struct drm_audio_component *acomp = bus->audio_component;
if (!acomp || !acomp->ops)
return -ENODEV;
dev_dbg(bus->dev, "display power %s\n", dev_dbg(bus->dev, "display power %s\n",
enable ? "enable" : "disable"); enable ? "enable" : "disable");
if (enable)
set_bit(idx, &bus->display_power_status);
else
clear_bit(idx, &bus->display_power_status);
if (enable) { if (!acomp || !acomp->ops)
if (!bus->drm_power_refcount++) { return;
if (bus->display_power_status) {
if (!bus->display_power_active) {
if (acomp->ops->get_power) if (acomp->ops->get_power)
acomp->ops->get_power(acomp->dev); acomp->ops->get_power(acomp->dev);
snd_hdac_set_codec_wakeup(bus, true); snd_hdac_set_codec_wakeup(bus, true);
snd_hdac_set_codec_wakeup(bus, false); snd_hdac_set_codec_wakeup(bus, false);
bus->display_power_active = true;
} }
} else { } else {
WARN_ON(!bus->drm_power_refcount); if (bus->display_power_active) {
if (!--bus->drm_power_refcount)
if (acomp->ops->put_power) if (acomp->ops->put_power)
acomp->ops->put_power(acomp->dev); acomp->ops->put_power(acomp->dev);
bus->display_power_active = false;
}
} }
return 0;
} }
EXPORT_SYMBOL_GPL(snd_hdac_display_power); EXPORT_SYMBOL_GPL(snd_hdac_display_power);
...@@ -321,10 +324,12 @@ int snd_hdac_acomp_exit(struct hdac_bus *bus) ...@@ -321,10 +324,12 @@ int snd_hdac_acomp_exit(struct hdac_bus *bus)
if (!acomp) if (!acomp)
return 0; return 0;
WARN_ON(bus->drm_power_refcount); if (WARN_ON(bus->display_power_active) && acomp->ops)
if (bus->drm_power_refcount > 0 && acomp->ops)
acomp->ops->put_power(acomp->dev); acomp->ops->put_power(acomp->dev);
bus->display_power_active = false;
bus->display_power_status = 0;
component_master_del(dev, &hdac_component_master_ops); component_master_del(dev, &hdac_component_master_ops);
bus->audio_component = NULL; bus->audio_component = NULL;
......
...@@ -622,23 +622,6 @@ int snd_hdac_power_down_pm(struct hdac_device *codec) ...@@ -622,23 +622,6 @@ int snd_hdac_power_down_pm(struct hdac_device *codec)
EXPORT_SYMBOL_GPL(snd_hdac_power_down_pm); EXPORT_SYMBOL_GPL(snd_hdac_power_down_pm);
#endif #endif
/**
* snd_hdac_link_power - Enable/disable the link power for a codec
* @codec: the codec object
* @bool: enable or disable the link power
*/
int snd_hdac_link_power(struct hdac_device *codec, bool enable)
{
if (!codec->link_power_control)
return 0;
if (codec->bus->ops->link_power)
return codec->bus->ops->link_power(codec->bus, enable);
else
return -EINVAL;
}
EXPORT_SYMBOL_GPL(snd_hdac_link_power);
/* codec vendor labels */ /* codec vendor labels */
struct hda_vendor_id { struct hda_vendor_id {
unsigned int id; unsigned int id;
......
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
#include "hda_beep.h" #include "hda_beep.h"
#include "hda_jack.h" #include "hda_jack.h"
#include <sound/hda_hwdep.h> #include <sound/hda_hwdep.h>
#include <sound/hda_component.h>
#define codec_in_pm(codec) snd_hdac_is_in_pm(&codec->core) #define codec_in_pm(codec) snd_hdac_is_in_pm(&codec->core)
#define hda_codec_is_power_on(codec) snd_hdac_is_power_on(&codec->core) #define hda_codec_is_power_on(codec) snd_hdac_is_power_on(&codec->core)
...@@ -799,6 +800,13 @@ void snd_hda_codec_cleanup_for_unbind(struct hda_codec *codec) ...@@ -799,6 +800,13 @@ void snd_hda_codec_cleanup_for_unbind(struct hda_codec *codec)
static unsigned int hda_set_power_state(struct hda_codec *codec, static unsigned int hda_set_power_state(struct hda_codec *codec,
unsigned int power_state); unsigned int power_state);
/* enable/disable display power per codec */
static void codec_display_power(struct hda_codec *codec, bool enable)
{
if (codec->display_power_control)
snd_hdac_display_power(&codec->bus->core, codec->addr, enable);
}
/* also called from hda_bind.c */ /* also called from hda_bind.c */
void snd_hda_codec_register(struct hda_codec *codec) void snd_hda_codec_register(struct hda_codec *codec)
{ {
...@@ -806,7 +814,7 @@ void snd_hda_codec_register(struct hda_codec *codec) ...@@ -806,7 +814,7 @@ void snd_hda_codec_register(struct hda_codec *codec)
return; return;
if (device_is_registered(hda_codec_dev(codec))) { if (device_is_registered(hda_codec_dev(codec))) {
snd_hda_register_beep_device(codec); snd_hda_register_beep_device(codec);
snd_hdac_link_power(&codec->core, true); codec_display_power(codec, true);
pm_runtime_enable(hda_codec_dev(codec)); pm_runtime_enable(hda_codec_dev(codec));
/* it was powered up in snd_hda_codec_new(), now all done */ /* it was powered up in snd_hda_codec_new(), now all done */
snd_hda_power_down(codec); snd_hda_power_down(codec);
...@@ -834,7 +842,7 @@ static int snd_hda_codec_dev_free(struct snd_device *device) ...@@ -834,7 +842,7 @@ static int snd_hda_codec_dev_free(struct snd_device *device)
codec->in_freeing = 1; codec->in_freeing = 1;
snd_hdac_device_unregister(&codec->core); snd_hdac_device_unregister(&codec->core);
snd_hdac_link_power(&codec->core, false); codec_display_power(codec, false);
put_device(hda_codec_dev(codec)); put_device(hda_codec_dev(codec));
return 0; return 0;
} }
...@@ -2926,7 +2934,7 @@ static int hda_codec_runtime_suspend(struct device *dev) ...@@ -2926,7 +2934,7 @@ static int hda_codec_runtime_suspend(struct device *dev)
(codec_has_clkstop(codec) && codec_has_epss(codec) && (codec_has_clkstop(codec) && codec_has_epss(codec) &&
(state & AC_PWRST_CLK_STOP_OK))) (state & AC_PWRST_CLK_STOP_OK)))
snd_hdac_codec_link_down(&codec->core); snd_hdac_codec_link_down(&codec->core);
snd_hdac_link_power(&codec->core, false); codec_display_power(codec, false);
return 0; return 0;
} }
...@@ -2934,7 +2942,7 @@ static int hda_codec_runtime_resume(struct device *dev) ...@@ -2934,7 +2942,7 @@ static int hda_codec_runtime_resume(struct device *dev)
{ {
struct hda_codec *codec = dev_to_hda_codec(dev); struct hda_codec *codec = dev_to_hda_codec(dev);
snd_hdac_link_power(&codec->core, true); codec_display_power(codec, true);
snd_hdac_codec_link_up(&codec->core); snd_hdac_codec_link_up(&codec->core);
hda_call_codec_resume(codec); hda_call_codec_resume(codec);
pm_runtime_mark_last_busy(dev); pm_runtime_mark_last_busy(dev);
......
...@@ -989,20 +989,9 @@ static int azx_get_response(struct hdac_bus *bus, unsigned int addr, ...@@ -989,20 +989,9 @@ static int azx_get_response(struct hdac_bus *bus, unsigned int addr,
return azx_rirb_get_response(bus, addr, res); return azx_rirb_get_response(bus, addr, res);
} }
static int azx_link_power(struct hdac_bus *bus, bool enable)
{
struct azx *chip = bus_to_azx(bus);
if (chip->ops->link_power)
return chip->ops->link_power(chip, enable);
else
return -EINVAL;
}
static const struct hdac_bus_ops bus_core_ops = { static const struct hdac_bus_ops bus_core_ops = {
.command = azx_send_cmd, .command = azx_send_cmd,
.get_response = azx_get_response, .get_response = azx_get_response,
.link_power = azx_link_power,
}; };
#ifdef CONFIG_SND_HDA_DSP_LOADER #ifdef CONFIG_SND_HDA_DSP_LOADER
......
...@@ -50,11 +50,7 @@ ...@@ -50,11 +50,7 @@
/* 24 unused */ /* 24 unused */
#define AZX_DCAPS_COUNT_LPIB_DELAY (1 << 25) /* Take LPIB as delay */ #define AZX_DCAPS_COUNT_LPIB_DELAY (1 << 25) /* Take LPIB as delay */
#define AZX_DCAPS_PM_RUNTIME (1 << 26) /* runtime PM support */ #define AZX_DCAPS_PM_RUNTIME (1 << 26) /* runtime PM support */
#ifdef CONFIG_SND_HDA_I915 /* 27 unused */
#define AZX_DCAPS_I915_POWERWELL (1 << 27) /* HSW i915 powerwell support */
#else
#define AZX_DCAPS_I915_POWERWELL 0 /* NOP */
#endif
#define AZX_DCAPS_CORBRP_SELF_CLEAR (1 << 28) /* CORBRP clears itself after reset */ #define AZX_DCAPS_CORBRP_SELF_CLEAR (1 << 28) /* CORBRP clears itself after reset */
#define AZX_DCAPS_NO_MSI64 (1 << 29) /* Stick to 32-bit MSIs */ #define AZX_DCAPS_NO_MSI64 (1 << 29) /* Stick to 32-bit MSIs */
#define AZX_DCAPS_SEPARATE_STREAM_TAG (1 << 30) /* capture and playback use separate stream tag */ #define AZX_DCAPS_SEPARATE_STREAM_TAG (1 << 30) /* capture and playback use separate stream tag */
......
This diff is collapsed.
...@@ -2616,11 +2616,7 @@ static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid) ...@@ -2616,11 +2616,7 @@ static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid)
intel_haswell_enable_all_pins(codec, true); intel_haswell_enable_all_pins(codec, true);
intel_haswell_fixup_enable_dp12(codec); intel_haswell_fixup_enable_dp12(codec);
/* For Haswell/Broadwell, the controller is also in the power well and codec->display_power_control = 1;
* can cover the codec power request, and so need not set this flag.
*/
if (!is_haswell(codec) && !is_broadwell(codec))
codec->core.link_power_control = 1;
codec->patch_ops.set_power_state = haswell_set_power_state; codec->patch_ops.set_power_state = haswell_set_power_state;
codec->depop_delay = 0; codec->depop_delay = 0;
...@@ -2656,7 +2652,7 @@ static int patch_i915_byt_hdmi(struct hda_codec *codec) ...@@ -2656,7 +2652,7 @@ static int patch_i915_byt_hdmi(struct hda_codec *codec)
/* For Valleyview/Cherryview, only the display codec is in the display /* For Valleyview/Cherryview, only the display codec is in the display
* power well and can use link_power ops to request/release the power. * power well and can use link_power ops to request/release the power.
*/ */
codec->core.link_power_control = 1; codec->display_power_control = 1;
codec->depop_delay = 0; codec->depop_delay = 0;
codec->auto_runtime_pm = 1; codec->auto_runtime_pm = 1;
......
...@@ -2031,13 +2031,7 @@ static int hdac_hdmi_dev_probe(struct hdac_device *hdev) ...@@ -2031,13 +2031,7 @@ static int hdac_hdmi_dev_probe(struct hdac_device *hdev)
* Turned off in the runtime_suspend during the first explicit * Turned off in the runtime_suspend during the first explicit
* pm_runtime_suspend call. * pm_runtime_suspend call.
*/ */
ret = snd_hdac_display_power(hdev->bus, true); snd_hdac_display_power(hdev->bus, hdev->addr, true);
if (ret < 0) {
dev_err(&hdev->dev,
"Cannot turn on display power on i915 err: %d\n",
ret);
return ret;
}
ret = hdac_hdmi_parse_and_map_nid(hdev, &hdmi_dais, &num_dais); ret = hdac_hdmi_parse_and_map_nid(hdev, &hdmi_dais, &num_dais);
if (ret < 0) { if (ret < 0) {
...@@ -2065,6 +2059,8 @@ static int hdac_hdmi_dev_remove(struct hdac_device *hdev) ...@@ -2065,6 +2059,8 @@ static int hdac_hdmi_dev_remove(struct hdac_device *hdev)
struct hdac_hdmi_port *port, *port_next; struct hdac_hdmi_port *port, *port_next;
int i; int i;
snd_hdac_display_power(hdev->bus, hdev->addr, false);
list_for_each_entry_safe(pcm, pcm_next, &hdmi->pcm_list, head) { list_for_each_entry_safe(pcm, pcm_next, &hdmi->pcm_list, head) {
pcm->cvt = NULL; pcm->cvt = NULL;
if (list_empty(&pcm->port_list)) if (list_empty(&pcm->port_list))
...@@ -2170,7 +2166,6 @@ static int hdac_hdmi_runtime_suspend(struct device *dev) ...@@ -2170,7 +2166,6 @@ static int hdac_hdmi_runtime_suspend(struct device *dev)
struct hdac_device *hdev = dev_to_hdac_dev(dev); struct hdac_device *hdev = dev_to_hdac_dev(dev);
struct hdac_bus *bus = hdev->bus; struct hdac_bus *bus = hdev->bus;
struct hdac_ext_link *hlink = NULL; struct hdac_ext_link *hlink = NULL;
int err;
dev_dbg(dev, "Enter: %s\n", __func__); dev_dbg(dev, "Enter: %s\n", __func__);
...@@ -2196,11 +2191,9 @@ static int hdac_hdmi_runtime_suspend(struct device *dev) ...@@ -2196,11 +2191,9 @@ static int hdac_hdmi_runtime_suspend(struct device *dev)
snd_hdac_ext_bus_link_put(bus, hlink); snd_hdac_ext_bus_link_put(bus, hlink);
err = snd_hdac_display_power(bus, false); snd_hdac_display_power(bus, hdev->addr, false);
if (err < 0)
dev_err(dev, "Cannot turn off display power on i915\n");
return err; return 0;
} }
static int hdac_hdmi_runtime_resume(struct device *dev) static int hdac_hdmi_runtime_resume(struct device *dev)
...@@ -2208,7 +2201,6 @@ static int hdac_hdmi_runtime_resume(struct device *dev) ...@@ -2208,7 +2201,6 @@ static int hdac_hdmi_runtime_resume(struct device *dev)
struct hdac_device *hdev = dev_to_hdac_dev(dev); struct hdac_device *hdev = dev_to_hdac_dev(dev);
struct hdac_bus *bus = hdev->bus; struct hdac_bus *bus = hdev->bus;
struct hdac_ext_link *hlink = NULL; struct hdac_ext_link *hlink = NULL;
int err;
dev_dbg(dev, "Enter: %s\n", __func__); dev_dbg(dev, "Enter: %s\n", __func__);
...@@ -2224,11 +2216,7 @@ static int hdac_hdmi_runtime_resume(struct device *dev) ...@@ -2224,11 +2216,7 @@ static int hdac_hdmi_runtime_resume(struct device *dev)
snd_hdac_ext_bus_link_get(bus, hlink); snd_hdac_ext_bus_link_get(bus, hlink);
err = snd_hdac_display_power(bus, true); snd_hdac_display_power(bus, hdev->addr, true);
if (err < 0) {
dev_err(dev, "Cannot turn on display power on i915\n");
return err;
}
hdac_hdmi_skl_enable_all_pins(hdev); hdac_hdmi_skl_enable_all_pins(hdev);
hdac_hdmi_skl_enable_dp12(hdev); hdac_hdmi_skl_enable_dp12(hdev);
......
...@@ -311,7 +311,7 @@ static int skl_suspend(struct device *dev) ...@@ -311,7 +311,7 @@ static int skl_suspend(struct device *dev)
struct pci_dev *pci = to_pci_dev(dev); struct pci_dev *pci = to_pci_dev(dev);
struct hdac_bus *bus = pci_get_drvdata(pci); struct hdac_bus *bus = pci_get_drvdata(pci);
struct skl *skl = bus_to_skl(bus); struct skl *skl = bus_to_skl(bus);
int ret = 0; int ret;
/* /*
* Do not suspend if streams which are marked ignore suspend are * Do not suspend if streams which are marked ignore suspend are
...@@ -333,14 +333,10 @@ static int skl_suspend(struct device *dev) ...@@ -333,14 +333,10 @@ static int skl_suspend(struct device *dev)
skl->skl_sst->fw_loaded = false; skl->skl_sst->fw_loaded = false;
} }
if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI)) { if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI))
ret = snd_hdac_display_power(bus, false); snd_hdac_display_power(bus, HDA_CODEC_IDX_CONTROLLER, false);
if (ret < 0)
dev_err(bus->dev,
"Cannot turn OFF display power on i915\n");
}
return ret; return 0;
} }
static int skl_resume(struct device *dev) static int skl_resume(struct device *dev)
...@@ -352,14 +348,8 @@ static int skl_resume(struct device *dev) ...@@ -352,14 +348,8 @@ static int skl_resume(struct device *dev)
int ret; int ret;
/* Turned OFF in HDMI codec driver after codec reconfiguration */ /* Turned OFF in HDMI codec driver after codec reconfiguration */
if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI)) { if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI))
ret = snd_hdac_display_power(bus, true); snd_hdac_display_power(bus, HDA_CODEC_IDX_CONTROLLER, true);
if (ret < 0) {
dev_err(bus->dev,
"Cannot turn on display power on i915\n");
return ret;
}
}
/* /*
* resume only when we are not in suspend active, otherwise need to * resume only when we are not in suspend active, otherwise need to
...@@ -783,11 +773,9 @@ static int skl_i915_init(struct hdac_bus *bus) ...@@ -783,11 +773,9 @@ static int skl_i915_init(struct hdac_bus *bus)
if (err < 0) if (err < 0)
return err; return err;
err = snd_hdac_display_power(bus, true); snd_hdac_display_power(bus, HDA_CODEC_IDX_CONTROLLER, true);
if (err < 0)
dev_err(bus->dev, "Cannot turn on display power on i915\n");
return err; return 0;
} }
static void skl_probe_work(struct work_struct *work) static void skl_probe_work(struct work_struct *work)
...@@ -837,14 +825,8 @@ static void skl_probe_work(struct work_struct *work) ...@@ -837,14 +825,8 @@ static void skl_probe_work(struct work_struct *work)
list_for_each_entry(hlink, &bus->hlink_list, list) list_for_each_entry(hlink, &bus->hlink_list, list)
snd_hdac_ext_bus_link_put(bus, hlink); snd_hdac_ext_bus_link_put(bus, hlink);
if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI)) { if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI))
err = snd_hdac_display_power(bus, false); snd_hdac_display_power(bus, HDA_CODEC_IDX_CONTROLLER, false);
if (err < 0) {
dev_err(bus->dev, "Cannot turn off display power on i915\n");
skl_machine_device_unregister(skl);
return;
}
}
/* configure PM */ /* configure PM */
pm_runtime_put_noidle(bus->dev); pm_runtime_put_noidle(bus->dev);
...@@ -855,7 +837,7 @@ static void skl_probe_work(struct work_struct *work) ...@@ -855,7 +837,7 @@ static void skl_probe_work(struct work_struct *work)
out_err: out_err:
if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI)) if (IS_ENABLED(CONFIG_SND_SOC_HDAC_HDMI))
err = snd_hdac_display_power(bus, false); snd_hdac_display_power(bus, HDA_CODEC_IDX_CONTROLLER, false);
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment