blob: fdaacc70c9bd14c5a3567b48cfa0913a9ec250f3 [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
Thomas Abrahame39448e2016-04-23 22:18:13 +05307#include <asm/armv8/mmu.h>
Sam Protsenkoe6e300d2024-01-10 21:09:07 -06008#include <linux/sizes.h>
Thomas Abrahame39448e2016-04-23 22:18:13 +05309
Simon Glass418f2172023-02-05 15:39:51 -070010#if IS_ENABLED(CONFIG_EXYNOS7420)
Minkyu Kanga80f5822021-11-04 16:13:17 +090011
Thomas Abrahame39448e2016-04-23 22:18:13 +053012static struct mm_region exynos7420_mem_map[] = {
13 {
York Suncd4b0c52016-06-24 16:46:22 -070014 .virt = 0x10000000UL,
15 .phys = 0x10000000UL,
Thomas Abrahame39448e2016-04-23 22:18:13 +053016 .size = 0x10000000UL,
17 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
18 PTE_BLOCK_NON_SHARE |
19 PTE_BLOCK_PXN | PTE_BLOCK_UXN,
20 }, {
York Suncd4b0c52016-06-24 16:46:22 -070021 .virt = 0x40000000UL,
22 .phys = 0x40000000UL,
Thomas Abrahame39448e2016-04-23 22:18:13 +053023 .size = 0x80000000UL,
24 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
25 PTE_BLOCK_INNER_SHARE,
26 }, {
27 /* List terminator */
Thomas Abrahame39448e2016-04-23 22:18:13 +053028 },
29};
30
31struct mm_region *mem_map = exynos7420_mem_map;
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030032
Minkyu Kanga80f5822021-11-04 16:13:17 +090033#elif CONFIG_IS_ENABLED(EXYNOS7870)
34
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030035static struct mm_region exynos7870_mem_map[] = {
36 {
37 .virt = 0x10000000UL,
38 .phys = 0x10000000UL,
39 .size = 0x10000000UL,
40 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
41 PTE_BLOCK_NON_SHARE |
42 PTE_BLOCK_PXN | PTE_BLOCK_UXN,
43 },
44 {
45 .virt = 0x40000000UL,
46 .phys = 0x40000000UL,
47 .size = 0x3E400000UL,
48 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
49 PTE_BLOCK_INNER_SHARE,
50 },
51 {
52 .virt = 0x80000000UL,
53 .phys = 0x80000000UL,
54 .size = 0x40000000UL,
55 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
56 PTE_BLOCK_INNER_SHARE,
57 },
58
59 {
60 /* List terminator */
61 },
62};
63
64struct mm_region *mem_map = exynos7870_mem_map;
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030065
Minkyu Kanga80f5822021-11-04 16:13:17 +090066#elif CONFIG_IS_ENABLED(EXYNOS7880)
67
Dzmitry Sankouski69bde042021-10-17 13:45:41 +030068static struct mm_region exynos7880_mem_map[] = {
69 {
70 .virt = 0x10000000UL,
71 .phys = 0x10000000UL,
72 .size = 0x10000000UL,
73 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
74 PTE_BLOCK_NON_SHARE |
75 PTE_BLOCK_PXN | PTE_BLOCK_UXN,
76 },
77 {
78 .virt = 0x40000000UL,
79 .phys = 0x40000000UL,
80 .size = 0x3E400000UL,
81 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
82 PTE_BLOCK_INNER_SHARE,
83 },
84 {
85 .virt = 0x80000000UL,
86 .phys = 0x80000000UL,
87 .size = 0x80000000UL,
88 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
89 PTE_BLOCK_INNER_SHARE,
90 },
91
92 {
93 /* List terminator */
94 },
95};
96
97struct mm_region *mem_map = exynos7880_mem_map;
Sam Protsenkoe6e300d2024-01-10 21:09:07 -060098
99#elif IS_ENABLED(CONFIG_EXYNOS850)
100
101static struct mm_region exynos850_mem_map[] = {
102 {
Sam Protsenko7045c4d2024-05-25 16:53:30 -0500103 /* iRAM */
104 .virt = 0x02000000UL,
105 .phys = 0x02000000UL,
106 .size = SZ_2M,
107 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRE) |
108 PTE_BLOCK_NON_SHARE |
109 PTE_BLOCK_PXN | PTE_BLOCK_UXN
110 }, {
Sam Protsenkoe6e300d2024-01-10 21:09:07 -0600111 /* Peripheral block */
112 .virt = 0x10000000UL,
113 .phys = 0x10000000UL,
114 .size = SZ_256M,
115 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
116 PTE_BLOCK_NON_SHARE |
117 PTE_BLOCK_PXN | PTE_BLOCK_UXN
118 }, {
119 /* DDR, 32-bit area */
120 .virt = 0x80000000UL,
121 .phys = 0x80000000UL,
122 .size = SZ_2G,
123 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
124 PTE_BLOCK_INNER_SHARE
125 }, {
126 /* DDR, 64-bit area */
127 .virt = 0x880000000UL,
128 .phys = 0x880000000UL,
129 .size = SZ_2G,
130 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
131 PTE_BLOCK_INNER_SHARE
132 }, {
133 /* List terminator */
134 }
135};
136
137struct mm_region *mem_map = exynos850_mem_map;
138
Dzmitry Sankouski69bde042021-10-17 13:45:41 +0300139#endif