| /* |
| * Copyright (c) 2016-2018, ARM Limited and Contributors. All rights reserved. |
| * Copyright (c) 2020, NVIDIA Corporation. All rights reserved. |
| * |
| * SPDX-License-Identifier: BSD-3-Clause |
| */ |
| |
| #include <assert.h> |
| #include <string.h> |
| |
| #include <platform_def.h> |
| |
| #include <common/bl_common.h> |
| #include <common/debug.h> |
| |
| #include <smmu.h> |
| #include <tegra_private.h> |
| |
| extern void memcpy16(void *dest, const void *src, unsigned int length); |
| |
| #define SMMU_NUM_CONTEXTS 64U |
| #define SMMU_CONTEXT_BANK_MAX_IDX 64U |
| |
| /* |
| * Init SMMU during boot or "System Suspend" exit |
| */ |
| void tegra_smmu_init(void) |
| { |
| uint32_t val, cb_idx, smmu_id, ctx_base; |
| uint32_t smmu_counter = plat_get_num_smmu_devices(); |
| |
| for (smmu_id = 0U; smmu_id < smmu_counter; smmu_id++) { |
| /* Program the SMMU pagesize and reset CACHE_LOCK bit */ |
| val = tegra_smmu_read_32(smmu_id, SMMU_GSR0_SECURE_ACR); |
| val |= SMMU_GSR0_PGSIZE_64K; |
| val &= (uint32_t)~SMMU_ACR_CACHE_LOCK_ENABLE_BIT; |
| tegra_smmu_write_32(smmu_id, SMMU_GSR0_SECURE_ACR, val); |
| |
| /* reset CACHE LOCK bit for NS Aux. Config. Register */ |
| val = tegra_smmu_read_32(smmu_id, SMMU_GNSR_ACR); |
| val &= (uint32_t)~SMMU_ACR_CACHE_LOCK_ENABLE_BIT; |
| tegra_smmu_write_32(smmu_id, SMMU_GNSR_ACR, val); |
| |
| /* disable TCU prefetch for all contexts */ |
| ctx_base = (SMMU_GSR0_PGSIZE_64K * SMMU_NUM_CONTEXTS) |
| + SMMU_CBn_ACTLR; |
| for (cb_idx = 0; cb_idx < SMMU_CONTEXT_BANK_MAX_IDX; cb_idx++) { |
| val = tegra_smmu_read_32(smmu_id, |
| ctx_base + (SMMU_GSR0_PGSIZE_64K * cb_idx)); |
| val &= (uint32_t)~SMMU_CBn_ACTLR_CPRE_BIT; |
| tegra_smmu_write_32(smmu_id, ctx_base + |
| (SMMU_GSR0_PGSIZE_64K * cb_idx), val); |
| } |
| |
| /* set CACHE LOCK bit for NS Aux. Config. Register */ |
| val = tegra_smmu_read_32(smmu_id, SMMU_GNSR_ACR); |
| val |= (uint32_t)SMMU_ACR_CACHE_LOCK_ENABLE_BIT; |
| tegra_smmu_write_32(smmu_id, SMMU_GNSR_ACR, val); |
| |
| /* set CACHE LOCK bit for S Aux. Config. Register */ |
| val = tegra_smmu_read_32(smmu_id, SMMU_GSR0_SECURE_ACR); |
| val |= (uint32_t)SMMU_ACR_CACHE_LOCK_ENABLE_BIT; |
| tegra_smmu_write_32(smmu_id, SMMU_GSR0_SECURE_ACR, val); |
| } |
| } |