ASoC: Intel: add support for Cherrytrail and Braswell in SST driver
authorMengdong Lin <mengdong.lin@intel.com>
Fri, 21 Nov 2014 08:09:17 +0000 (16:09 +0800)
committerMark Brown <broonie@kernel.org>
Fri, 21 Nov 2014 19:23:01 +0000 (19:23 +0000)
This patch add ACPI device ID and platform data for two Cherryview-based
platforms, Cherrytrail and Braswell. Also reuse mfld driver ops in sst driver.

Signed-off-by: Mengdong Lin <mengdong.lin@intel.com>
Acked-by: Vinod Koul <vinod.koul@intel.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/intel/sst/sst.c
sound/soc/intel/sst/sst.h
sound/soc/intel/sst/sst_acpi.c

index 9e68a7cefd1bf8ea1686611ebd4af9cc94c28b5e..8a8d56a146e75a19d4587e169cb967b730b3eb36 100644 (file)
@@ -183,6 +183,7 @@ int sst_driver_ops(struct intel_sst_drv *sst)
        switch (sst->dev_id) {
        case SST_MRFLD_PCI_ID:
        case SST_BYT_ACPI_ID:
+       case SST_CHV_ACPI_ID:
                sst->tstamp = SST_TIME_STAMP_MRFLD;
                sst->ops = &mrfld_ops;
                return 0;
index 683dc717e4e8bd20f0b05eefb12422d24a210a1a..7f4bbfcbc6f552956977954b1cea39d12927fa81 100644 (file)
@@ -30,6 +30,7 @@
 #define SST_DRV_NAME "intel_sst_driver"
 #define SST_MRFLD_PCI_ID 0x119A
 #define SST_BYT_ACPI_ID        0x80860F28
+#define SST_CHV_ACPI_ID        0x808622A8
 
 #define SST_SUSPEND_DELAY 2000
 #define FW_CONTEXT_MEM (64*1024)
index f94f007a0e4943602e7a95f2d9c3c5b6cae89d09..3f29721625cca0b0bcb5dd32040466a07970445a 100644 (file)
@@ -129,6 +129,17 @@ static struct sst_platform_info byt_rvp_platform_data = {
        .platform = "sst-mfld-platform",
 };
 
+/* Cherryview (Cherrytrail and Braswell) uses same mrfld dpcm fw as Baytrail,
+ * so pdata is same as Baytrail.
+ */
+struct sst_platform_info chv_platform_data = {
+       .probe_data = &byt_fwparse_info,
+       .ipc_info = &byt_ipc_info,
+       .lib_info = &byt_lib_dnld_info,
+       .res_info = &byt_rvp_res_info,
+       .platform = "sst-mfld-platform",
+};
+
 static int sst_platform_get_resources(struct intel_sst_drv *ctx)
 {
        struct resource *rsrc;
@@ -337,8 +348,16 @@ static struct sst_machines sst_acpi_bytcr[] = {
        {},
 };
 
+/* Cherryview-based platforms: CherryTrail and Braswell */
+static struct sst_machines sst_acpi_chv[] = {
+       {"10EC5670", "cht-bsw", "cht-bsw-rt5672", NULL, "fw_sst_22a8.bin",
+                                               &chv_platform_data },
+       {},
+};
+
 static const struct acpi_device_id sst_acpi_ids[] = {
        { "80860F28", (unsigned long)&sst_acpi_bytcr},
+       { "808622A8", (unsigned long) &sst_acpi_chv},
        { },
 };