mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 10:45:49 +00:00
ASoC: Merge up fixes
Some refactoring opportunities for the rcard driver were noticed while fixing a bug.
This commit is contained in:
commit
cab6557724
@ -102,21 +102,21 @@ properties:
|
||||
default: 2
|
||||
|
||||
interrupts:
|
||||
oneOf:
|
||||
- minItems: 1
|
||||
items:
|
||||
- description: TX interrupt
|
||||
- description: RX interrupt
|
||||
- items:
|
||||
- description: common/combined interrupt
|
||||
minItems: 1
|
||||
maxItems: 2
|
||||
|
||||
interrupt-names:
|
||||
oneOf:
|
||||
- minItems: 1
|
||||
- description: TX interrupt
|
||||
const: tx
|
||||
- description: RX interrupt
|
||||
const: rx
|
||||
- description: TX and RX interrupts
|
||||
items:
|
||||
- const: tx
|
||||
- const: rx
|
||||
- const: common
|
||||
- description: Common/combined interrupt
|
||||
const: common
|
||||
|
||||
fck_parent:
|
||||
$ref: /schemas/types.yaml#/definitions/string
|
||||
|
@ -15089,6 +15089,7 @@ F: drivers/spi/spi-at91-usart.c
|
||||
|
||||
MICROCHIP AUDIO ASOC DRIVERS
|
||||
M: Claudiu Beznea <claudiu.beznea@tuxon.dev>
|
||||
M: Andrei Simion <andrei.simion@microchip.com>
|
||||
L: linux-sound@vger.kernel.org
|
||||
S: Supported
|
||||
F: Documentation/devicetree/bindings/sound/atmel*
|
||||
@ -15197,6 +15198,7 @@ F: include/video/atmel_lcdc.h
|
||||
|
||||
MICROCHIP MCP16502 PMIC DRIVER
|
||||
M: Claudiu Beznea <claudiu.beznea@tuxon.dev>
|
||||
M: Andrei Simion <andrei.simion@microchip.com>
|
||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||
S: Supported
|
||||
F: Documentation/devicetree/bindings/regulator/microchip,mcp16502.yaml
|
||||
@ -15328,6 +15330,7 @@ F: drivers/spi/spi-atmel.*
|
||||
|
||||
MICROCHIP SSC DRIVER
|
||||
M: Claudiu Beznea <claudiu.beznea@tuxon.dev>
|
||||
M: Andrei Simion <andrei.simion@microchip.com>
|
||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||
S: Supported
|
||||
F: Documentation/devicetree/bindings/misc/atmel-ssc.txt
|
||||
|
@ -88,7 +88,7 @@
|
||||
|
||||
/* ABI version */
|
||||
#define SND_SOC_TPLG_ABI_VERSION 0x5 /* current version */
|
||||
#define SND_SOC_TPLG_ABI_VERSION_MIN 0x4 /* oldest version supported */
|
||||
#define SND_SOC_TPLG_ABI_VERSION_MIN 0x5 /* oldest version supported */
|
||||
|
||||
/* Max size of TLV data */
|
||||
#define SND_SOC_TPLG_TLV_SIZE 32
|
||||
|
@ -339,6 +339,13 @@ static const struct dmi_system_id yc_acp_quirk_table[] = {
|
||||
DMI_MATCH(DMI_PRODUCT_NAME, "M7600RE"),
|
||||
}
|
||||
},
|
||||
{
|
||||
.driver_data = &acp6x_card,
|
||||
.matches = {
|
||||
DMI_MATCH(DMI_BOARD_VENDOR, "ASUSTeK COMPUTER INC."),
|
||||
DMI_MATCH(DMI_PRODUCT_NAME, "M3502RA"),
|
||||
}
|
||||
},
|
||||
{
|
||||
.driver_data = &acp6x_card,
|
||||
.matches = {
|
||||
|
@ -763,6 +763,7 @@ static int max98388_dai_tdm_slot(struct snd_soc_dai *dai,
|
||||
addr = MAX98388_R2044_PCM_TX_CTRL1 + (cnt / 8);
|
||||
bits = cnt % 8;
|
||||
regmap_update_bits(max98388->regmap, addr, bits, bits);
|
||||
slot_found++;
|
||||
if (slot_found >= MAX_NUM_CH)
|
||||
break;
|
||||
}
|
||||
|
@ -119,10 +119,10 @@ static irqreturn_t esai_isr(int irq, void *devid)
|
||||
dev_dbg(&pdev->dev, "isr: Transmission Initialized\n");
|
||||
|
||||
if (esr & ESAI_ESR_RFF_MASK)
|
||||
dev_warn(&pdev->dev, "isr: Receiving overrun\n");
|
||||
dev_dbg(&pdev->dev, "isr: Receiving overrun\n");
|
||||
|
||||
if (esr & ESAI_ESR_TFE_MASK)
|
||||
dev_warn(&pdev->dev, "isr: Transmission underrun\n");
|
||||
dev_dbg(&pdev->dev, "isr: Transmission underrun\n");
|
||||
|
||||
if (esr & ESAI_ESR_TLS_MASK)
|
||||
dev_dbg(&pdev->dev, "isr: Just transmitted the last slot\n");
|
||||
|
@ -28,6 +28,7 @@
|
||||
#include "avs.h"
|
||||
#include "cldma.h"
|
||||
#include "messages.h"
|
||||
#include "pcm.h"
|
||||
|
||||
static u32 pgctl_mask = AZX_PGCTL_LSRMD_MASK;
|
||||
module_param(pgctl_mask, uint, 0444);
|
||||
@ -247,7 +248,7 @@ static void hdac_stream_update_pos(struct hdac_stream *stream, u64 buffer_size)
|
||||
static void hdac_update_stream(struct hdac_bus *bus, struct hdac_stream *stream)
|
||||
{
|
||||
if (stream->substream) {
|
||||
snd_pcm_period_elapsed(stream->substream);
|
||||
avs_period_elapsed(stream->substream);
|
||||
} else if (stream->cstream) {
|
||||
u64 buffer_size = stream->cstream->runtime->buffer_size;
|
||||
|
||||
|
@ -16,6 +16,7 @@
|
||||
#include <sound/soc-component.h>
|
||||
#include "avs.h"
|
||||
#include "path.h"
|
||||
#include "pcm.h"
|
||||
#include "topology.h"
|
||||
#include "../../codecs/hda.h"
|
||||
|
||||
@ -30,6 +31,7 @@ struct avs_dma_data {
|
||||
struct hdac_ext_stream *host_stream;
|
||||
};
|
||||
|
||||
struct work_struct period_elapsed_work;
|
||||
struct snd_pcm_substream *substream;
|
||||
};
|
||||
|
||||
@ -56,6 +58,22 @@ avs_dai_find_path_template(struct snd_soc_dai *dai, bool is_fe, int direction)
|
||||
return dw->priv;
|
||||
}
|
||||
|
||||
static void avs_period_elapsed_work(struct work_struct *work)
|
||||
{
|
||||
struct avs_dma_data *data = container_of(work, struct avs_dma_data, period_elapsed_work);
|
||||
|
||||
snd_pcm_period_elapsed(data->substream);
|
||||
}
|
||||
|
||||
void avs_period_elapsed(struct snd_pcm_substream *substream)
|
||||
{
|
||||
struct snd_soc_pcm_runtime *rtd = snd_soc_substream_to_rtd(substream);
|
||||
struct snd_soc_dai *dai = snd_soc_rtd_to_cpu(rtd, 0);
|
||||
struct avs_dma_data *data = snd_soc_dai_get_dma_data(dai, substream);
|
||||
|
||||
schedule_work(&data->period_elapsed_work);
|
||||
}
|
||||
|
||||
static int avs_dai_startup(struct snd_pcm_substream *substream, struct snd_soc_dai *dai)
|
||||
{
|
||||
struct snd_soc_pcm_runtime *rtd = snd_soc_substream_to_rtd(substream);
|
||||
@ -77,6 +95,7 @@ static int avs_dai_startup(struct snd_pcm_substream *substream, struct snd_soc_d
|
||||
data->substream = substream;
|
||||
data->template = template;
|
||||
data->adev = adev;
|
||||
INIT_WORK(&data->period_elapsed_work, avs_period_elapsed_work);
|
||||
snd_soc_dai_set_dma_data(dai, substream, data);
|
||||
|
||||
if (rtd->dai_link->ignore_suspend)
|
||||
|
16
sound/soc/intel/avs/pcm.h
Normal file
16
sound/soc/intel/avs/pcm.h
Normal file
@ -0,0 +1,16 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
/*
|
||||
* Copyright(c) 2024 Intel Corporation
|
||||
*
|
||||
* Authors: Cezary Rojewski <cezary.rojewski@intel.com>
|
||||
* Amadeusz Slawinski <amadeuszx.slawinski@linux.intel.com>
|
||||
*/
|
||||
|
||||
#ifndef __SOUND_SOC_INTEL_AVS_PCM_H
|
||||
#define __SOUND_SOC_INTEL_AVS_PCM_H
|
||||
|
||||
#include <sound/pcm.h>
|
||||
|
||||
void avs_period_elapsed(struct snd_pcm_substream *substream);
|
||||
|
||||
#endif
|
@ -144,6 +144,7 @@ static int loongson_card_parse_of(struct loongson_card_data *data)
|
||||
dev_err(dev, "getting cpu dlc error (%d)\n", ret);
|
||||
goto err;
|
||||
}
|
||||
loongson_dai_links[i].platforms->of_node = loongson_dai_links[i].cpus->of_node;
|
||||
|
||||
ret = snd_soc_of_get_dlc(codec, NULL, loongson_dai_links[i].codecs, 0);
|
||||
if (ret < 0) {
|
||||
|
@ -157,6 +157,7 @@ config SND_SOC_SDM845
|
||||
depends on COMMON_CLK
|
||||
select SND_SOC_QDSP6
|
||||
select SND_SOC_QCOM_COMMON
|
||||
select SND_SOC_QCOM_SDW
|
||||
select SND_SOC_RT5663
|
||||
select SND_SOC_MAX98927
|
||||
imply SND_SOC_CROS_EC_CODEC
|
||||
|
@ -1242,6 +1242,8 @@ int asoc_qcom_lpass_cpu_platform_probe(struct platform_device *pdev)
|
||||
/* Allocation for i2sctl regmap fields */
|
||||
drvdata->i2sctl = devm_kzalloc(&pdev->dev, sizeof(struct lpaif_i2sctl),
|
||||
GFP_KERNEL);
|
||||
if (!drvdata->i2sctl)
|
||||
return -ENOMEM;
|
||||
|
||||
/* Initialize bitfields for dai I2SCTL register */
|
||||
ret = lpass_cpu_init_i2sctl_bitfields(dev, drvdata->i2sctl,
|
||||
|
@ -15,6 +15,7 @@
|
||||
#include <uapi/linux/input-event-codes.h>
|
||||
#include "common.h"
|
||||
#include "qdsp6/q6afe.h"
|
||||
#include "sdw.h"
|
||||
#include "../codecs/rt5663.h"
|
||||
|
||||
#define DRIVER_NAME "sdm845"
|
||||
@ -416,7 +417,7 @@ static int sdm845_snd_startup(struct snd_pcm_substream *substream)
|
||||
pr_err("%s: invalid dai id 0x%x\n", __func__, cpu_dai->id);
|
||||
break;
|
||||
}
|
||||
return 0;
|
||||
return qcom_snd_sdw_startup(substream);
|
||||
}
|
||||
|
||||
static void sdm845_snd_shutdown(struct snd_pcm_substream *substream)
|
||||
@ -425,6 +426,7 @@ static void sdm845_snd_shutdown(struct snd_pcm_substream *substream)
|
||||
struct snd_soc_card *card = rtd->card;
|
||||
struct sdm845_snd_data *data = snd_soc_card_get_drvdata(card);
|
||||
struct snd_soc_dai *cpu_dai = snd_soc_rtd_to_cpu(rtd, 0);
|
||||
struct sdw_stream_runtime *sruntime = data->sruntime[cpu_dai->id];
|
||||
|
||||
switch (cpu_dai->id) {
|
||||
case PRIMARY_MI2S_RX:
|
||||
@ -463,6 +465,9 @@ static void sdm845_snd_shutdown(struct snd_pcm_substream *substream)
|
||||
pr_err("%s: invalid dai id 0x%x\n", __func__, cpu_dai->id);
|
||||
break;
|
||||
}
|
||||
|
||||
data->sruntime[cpu_dai->id] = NULL;
|
||||
sdw_release_stream(sruntime);
|
||||
}
|
||||
|
||||
static int sdm845_snd_prepare(struct snd_pcm_substream *substream)
|
||||
|
@ -1281,7 +1281,9 @@ static int rsnd_dai_of_node(struct rsnd_priv *priv, int *is_graph)
|
||||
if (!of_node_name_eq(ports, "ports") &&
|
||||
!of_node_name_eq(ports, "port"))
|
||||
continue;
|
||||
priv->component_dais[i] = of_graph_get_endpoint_count(ports);
|
||||
priv->component_dais[i] =
|
||||
of_graph_get_endpoint_count(of_node_name_eq(ports, "ports") ?
|
||||
ports : np);
|
||||
nr += priv->component_dais[i];
|
||||
i++;
|
||||
if (i >= RSND_MAX_COMPONENT) {
|
||||
@ -1493,7 +1495,8 @@ static int rsnd_dai_probe(struct rsnd_priv *priv)
|
||||
if (!of_node_name_eq(ports, "ports") &&
|
||||
!of_node_name_eq(ports, "port"))
|
||||
continue;
|
||||
for_each_endpoint_of_node(ports, dai_np) {
|
||||
for_each_endpoint_of_node(of_node_name_eq(ports, "ports") ?
|
||||
ports : np, dai_np) {
|
||||
__rsnd_dai_probe(priv, dai_np, dai_np, 0, dai_i);
|
||||
if (!rsnd_is_gen1(priv) && !rsnd_is_gen2(priv)) {
|
||||
rdai = rsnd_rdai_get(priv, dai_i);
|
||||
|
@ -2785,10 +2785,10 @@ EXPORT_SYMBOL_GPL(snd_soc_dapm_update_dai);
|
||||
|
||||
int snd_soc_dapm_widget_name_cmp(struct snd_soc_dapm_widget *widget, const char *s)
|
||||
{
|
||||
struct snd_soc_component *component = snd_soc_dapm_to_component(widget->dapm);
|
||||
struct snd_soc_component *component = widget->dapm->component;
|
||||
const char *wname = widget->name;
|
||||
|
||||
if (component->name_prefix)
|
||||
if (component && component->name_prefix)
|
||||
wname += strlen(component->name_prefix) + 1; /* plus space */
|
||||
|
||||
return strcmp(wname, s);
|
||||
|
@ -206,7 +206,10 @@ int acp_dsp_pre_fw_run(struct snd_sof_dev *sdev)
|
||||
configure_pte_for_fw_loading(FW_SRAM_DATA_BIN, ACP_SRAM_PAGE_COUNT, adata);
|
||||
src_addr = ACP_SYSTEM_MEMORY_WINDOW + ACP_DEFAULT_SRAM_LENGTH +
|
||||
(page_count * ACP_PAGE_SIZE);
|
||||
dest_addr = ACP_SRAM_BASE_ADDRESS;
|
||||
if (adata->pci_rev > ACP63_PCI_ID)
|
||||
dest_addr = ACP7X_SRAM_BASE_ADDRESS;
|
||||
else
|
||||
dest_addr = ACP_SRAM_BASE_ADDRESS;
|
||||
|
||||
ret = configure_and_run_dma(adata, src_addr, dest_addr,
|
||||
adata->fw_sram_data_bin_size);
|
||||
|
@ -329,7 +329,9 @@ int configure_and_run_sha_dma(struct acp_dev_data *adata, void *image_addr,
|
||||
fw_qualifier, fw_qualifier & DSP_FW_RUN_ENABLE,
|
||||
ACP_REG_POLL_INTERVAL, ACP_DMA_COMPLETE_TIMEOUT_US);
|
||||
if (ret < 0) {
|
||||
dev_err(sdev->dev, "PSP validation failed\n");
|
||||
val = snd_sof_dsp_read(sdev, ACP_DSP_BAR, ACP_SHA_PSP_ACK);
|
||||
dev_err(sdev->dev, "PSP validation failed: fw_qualifier = %#x, ACP_SHA_PSP_ACK = %#x\n",
|
||||
fw_qualifier, val);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -294,14 +294,9 @@ int hda_cl_copy_fw(struct snd_sof_dev *sdev, struct hdac_ext_stream *hext_stream
|
||||
{
|
||||
struct sof_intel_hda_dev *hda = sdev->pdata->hw_pdata;
|
||||
const struct sof_intel_dsp_desc *chip = hda->desc;
|
||||
struct sof_intel_hda_stream *hda_stream;
|
||||
unsigned long time_left;
|
||||
unsigned int reg;
|
||||
int ret, status;
|
||||
|
||||
hda_stream = container_of(hext_stream, struct sof_intel_hda_stream,
|
||||
hext_stream);
|
||||
|
||||
dev_dbg(sdev->dev, "Code loader DMA starting\n");
|
||||
|
||||
ret = hda_cl_trigger(sdev->dev, hext_stream, SNDRV_PCM_TRIGGER_START);
|
||||
@ -310,18 +305,6 @@ int hda_cl_copy_fw(struct snd_sof_dev *sdev, struct hdac_ext_stream *hext_stream
|
||||
return ret;
|
||||
}
|
||||
|
||||
if (sdev->pdata->ipc_type == SOF_IPC_TYPE_4) {
|
||||
/* Wait for completion of transfer */
|
||||
time_left = wait_for_completion_timeout(&hda_stream->ioc,
|
||||
msecs_to_jiffies(HDA_CL_DMA_IOC_TIMEOUT_MS));
|
||||
|
||||
if (!time_left) {
|
||||
dev_err(sdev->dev, "Code loader DMA did not complete\n");
|
||||
return -ETIMEDOUT;
|
||||
}
|
||||
dev_dbg(sdev->dev, "Code loader DMA done\n");
|
||||
}
|
||||
|
||||
dev_dbg(sdev->dev, "waiting for FW_ENTERED status\n");
|
||||
|
||||
status = snd_sof_dsp_read_poll_timeout(sdev, HDA_DSP_BAR,
|
||||
|
Loading…
Reference in New Issue
Block a user