xref: /arm-trusted-firmware/plat/arm/board/fvp/fvp_drtm_dma_prot.c (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu /*
2*91f16700Schasinglulu  * Copyright (c) 2022, Arm Limited. All rights reserved.
3*91f16700Schasinglulu  *
4*91f16700Schasinglulu  * SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu  */
6*91f16700Schasinglulu 
7*91f16700Schasinglulu #include <stdbool.h>
8*91f16700Schasinglulu #include <stddef.h>
9*91f16700Schasinglulu 
10*91f16700Schasinglulu #include <drivers/arm/smmu_v3.h>
11*91f16700Schasinglulu #include <lib/utils_def.h>
12*91f16700Schasinglulu #include <plat/arm/common/arm_config.h>
13*91f16700Schasinglulu #include <plat/common/platform.h>
14*91f16700Schasinglulu 
15*91f16700Schasinglulu #include <platform_def.h>
16*91f16700Schasinglulu 
17*91f16700Schasinglulu /**
18*91f16700Schasinglulu  * Array mentioning number of SMMUs supported by FVP
19*91f16700Schasinglulu  */
20*91f16700Schasinglulu static const uintptr_t fvp_smmus[] = {
21*91f16700Schasinglulu 	PLAT_FVP_SMMUV3_BASE,
22*91f16700Schasinglulu };
23*91f16700Schasinglulu 
24*91f16700Schasinglulu bool plat_has_non_host_platforms(void)
25*91f16700Schasinglulu {
26*91f16700Schasinglulu 	/* FVP base platforms typically have GPU, as per FVP Reference guide */
27*91f16700Schasinglulu 	return true;
28*91f16700Schasinglulu }
29*91f16700Schasinglulu 
30*91f16700Schasinglulu bool plat_has_unmanaged_dma_peripherals(void)
31*91f16700Schasinglulu {
32*91f16700Schasinglulu 	/*
33*91f16700Schasinglulu 	 * FVP Reference guide does not show devices that are described as
34*91f16700Schasinglulu 	 * DMA-capable but not managed by an SMMU in the FVP documentation.
35*91f16700Schasinglulu 	 * However, the SMMU seems to have only been introduced in the RevC
36*91f16700Schasinglulu 	 * revision.
37*91f16700Schasinglulu 	 */
38*91f16700Schasinglulu 	return (arm_config.flags & ARM_CONFIG_FVP_HAS_SMMUV3) == 0;
39*91f16700Schasinglulu }
40*91f16700Schasinglulu 
41*91f16700Schasinglulu unsigned int plat_get_total_smmus(void)
42*91f16700Schasinglulu {
43*91f16700Schasinglulu 	if ((arm_config.flags & ARM_CONFIG_FVP_HAS_SMMUV3) != 0U) {
44*91f16700Schasinglulu 		return ARRAY_SIZE(fvp_smmus);
45*91f16700Schasinglulu 	} else {
46*91f16700Schasinglulu 		return 0;
47*91f16700Schasinglulu 	}
48*91f16700Schasinglulu }
49*91f16700Schasinglulu 
50*91f16700Schasinglulu void plat_enumerate_smmus(const uintptr_t **smmus_out,
51*91f16700Schasinglulu 			  size_t *smmu_count_out)
52*91f16700Schasinglulu {
53*91f16700Schasinglulu 	if ((arm_config.flags & ARM_CONFIG_FVP_HAS_SMMUV3) != 0U) {
54*91f16700Schasinglulu 		*smmus_out = fvp_smmus;
55*91f16700Schasinglulu 		*smmu_count_out = ARRAY_SIZE(fvp_smmus);
56*91f16700Schasinglulu 	} else {
57*91f16700Schasinglulu 		*smmus_out = NULL;
58*91f16700Schasinglulu 		*smmu_count_out = 0;
59*91f16700Schasinglulu 	}
60*91f16700Schasinglulu }
61*91f16700Schasinglulu 
62*91f16700Schasinglulu /* DRTM DMA Protection Features */
63*91f16700Schasinglulu static const plat_drtm_dma_prot_features_t dma_prot_features = {
64*91f16700Schasinglulu 	.max_num_mem_prot_regions = 0, /* No protection regions are present */
65*91f16700Schasinglulu 	.dma_protection_support = 0x1 /* Complete DMA protection only */
66*91f16700Schasinglulu };
67*91f16700Schasinglulu 
68*91f16700Schasinglulu const plat_drtm_dma_prot_features_t *plat_drtm_get_dma_prot_features(void)
69*91f16700Schasinglulu {
70*91f16700Schasinglulu 	return &dma_prot_features;
71*91f16700Schasinglulu }
72*91f16700Schasinglulu 
73*91f16700Schasinglulu uint64_t plat_drtm_dma_prot_get_max_table_bytes(void)
74*91f16700Schasinglulu {
75*91f16700Schasinglulu 	return 0U;
76*91f16700Schasinglulu }
77