Angel Pons | bbc99cf | 2020-04-04 18:51:23 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 2 | |
Julius Werner | dae15a6 | 2014-10-15 18:50:45 -0700 | [diff] [blame] | 3 | #include <arch/cache.h> |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 4 | #include <bootblock_common.h> |
Julius Werner | 7a453eb | 2014-10-20 13:14:55 -0700 | [diff] [blame] | 5 | #include <soc/addressmap.h> |
| 6 | #include <soc/clock.h> |
| 7 | #include <soc/grf.h> |
| 8 | #include <soc/timer.h> |
Julius Werner | dae15a6 | 2014-10-15 18:50:45 -0700 | [diff] [blame] | 9 | #include <symbols.h> |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 10 | |
Julius Werner | c827c9b | 2023-11-09 12:20:59 -0800 | [diff] [blame^] | 11 | _Static_assert(!CONFIG(CBFS_VERIFICATION), |
| 12 | "RK3288 doesn't have enough PRERAM_CBFS_CACHE to support the FMAP mapping needed for CBFS verification"); |
| 13 | |
Patrick Georgi | 20864c1 | 2015-07-01 20:29:42 +0200 | [diff] [blame] | 14 | void bootblock_soc_init(void) |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 15 | { |
David Hendricks | 3b63161 | 2014-09-29 13:37:51 -0700 | [diff] [blame] | 16 | rkclk_init(); |
Julius Werner | dae15a6 | 2014-10-15 18:50:45 -0700 | [diff] [blame] | 17 | |
| 18 | mmu_init(); |
| 19 | /* Start with a clean slate. */ |
| 20 | mmu_config_range(0, 4096, DCACHE_OFF); |
| 21 | /* SRAM is tightly wedged between registers, need to use subtables. Map |
| 22 | * write-through as equivalent for non-cacheable without XN on A17. */ |
| 23 | mmu_config_range_kb((uintptr_t)_sram/KiB, |
Julius Werner | 7e0dea6 | 2019-02-20 18:39:22 -0800 | [diff] [blame] | 24 | REGION_SIZE(sram)/KiB, DCACHE_WRITETHROUGH); |
Julius Werner | dae15a6 | 2014-10-15 18:50:45 -0700 | [diff] [blame] | 25 | dcache_mmu_enable(); |
Julius Werner | 33df495 | 2014-12-16 22:48:26 -0800 | [diff] [blame] | 26 | |
| 27 | rkclk_configure_crypto(148500*KHz); |
jinkun.hong | ac490b8 | 2014-06-22 20:40:39 -0700 | [diff] [blame] | 28 | } |