]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
bus: imx-aipstz: set default value for opacr registers
authorShengjiu Wang <shengjiu.wang@nxp.com>
Mon, 26 Jan 2026 09:11:56 +0000 (17:11 +0800)
committerFrank Li <Frank.Li@nxp.com>
Tue, 24 Feb 2026 20:51:29 +0000 (15:51 -0500)
The sdma script app_2_mcu needs the permission to access the peripheral
devices:

1) SDMA2 transactions are set to user-mode in this particular case.
2) This type of script doesn't use the peripheral interface (connected
directly to SPBA), but it uses the peripheral DMA interface, then the
SDMA2-issued transactions are subjected to AIPSTZ5's security-related
checks.

So need to clear the Supervisor Protect bit of SPBA2, otherwise the sdma
script can't work. As the imx-aipstz is a common driver for all aips bus,
so set default value (zero) for all opacr registers.

Signed-off-by: Shengjiu Wang <shengjiu.wang@nxp.com>
Reviewed-by: Laurentiu Mihalcea <laurentiu.mihalcea@nxp.com>
Reviewed-by: Daniel Baluta <daniel.baluta@nxp.com>
Reviewed-by: Frank Li <Frank.Li@nxp.com>
Signed-off-by: Frank Li <Frank.Li@nxp.com>
drivers/bus/imx-aipstz.c

index 5fdf377f5d06347bca8c940e739726152a2b684b..83371e5b35a2d80226f0326bfc1b930ae3d73321 100644 (file)
 #include <linux/regmap.h>
 
 #define IMX_AIPSTZ_MPR0 0x0
+#define IMX_AIPSTZ_OPACR0 0x40
+#define IMX_AIPSTZ_OPACR1 0x44
+#define IMX_AIPSTZ_OPACR2 0x48
+#define IMX_AIPSTZ_OPACR3 0x4c
+#define IMX_AIPSTZ_OPACR4 0x50
 
 struct imx_aipstz_config {
        u32 mpr0;
+       u32 opacr0;
+       u32 opacr1;
+       u32 opacr2;
+       u32 opacr3;
+       u32 opacr4;
 };
 
 struct imx_aipstz_data {
@@ -24,6 +34,11 @@ struct imx_aipstz_data {
 static void imx_aipstz_apply_default(struct imx_aipstz_data *data)
 {
        writel(data->default_cfg->mpr0, data->base + IMX_AIPSTZ_MPR0);
+       writel(data->default_cfg->opacr0, data->base + IMX_AIPSTZ_OPACR0);
+       writel(data->default_cfg->opacr1, data->base + IMX_AIPSTZ_OPACR1);
+       writel(data->default_cfg->opacr2, data->base + IMX_AIPSTZ_OPACR2);
+       writel(data->default_cfg->opacr3, data->base + IMX_AIPSTZ_OPACR3);
+       writel(data->default_cfg->opacr4, data->base + IMX_AIPSTZ_OPACR4);
 }
 
 static const struct of_device_id imx_aipstz_match_table[] = {