/* SPDX-License-Identifier: GPL-2.0-only OR MIT */ #include <console/console.h> #include <device/mmio.h> #include <soc/apusys.h> /* MBOX Functional Configuration */ DEFINE_BITFIELD(LOCK, 0, 0) DEFINE_BITFIELD(NO_MPU, 16, 16) static void dump_apusys_reg(void) { size_t i; for (i = 0; i < ARRAY_SIZE(mt8195_apu_mbox); i++) { printk(BIOS_DEBUG, "APU_MBOX %p = %#x\n", (void *)&mt8195_apu_mbox[i]->mbox_func_cfg, read32(&mt8195_apu_mbox[i]->mbox_func_cfg)); } } void apusys_init(void) { size_t i; /* Set up MBOX MPU for non secure access */ for (i = 0; i < ARRAY_SIZE(mt8195_apu_mbox); i++) SET32_BITFIELDS(&mt8195_apu_mbox[i]->mbox_func_cfg, NO_MPU, 1, LOCK, 1); dump_apusys_reg(); }