Skip to content

Commit f107ffc

Browse files
committed
ASoC: SOF: amd: Skip IRAM/DRAM size modification
Merge series from Cristian Ciocaltea <cristian.ciocaltea@collabora.com>: This patch series restores audio support on Valve's Steam Deck OLED model, which broke after the recent introduction of ACP/PSP communication for IRAM/DRAM fence register programming.
2 parents 37bee18 + 094d117 commit f107ffc

File tree

4 files changed

+41
-27
lines changed

4 files changed

+41
-27
lines changed

sound/soc/sof/amd/acp-loader.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -173,7 +173,7 @@ int acp_dsp_pre_fw_run(struct snd_sof_dev *sdev)
173173

174174
adata = sdev->pdata->hw_pdata;
175175

176-
if (adata->signed_fw_image)
176+
if (adata->quirks && adata->quirks->signed_fw_image)
177177
size_fw = adata->fw_bin_size - ACP_FIRMWARE_SIGNATURE;
178178
else
179179
size_fw = adata->fw_bin_size;

sound/soc/sof/amd/acp.c

Lines changed: 27 additions & 23 deletions
Original file line numberDiff line numberDiff line change
@@ -20,20 +20,23 @@
2020
#include "acp.h"
2121
#include "acp-dsp-offset.h"
2222

23-
#define SECURED_FIRMWARE 1
24-
2523
static bool enable_fw_debug;
2624
module_param(enable_fw_debug, bool, 0444);
2725
MODULE_PARM_DESC(enable_fw_debug, "Enable Firmware debug");
2826

27+
static struct acp_quirk_entry quirk_valve_galileo = {
28+
.signed_fw_image = true,
29+
.skip_iram_dram_size_mod = true,
30+
};
31+
2932
const struct dmi_system_id acp_sof_quirk_table[] = {
3033
{
3134
/* Steam Deck OLED device */
3235
.matches = {
3336
DMI_MATCH(DMI_SYS_VENDOR, "Valve"),
3437
DMI_MATCH(DMI_PRODUCT_NAME, "Galileo"),
3538
},
36-
.driver_data = (void *)SECURED_FIRMWARE,
39+
.driver_data = &quirk_valve_galileo,
3740
},
3841
{}
3942
};
@@ -254,7 +257,7 @@ int configure_and_run_sha_dma(struct acp_dev_data *adata, void *image_addr,
254257
}
255258
}
256259

257-
if (adata->signed_fw_image)
260+
if (adata->quirks && adata->quirks->signed_fw_image)
258261
snd_sof_dsp_write(sdev, ACP_DSP_BAR, ACP_SHA_DMA_INCLUDE_HDR, ACP_SHA_HEADER);
259262

260263
snd_sof_dsp_write(sdev, ACP_DSP_BAR, ACP_SHA_DMA_STRT_ADDR, start_addr);
@@ -278,7 +281,7 @@ int configure_and_run_sha_dma(struct acp_dev_data *adata, void *image_addr,
278281
}
279282

280283
/* psp_send_cmd only required for vangogh platform (rev - 5) */
281-
if (desc->rev == 5) {
284+
if (desc->rev == 5 && !(adata->quirks && adata->quirks->skip_iram_dram_size_mod)) {
282285
/* Modify IRAM and DRAM size */
283286
ret = psp_send_cmd(adata, MBOX_ACP_IRAM_DRAM_FENCE_COMMAND | IRAM_DRAM_FENCE_2);
284287
if (ret)
@@ -738,26 +741,27 @@ int amd_sof_acp_probe(struct snd_sof_dev *sdev)
738741
sdev->debug_box.offset = sdev->host_box.offset + sdev->host_box.size;
739742
sdev->debug_box.size = BOX_SIZE_1024;
740743

741-
adata->signed_fw_image = false;
742744
dmi_id = dmi_first_match(acp_sof_quirk_table);
743-
if (dmi_id && dmi_id->driver_data) {
744-
adata->fw_code_bin = devm_kasprintf(sdev->dev, GFP_KERNEL,
745-
"sof-%s-code.bin",
746-
chip->name);
747-
if (!adata->fw_code_bin) {
748-
ret = -ENOMEM;
749-
goto free_ipc_irq;
745+
if (dmi_id) {
746+
adata->quirks = dmi_id->driver_data;
747+
748+
if (adata->quirks->signed_fw_image) {
749+
adata->fw_code_bin = devm_kasprintf(sdev->dev, GFP_KERNEL,
750+
"sof-%s-code.bin",
751+
chip->name);
752+
if (!adata->fw_code_bin) {
753+
ret = -ENOMEM;
754+
goto free_ipc_irq;
755+
}
756+
757+
adata->fw_data_bin = devm_kasprintf(sdev->dev, GFP_KERNEL,
758+
"sof-%s-data.bin",
759+
chip->name);
760+
if (!adata->fw_data_bin) {
761+
ret = -ENOMEM;
762+
goto free_ipc_irq;
763+
}
750764
}
751-
752-
adata->fw_data_bin = devm_kasprintf(sdev->dev, GFP_KERNEL,
753-
"sof-%s-data.bin",
754-
chip->name);
755-
if (!adata->fw_data_bin) {
756-
ret = -ENOMEM;
757-
goto free_ipc_irq;
758-
}
759-
760-
adata->signed_fw_image = dmi_id->driver_data;
761765
}
762766

763767
adata->enable_fw_debug = enable_fw_debug;

sound/soc/sof/amd/acp.h

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -207,6 +207,11 @@ struct sof_amd_acp_desc {
207207
u64 sdw_acpi_dev_addr;
208208
};
209209

210+
struct acp_quirk_entry {
211+
bool signed_fw_image;
212+
bool skip_iram_dram_size_mod;
213+
};
214+
210215
/* Common device data struct for ACP devices */
211216
struct acp_dev_data {
212217
struct snd_sof_dev *dev;
@@ -236,7 +241,7 @@ struct acp_dev_data {
236241
u8 *data_buf;
237242
dma_addr_t sram_dma_addr;
238243
u8 *sram_data_buf;
239-
bool signed_fw_image;
244+
struct acp_quirk_entry *quirks;
240245
struct dma_descriptor dscr_info[ACP_MAX_DESC];
241246
struct acp_dsp_stream stream_buf[ACP_MAX_STREAM];
242247
struct acp_dsp_stream *dtrace_stream;

sound/soc/sof/amd/vangogh.c

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -143,6 +143,7 @@ EXPORT_SYMBOL_NS(sof_vangogh_ops, SND_SOC_SOF_AMD_COMMON);
143143
int sof_vangogh_ops_init(struct snd_sof_dev *sdev)
144144
{
145145
const struct dmi_system_id *dmi_id;
146+
struct acp_quirk_entry *quirks;
146147

147148
/* common defaults */
148149
memcpy(&sof_vangogh_ops, &sof_acp_common_ops, sizeof(struct snd_sof_dsp_ops));
@@ -151,8 +152,12 @@ int sof_vangogh_ops_init(struct snd_sof_dev *sdev)
151152
sof_vangogh_ops.num_drv = ARRAY_SIZE(vangogh_sof_dai);
152153

153154
dmi_id = dmi_first_match(acp_sof_quirk_table);
154-
if (dmi_id && dmi_id->driver_data)
155-
sof_vangogh_ops.load_firmware = acp_sof_load_signed_firmware;
155+
if (dmi_id) {
156+
quirks = dmi_id->driver_data;
157+
158+
if (quirks->signed_fw_image)
159+
sof_vangogh_ops.load_firmware = acp_sof_load_signed_firmware;
160+
}
156161

157162
return 0;
158163
}

0 commit comments

Comments
 (0)