mirror of
https://github.com/torvalds/linux.git
synced 2026-05-25 23:52:08 +02:00
ASoC: hdac_hdmi: Rate limit logging on connection and disconnection
We currently log parse failures for ELD data and some disconnection events as errors without rate limiting. These log messages can be triggered very frequently in some situations, especially ELD parsing when there is nothing connected to a HDMI port which will generate: hdmi-audio-codec hdmi-audio-codec.1.auto: HDMI: Unknown ELD version 0 While there's doubtless work that could be done on reducing the number of connection notification callbacks it's possible these may be legitimately generated by poor quality physical connections so let's use rate limiting to mitigate the log spam for the parse errors and lower the severity for disconnect logging to debug level. Signed-off-by: Mark Brown <broonie@kernel.org> Link: https://patch.msgid.link/20250613-asoc-hdmi-eld-logging-v1-1-76d64154d969@kernel.org Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
ac558015df
commit
c4ca928a6d
|
|
@ -1231,7 +1231,8 @@ static int hdac_hdmi_parse_eld(struct hdac_device *hdev,
|
|||
>> DRM_ELD_VER_SHIFT;
|
||||
|
||||
if (ver != ELD_VER_CEA_861D && ver != ELD_VER_PARTIAL) {
|
||||
dev_err(&hdev->dev, "HDMI: Unknown ELD version %d\n", ver);
|
||||
dev_err_ratelimited(&hdev->dev,
|
||||
"HDMI: Unknown ELD version %d\n", ver);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
|
|
@ -1239,7 +1240,8 @@ static int hdac_hdmi_parse_eld(struct hdac_device *hdev,
|
|||
DRM_ELD_MNL_MASK) >> DRM_ELD_MNL_SHIFT;
|
||||
|
||||
if (mnl > ELD_MAX_MNL) {
|
||||
dev_err(&hdev->dev, "HDMI: MNL Invalid %d\n", mnl);
|
||||
dev_err_ratelimited(&hdev->dev,
|
||||
"HDMI: MNL Invalid %d\n", mnl);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
|
|
@ -1298,8 +1300,8 @@ static void hdac_hdmi_present_sense(struct hdac_hdmi_pin *pin,
|
|||
|
||||
if (!port->eld.monitor_present || !port->eld.eld_valid) {
|
||||
|
||||
dev_err(&hdev->dev, "%s: disconnect for pin:port %d:%d\n",
|
||||
__func__, pin->nid, port->id);
|
||||
dev_dbg(&hdev->dev, "%s: disconnect for pin:port %d:%d\n",
|
||||
__func__, pin->nid, port->id);
|
||||
|
||||
/*
|
||||
* PCMs are not registered during device probe, so don't
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user