Linux-ARM-Kernel Archive on lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] media: verisilicon: Fix kernel panic due to __initconst misuse
@ 2026-03-05  8:03 ming.qian
  2026-03-05  9:01 ` Marco Felsch
                   ` (3 more replies)
  0 siblings, 4 replies; 9+ messages in thread
From: ming.qian @ 2026-03-05  8:03 UTC (permalink / raw)
  To: linux-media
  Cc: mchehab, hverkuil-cisco, nicolas, benjamin.gaignard, robh,
	krzk+dt, conor+dt, p.zabel, sebastian.fricke, shawnguo,
	ulf.hansson, s.hauer, kernel, festevam, m.felsch, fra.schnyder,
	linux-imx, l.stach, Frank.li, peng.fan, eagle.zhou, devicetree,
	imx, linux-pm, linux-kernel, linux-arm-kernel

From: Ming Qian <ming.qian@oss.nxp.com>

Fix a kernel panic when probing the driver as a module:

  Unable to handle kernel paging request at virtual address
  ffffd9c18eb05000
  of_find_matching_node_and_match+0x5c/0x1a0
  hantro_probe+0x2f4/0x7d0 [hantro_vpu]

The imx8mq_vpu_shared_resources array is referenced by variant
structures through their shared_devices field. When built as a
module, __initconst causes this data to be freed after module
init, but it's later accessed during probe, causing a page fault.

Use __initconst_or_module to keep the data available when built
as a module while still allowing it to be freed when built-in.

Fixes: e0203ddf9af7 ("media: verisilicon: Avoid G2 bus error while decoding H.264 and HEVC")
Signed-off-by: Ming Qian <ming.qian@oss.nxp.com>
---
 drivers/media/platform/verisilicon/imx8m_vpu_hw.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/media/platform/verisilicon/imx8m_vpu_hw.c b/drivers/media/platform/verisilicon/imx8m_vpu_hw.c
index 6f8e43b7f157..fa429e6e8281 100644
--- a/drivers/media/platform/verisilicon/imx8m_vpu_hw.c
+++ b/drivers/media/platform/verisilicon/imx8m_vpu_hw.c
@@ -343,7 +343,7 @@ const struct hantro_variant imx8mq_vpu_variant = {
 	.num_regs = ARRAY_SIZE(imx8mq_reg_names)
 };
 
-static const struct of_device_id imx8mq_vpu_shared_resources[] __initconst = {
+static const struct of_device_id imx8mq_vpu_shared_resources[] __initconst_or_module = {
 	{ .compatible = "nxp,imx8mq-vpu-g1", },
 	{ .compatible = "nxp,imx8mq-vpu-g2", },
 	{ /* sentinel */ }
-- 
2.52.0



^ permalink raw reply related	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2026-03-05  9:57 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-03-05  8:03 [PATCH] media: verisilicon: Fix kernel panic due to __initconst misuse ming.qian
2026-03-05  9:01 ` Marco Felsch
2026-03-05  9:08   ` Ming Qian(OSS)
2026-03-05  9:50   ` Krzysztof Kozlowski
2026-03-05  9:57     ` Marco Felsch
2026-03-05  9:08 ` Franz Schnyder
2026-03-05  9:19 ` Krzysztof Kozlowski
2026-03-05  9:28   ` Ming Qian(OSS)
2026-03-05  9:28 ` Francesco Dolcini

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox