blob: 30e522804fbf379822f2af34a8cc8f1f92a36816 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Thomas Abrahame39448e2016-04-23 22:18:13 +05302/*
3 * Copyright (C) 2016 Samsung Electronics
4 * Thomas Abraham <thomas.ab@samsung.com>
Thomas Abrahame39448e2016-04-23 22:18:13 +05305 */
6
7#include <common.h>
8#include <asm/armv8/mmu.h>
Sam Protsenkoe6e300d2024-01-10 21:09:07 -06009#include <linux/sizes.h>
Thomas Abrahame39448e2016-04-23 22:18:13 +053010
Simon Glass418f2172023-02-05 15:39:51 -070011#if IS_ENABLED(CONFIG_EXYNOS7420)
Minkyu Kanga80f5822021-11-04 16:13:17 +090012
Thomas Abrahame39448e2016-04-23 22:18:13 +053013static struct mm_region exynos7420_mem_map[] = {
14 {
York Suncd4b0c52016-06-24 16:46:22 -070015 .virt = 0x10000000UL,
16 .phys = 0x10000000UL,
Thomas Abrahame39448e2016-04-23 22:18:13 +053017 .size = 0x10000000UL,
18 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
19 PTE_BLOCK_NON_SHARE |
20 PTE_BLOCK_PXN | PTE_BLOCK_UXN,
21 }, {
York Suncd4b0c52016-06-24 16:46:22 -070022 .virt = 0x40000000UL,
23 .phys = 0x40000000UL,
Thomas Abrahame39448e2016-04-23 22:18:13 +053024 .size = 0x80000000UL,
25 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
26 PTE_BLOCK_INNER_SHARE,
27 }, {
28 /* List terminator */
Thomas Abrahame39448e2016-04-23 22:18:13 +053029 },
30};
31
32struct mm_region *mem_map = exynos7420_mem_map;
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030033
Minkyu Kanga80f5822021-11-04 16:13:17 +090034#elif CONFIG_IS_ENABLED(EXYNOS7870)
35
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030036static struct mm_region exynos7870_mem_map[] = {
37 {
38 .virt = 0x10000000UL,
39 .phys = 0x10000000UL,
40 .size = 0x10000000UL,
41 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
42 PTE_BLOCK_NON_SHARE |
43 PTE_BLOCK_PXN | PTE_BLOCK_UXN,
44 },
45 {
46 .virt = 0x40000000UL,
47 .phys = 0x40000000UL,
48 .size = 0x3E400000UL,
49 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
50 PTE_BLOCK_INNER_SHARE,
51 },
52 {
53 .virt = 0x80000000UL,
54 .phys = 0x80000000UL,
55 .size = 0x40000000UL,
56 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
57 PTE_BLOCK_INNER_SHARE,
58 },
59
60 {
61 /* List terminator */
62 },
63};
64
65struct mm_region *mem_map = exynos7870_mem_map;
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030066
Minkyu Kanga80f5822021-11-04 16:13:17 +090067#elif CONFIG_IS_ENABLED(EXYNOS7880)
68
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030069static struct mm_region exynos7880_mem_map[] = {
70 {
71 .virt = 0x10000000UL,
72 .phys = 0x10000000UL,
73 .size = 0x10000000UL,
74 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
75 PTE_BLOCK_NON_SHARE |
76 PTE_BLOCK_PXN | PTE_BLOCK_UXN,
77 },
78 {
79 .virt = 0x40000000UL,
80 .phys = 0x40000000UL,
81 .size = 0x3E400000UL,
82 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
83 PTE_BLOCK_INNER_SHARE,
84 },
85 {
86 .virt = 0x80000000UL,
87 .phys = 0x80000000UL,
88 .size = 0x80000000UL,
89 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
90 PTE_BLOCK_INNER_SHARE,
91 },
92
93 {
94 /* List terminator */
95 },
96};
97
98struct mm_region *mem_map = exynos7880_mem_map;
Sam Protsenkoe6e300d2024-01-10 21:09:07 -060099
100#elif IS_ENABLED(CONFIG_EXYNOS850)
101
102static struct mm_region exynos850_mem_map[] = {
103 {
104 /* Peripheral block */
105 .virt = 0x10000000UL,
106 .phys = 0x10000000UL,
107 .size = SZ_256M,
108 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
109 PTE_BLOCK_NON_SHARE |
110 PTE_BLOCK_PXN | PTE_BLOCK_UXN
111 }, {
112 /* DDR, 32-bit area */
113 .virt = 0x80000000UL,
114 .phys = 0x80000000UL,
115 .size = SZ_2G,
116 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
117 PTE_BLOCK_INNER_SHARE
118 }, {
119 /* DDR, 64-bit area */
120 .virt = 0x880000000UL,
121 .phys = 0x880000000UL,
122 .size = SZ_2G,
123 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
124 PTE_BLOCK_INNER_SHARE
125 }, {
126 /* List terminator */
127 }
128};
129
130struct mm_region *mem_map = exynos850_mem_map;
131
Dzmitry Sankouski69bde042021-10-17 13:45:41 +0300132#endif