broadwell: Disable ADSP power gating feature by default

Disable ADSP D3 and SRAM power gating features by default, and make
the devicetree.cb flags into enable flags instead of disable.

BUG=chrome-os-partner:31588
BRANCH=samus,auron
TEST=build and boot on samus

Change-Id: Ibda298b995b07a2826a406e74e0d244b1fd97746
Signed-off-by: Stefan Reinauer <reinauer@chromium.org>
Original-Commit-Id: b81ef37c036d61dc56e650796227dcc84a7ccc89
Original-Change-Id: Ib881290acc07819b55d776d4696bf0062df4d50e
Original-Signed-off-by: Duncan Laurie <dlaurie@chromium.org>
Original-Reviewed-on: https://chromium-review.googlesource.com/220863
Original-Reviewed-by: Aaron Durbin <adurbin@chromium.org>
Reviewed-on: http://review.coreboot.org/9218
Tested-by: build bot (Jenkins)
Reviewed-by: Patrick Georgi <pgeorgi@google.com>
diff --git a/src/soc/intel/broadwell/adsp.c b/src/soc/intel/broadwell/adsp.c
index 9ecbe95..bf77763 100644
--- a/src/soc/intel/broadwell/adsp.c
+++ b/src/soc/intel/broadwell/adsp.c
@@ -69,21 +69,25 @@
 
 	/* Set D3 Power Gating Enable in D19:F0:A0 based on PCH type */
 	tmp32 = pci_read_config32(dev, ADSP_PCI_VDRTCTL0);
-	if (config->adsp_d3_pg_disable) {
-		if (pch_is_wpt()) {
-			tmp32 |= ADSP_VDRTCTL0_D3PGD_WPT;
-			tmp32 |= ADSP_VDRTCTL0_D3SRAMPGD_WPT;
+	if (pch_is_wpt()) {
+		if (config->adsp_d3_pg_enable) {
+			tmp32 &= ~ADSP_VDRTCTL0_D3PGD_WPT;
+			if (config->adsp_sram_pg_enable)
+				tmp32 &= ~ADSP_VDRTCTL0_D3SRAMPGD_WPT;
+			else
+				tmp32 |= ADSP_VDRTCTL0_D3SRAMPGD_WPT;
 		} else {
-			tmp32 |= ADSP_VDRTCTL0_D3PGD_LPT;
-			tmp32 |= ADSP_VDRTCTL0_D3SRAMPGD_LPT;
+			tmp32 |= ADSP_VDRTCTL0_D3PGD_WPT;
 		}
 	} else {
-		if (pch_is_wpt()) {
-			tmp32 &= ~ADSP_VDRTCTL0_D3PGD_WPT;
-			tmp32 &= ~ADSP_VDRTCTL0_D3SRAMPGD_WPT;
-		} else {
+		if (config->adsp_d3_pg_enable) {
 			tmp32 &= ~ADSP_VDRTCTL0_D3PGD_LPT;
-			tmp32 &= ~ADSP_VDRTCTL0_D3SRAMPGD_LPT;
+			if (config->adsp_sram_pg_enable)
+				tmp32 &= ~ADSP_VDRTCTL0_D3SRAMPGD_LPT;
+			else
+				tmp32 |= ADSP_VDRTCTL0_D3SRAMPGD_LPT;
+		} else {
+			tmp32 |= ADSP_VDRTCTL0_D3PGD_LPT;
 		}
 	}
 	pci_write_config32(dev, ADSP_PCI_VDRTCTL0, tmp32);