1*91f16700Schasinglulu /* 2*91f16700Schasinglulu * Copyright (c) 2017, ARM Limited and Contributors. All rights reserved. 3*91f16700Schasinglulu * 4*91f16700Schasinglulu * SPDX-License-Identifier: BSD-3-Clause 5*91f16700Schasinglulu */ 6*91f16700Schasinglulu 7*91f16700Schasinglulu #ifndef DDR_PARAMETER_H 8*91f16700Schasinglulu #define DDR_PARAMETER_H 9*91f16700Schasinglulu 10*91f16700Schasinglulu #include <string.h> 11*91f16700Schasinglulu 12*91f16700Schasinglulu #include <platform_def.h> 13*91f16700Schasinglulu 14*91f16700Schasinglulu #include <arch_helpers.h> 15*91f16700Schasinglulu #include <common/debug.h> 16*91f16700Schasinglulu #include <drivers/console.h> 17*91f16700Schasinglulu #include <drivers/delay_timer.h> 18*91f16700Schasinglulu #include <lib/mmio.h> 19*91f16700Schasinglulu 20*91f16700Schasinglulu #include <plat_private.h> 21*91f16700Schasinglulu #include <soc.h> 22*91f16700Schasinglulu 23*91f16700Schasinglulu #define DDR_REGION_NR_MAX 10 24*91f16700Schasinglulu #define REGION_NR_OFFSET 0 25*91f16700Schasinglulu #define REGION_ADDR_OFFSET 8 26*91f16700Schasinglulu #define REGION_DATA_PER_BYTES 8 27*91f16700Schasinglulu #define RG_SIZE_MB(byte) ((byte) >> 20) 28*91f16700Schasinglulu 29*91f16700Schasinglulu /* unit: MB */ 30*91f16700Schasinglulu struct param_ddr_usage { 31*91f16700Schasinglulu uint64_t boundary; 32*91f16700Schasinglulu 33*91f16700Schasinglulu uint32_t ns_nr; 34*91f16700Schasinglulu uint64_t ns_base[DDR_REGION_NR_MAX]; 35*91f16700Schasinglulu uint64_t ns_top[DDR_REGION_NR_MAX]; 36*91f16700Schasinglulu 37*91f16700Schasinglulu uint32_t s_nr; 38*91f16700Schasinglulu uint64_t s_base[DDR_REGION_NR_MAX + 1]; 39*91f16700Schasinglulu uint64_t s_top[DDR_REGION_NR_MAX + 1]; 40*91f16700Schasinglulu }; 41*91f16700Schasinglulu 42*91f16700Schasinglulu struct param_ddr_usage ddr_region_usage_parse(uint64_t addr, uint64_t max_mb); 43*91f16700Schasinglulu 44*91f16700Schasinglulu #endif /* DDR_PARAMETER_H */ 45