// SPDX-License-Identifier: GPL-2.0 /* * Copyright (C) 2022 Renesas Electronics Corp. * */ #include #include #include #include #include #include static const struct andes_pma_region renesas_rzfive_pma_regions[] = { { .pa = 0x58000000, .size = 0x8000000, .flags = ANDES_PMACFG_ETYP_NAPOT | ANDES_PMACFG_MTYP_MEM_NON_CACHE_BUF, .dt_populate = true, .shared_dma = true, .no_map = true, .dma_default = true, }, }; static int renesas_rzfive_final_init(bool cold_boot) { int rc; if (cold_boot) { void *fdt = fdt_get_address_rw(); rc = andes_pma_setup_regions(fdt, renesas_rzfive_pma_regions, array_size(renesas_rzfive_pma_regions)); if (rc) return rc; } return generic_final_init(cold_boot); } static int renesas_rzfive_early_init(bool cold_boot) { int rc; rc = generic_early_init(cold_boot); if (rc) return rc; /* * Renesas RZ/Five RISC-V SoC has Instruction local memory and * Data local memory (ILM & DLM) mapped between region 0x30000 * to 0x4FFFF. When a virtual address falls within this range, * the MMU doesn't trigger a page fault; it assumes the virtual * address is a physical address which can cause undesired * behaviours for statically linked applications/libraries. To * avoid this, add the ILM/DLM memory regions to the root domain * region of the PMPU with permissions set to 0x0 for S/U modes * so that any access to these regions gets blocked and for M-mode * we grant full access. */ return sbi_domain_root_add_memrange(0x30000, 0x20000, 0x1000, SBI_DOMAIN_MEMREGION_M_RWX); } static int renesas_rzfive_platform_init(const void *fdt, int nodeoff, const struct fdt_match *match) { generic_platform_ops.early_init = renesas_rzfive_early_init; generic_platform_ops.final_init = renesas_rzfive_final_init; generic_platform_ops.extensions_init = andes_pmu_extensions_init; generic_platform_ops.pmu_init = andes_pmu_init; generic_platform_ops.vendor_ext_provider = andes_sbi_vendor_ext_provider; return 0; } static const struct fdt_match renesas_rzfive_match[] = { { .compatible = "renesas,r9a07g043f01" }, { /* sentinel */ } }; const struct fdt_driver renesas_rzfive = { .match_table = renesas_rzfive_match, .init = renesas_rzfive_platform_init, };