|
@@ -26,6 +26,7 @@
|
|
|
#include <linux/pm_runtime.h>
|
|
|
#include <linux/platform_device.h>
|
|
|
#include <linux/firmware.h>
|
|
|
+#include <linux/delay.h>
|
|
|
#include <sound/pcm.h>
|
|
|
#include "../common/sst-acpi.h"
|
|
|
#include <sound/hda_register.h>
|
|
@@ -109,6 +110,52 @@ static int skl_init_chip(struct hdac_bus *bus, bool full_reset)
|
|
|
return ret;
|
|
|
}
|
|
|
|
|
|
+void skl_update_d0i3c(struct device *dev, bool enable)
|
|
|
+{
|
|
|
+ struct pci_dev *pci = to_pci_dev(dev);
|
|
|
+ struct hdac_ext_bus *ebus = pci_get_drvdata(pci);
|
|
|
+ struct hdac_bus *bus = ebus_to_hbus(ebus);
|
|
|
+ u8 reg;
|
|
|
+ int timeout = 50;
|
|
|
+
|
|
|
+ reg = snd_hdac_chip_readb(bus, VS_D0I3C);
|
|
|
+ /* Do not write to D0I3C until command in progress bit is cleared */
|
|
|
+ while ((reg & AZX_REG_VS_D0I3C_CIP) && --timeout) {
|
|
|
+ udelay(10);
|
|
|
+ reg = snd_hdac_chip_readb(bus, VS_D0I3C);
|
|
|
+ }
|
|
|
+
|
|
|
+ /* Highly unlikely. But if it happens, flag error explicitly */
|
|
|
+ if (!timeout) {
|
|
|
+ dev_err(bus->dev, "Before D0I3C update: D0I3C CIP timeout\n");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (enable)
|
|
|
+ reg = reg | AZX_REG_VS_D0I3C_I3;
|
|
|
+ else
|
|
|
+ reg = reg & (~AZX_REG_VS_D0I3C_I3);
|
|
|
+
|
|
|
+ snd_hdac_chip_writeb(bus, VS_D0I3C, reg);
|
|
|
+
|
|
|
+ timeout = 50;
|
|
|
+ /* Wait for cmd in progress to be cleared before exiting the function */
|
|
|
+ reg = snd_hdac_chip_readb(bus, VS_D0I3C);
|
|
|
+ while ((reg & AZX_REG_VS_D0I3C_CIP) && --timeout) {
|
|
|
+ udelay(10);
|
|
|
+ reg = snd_hdac_chip_readb(bus, VS_D0I3C);
|
|
|
+ }
|
|
|
+
|
|
|
+ /* Highly unlikely. But if it happens, flag error explicitly */
|
|
|
+ if (!timeout) {
|
|
|
+ dev_err(bus->dev, "After D0I3C update: D0I3C CIP timeout\n");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ dev_dbg(bus->dev, "D0I3C register = 0x%x\n",
|
|
|
+ snd_hdac_chip_readb(bus, VS_D0I3C));
|
|
|
+}
|
|
|
+
|
|
|
/* called from IRQ */
|
|
|
static void skl_stream_update(struct hdac_bus *bus, struct hdac_stream *hstr)
|
|
|
{
|