Unverified Commit 1de6ddcd authored by Maciej Strozek's avatar Maciej Strozek Committed by Mark Brown
Browse files

ASoC: SOF: Intel: fix iteration in is_endpoint_present()



is_endpoint_present() iterates over sdca_data.num_functions, but checks
the dai_type according to codec info list, which will cause problems if
not all endpoints from the codec info list are present. Make sure the
type of actually present functions is compared against target dai_type.

Fixes: 5226d19d ("ASoC: SOF: Intel: use sof_sdw as default SDW machine driver")
Signed-off-by: default avatarMaciej Strozek <mstrozek@opensource.cirrus.com>
Signed-off-by: default avatarBard Liao <yung-chuan.liao@linux.intel.com>
Link: https://patch.msgid.link/20260402064531.2287261-3-yung-chuan.liao@linux.intel.com


Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 86facd80
Loading
Loading
Loading
Loading
+3 −5
Original line number Diff line number Diff line
@@ -1133,8 +1133,7 @@ static void hda_generic_machine_select(struct snd_sof_dev *sdev,

#if IS_ENABLED(CONFIG_SND_SOC_SOF_INTEL_SOUNDWIRE)

static bool is_endpoint_present(struct sdw_slave *sdw_device,
				struct asoc_sdw_codec_info *dai_info, int dai_type)
static bool is_endpoint_present(struct sdw_slave *sdw_device, int dai_type)
{
	int i;

@@ -1145,7 +1144,7 @@ static bool is_endpoint_present(struct sdw_slave *sdw_device,
	}

	for (i = 0; i < sdw_device->sdca_data.num_functions; i++) {
		if (dai_type == dai_info->dais[i].dai_type)
		if (dai_type == asoc_sdw_get_dai_type(sdw_device->sdca_data.function[i].type))
			return true;
	}
	dev_dbg(&sdw_device->dev, "Endpoint DAI type %d not found\n", dai_type);
@@ -1199,8 +1198,7 @@ static struct snd_soc_acpi_adr_device *find_acpi_adr_device(struct device *dev,
		}
		for (j = 0; j < codec_info_list[i].dai_num; j++) {
			/* Check if the endpoint is present by the SDCA DisCo table */
			if (!is_endpoint_present(sdw_device, &codec_info_list[i],
						 codec_info_list[i].dais[j].dai_type))
			if (!is_endpoint_present(sdw_device, codec_info_list[i].dais[j].dai_type))
				continue;

			endpoints[ep_index].num = j;