Patrick Georgi | ac95903 | 2020-05-05 22:49:26 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Aaron Durbin | 595688a | 2016-03-31 11:38:13 -0500 | [diff] [blame] | 2 | |
Furquan Shaikh | 0b6ff78 | 2016-04-21 08:10:02 -0700 | [diff] [blame] | 3 | #include <assert.h> |
Barnali Sarkar | 66fe0c4 | 2017-05-23 18:17:14 +0530 | [diff] [blame] | 4 | #include <intelblocks/msr.h> |
Aaron Durbin | 595688a | 2016-03-31 11:38:13 -0500 | [diff] [blame] | 5 | #include <program_loading.h> |
Naresh G Solanki | 4764be3 | 2018-04-05 11:22:12 +0530 | [diff] [blame] | 6 | #include <soc/cpu.h> |
Aaron Durbin | 595688a | 2016-03-31 11:38:13 -0500 | [diff] [blame] | 7 | |
| 8 | /* |
| 9 | * This file supports the necessary hoops one needs to jump through since |
| 10 | * early FSP component and early stages are running from cache-as-ram. |
| 11 | */ |
| 12 | |
Furquan Shaikh | 0b6ff78 | 2016-04-21 08:10:02 -0700 | [diff] [blame] | 13 | static inline int is_car_addr(uintptr_t addr) |
| 14 | { |
| 15 | return ((addr >= CONFIG_DCACHE_RAM_BASE) && |
| 16 | (addr < (CONFIG_DCACHE_RAM_BASE + CONFIG_DCACHE_RAM_SIZE))); |
| 17 | } |
| 18 | |
Aaron Durbin | faa74b0 | 2016-03-31 14:00:47 -0500 | [diff] [blame] | 19 | void platform_segment_loaded(uintptr_t start, size_t size, int flags) |
Aaron Durbin | 595688a | 2016-03-31 11:38:13 -0500 | [diff] [blame] | 20 | { |
Furquan Shaikh | 0b6ff78 | 2016-04-21 08:10:02 -0700 | [diff] [blame] | 21 | /* Bail out if this is not the final segment. */ |
| 22 | if (!(flags & SEG_FINAL)) |
| 23 | return; |
Aaron Durbin | faa74b0 | 2016-03-31 14:00:47 -0500 | [diff] [blame] | 24 | |
Furquan Shaikh | 0b6ff78 | 2016-04-21 08:10:02 -0700 | [diff] [blame] | 25 | char start_car_check = is_car_addr(start); |
| 26 | char end_car_check = is_car_addr(start + size - 1); |
| 27 | |
| 28 | /* Bail out if loaded program segment does not lie in CAR region. */ |
| 29 | if (!start_car_check && !end_car_check) |
| 30 | return; |
| 31 | |
| 32 | /* Loaded program segment should lie entirely within CAR region. */ |
Lee Leahy | d8fb362 | 2017-03-09 10:10:25 -0800 | [diff] [blame] | 33 | assert(start_car_check && end_car_check); |
Furquan Shaikh | 0b6ff78 | 2016-04-21 08:10:02 -0700 | [diff] [blame] | 34 | |
| 35 | flush_l1d_to_l2(); |
Aaron Durbin | 595688a | 2016-03-31 11:38:13 -0500 | [diff] [blame] | 36 | } |