Message ID | 20230830195536.448884-1-vkarpovi@opensource.cirrus.com |
---|---|
State | New |
Headers | show |
Series | [v2,1/4] ASoC: cs35l45: Checks index of cs35l45_irqs[] | expand |
On Wed, Aug 30, 2023 at 02:55:33PM -0500, Vlad Karpovich wrote: > Checks the index computed by the virq offset before printing the > error condition in cs35l45_spk_safe_err() handler. > > Signed-off-by: Ricardo Rivera-Matos <rriveram@opensource.cirrus.com> > Signed-off-by: Vlad Karpovich <vkarpovi@opensource.cirrus.com> Who actually wrote this patch?
diff --git a/sound/soc/codecs/cs35l45.c b/sound/soc/codecs/cs35l45.c index 2ac4612402eb..02b1172d2647 100644 --- a/sound/soc/codecs/cs35l45.c +++ b/sound/soc/codecs/cs35l45.c @@ -1023,7 +1023,10 @@ static irqreturn_t cs35l45_spk_safe_err(int irq, void *data) i = irq - regmap_irq_get_virq(cs35l45->irq_data, 0); - dev_err(cs35l45->dev, "%s condition detected!\n", cs35l45_irqs[i].name); + if (i < 0 || i >= ARRAY_SIZE(cs35l45_irqs)) + dev_err(cs35l45->dev, "Unspecified global error condition (%d) detected!\n", irq); + else + dev_err(cs35l45->dev, "%s condition detected!\n", cs35l45_irqs[i].name); return IRQ_HANDLED; }