Lokesh Vutla | c1e60e8 | 2018-11-02 19:51:03 +0530 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
| 2 | /* |
| 3 | * K3: Architecture common definitions |
| 4 | * |
Manorit Chawdhry | 53dde1a | 2024-05-21 16:26:45 +0530 | [diff] [blame] | 5 | * Copyright (C) 2018-2024 Texas Instruments Incorporated - https://www.ti.com/ |
Lokesh Vutla | c1e60e8 | 2018-11-02 19:51:03 +0530 | [diff] [blame] | 6 | * Lokesh Vutla <lokeshvutla@ti.com> |
| 7 | */ |
| 8 | |
| 9 | #include <asm/armv7_mpu.h> |
Lokesh Vutla | 8be6bbf | 2020-08-05 22:44:23 +0530 | [diff] [blame] | 10 | #include <asm/hardware.h> |
Manorit Chawdhry | 53dde1a | 2024-05-21 16:26:45 +0530 | [diff] [blame] | 11 | #include <mach/security.h> |
Lokesh Vutla | c1e60e8 | 2018-11-02 19:51:03 +0530 | [diff] [blame] | 12 | |
Manorit Chawdhry | a2cfec4 | 2023-07-14 11:22:27 +0530 | [diff] [blame] | 13 | #define K3_FIREWALL_BACKGROUND_BIT (8) |
Manorit Chawdhry | 33f75ee | 2023-05-05 15:54:00 +0530 | [diff] [blame] | 14 | |
Andrew F. Davis | f0bcb66 | 2020-01-10 14:35:21 -0500 | [diff] [blame] | 15 | struct fwl_data { |
| 16 | const char *name; |
| 17 | u16 fwl_id; |
| 18 | u16 regions; |
| 19 | }; |
| 20 | |
Manorit Chawdhry | 33f75ee | 2023-05-05 15:54:00 +0530 | [diff] [blame] | 21 | enum k3_firewall_region_type { |
| 22 | K3_FIREWALL_REGION_FOREGROUND, |
| 23 | K3_FIREWALL_REGION_BACKGROUND |
| 24 | }; |
| 25 | |
Andrew Davis | f8c9836 | 2022-07-15 11:34:32 -0500 | [diff] [blame] | 26 | enum k3_device_type { |
| 27 | K3_DEVICE_TYPE_BAD, |
| 28 | K3_DEVICE_TYPE_GP, |
| 29 | K3_DEVICE_TYPE_TEST, |
| 30 | K3_DEVICE_TYPE_EMU, |
| 31 | K3_DEVICE_TYPE_HS_FS, |
| 32 | K3_DEVICE_TYPE_HS_SE, |
| 33 | }; |
| 34 | |
Lokesh Vutla | c1e60e8 | 2018-11-02 19:51:03 +0530 | [diff] [blame] | 35 | void setup_k3_mpu_regions(void); |
Andreas Dannenberg | d13ec8c | 2019-08-15 15:55:28 -0500 | [diff] [blame] | 36 | int early_console_init(void); |
Lokesh Vutla | 5fbd6fe | 2019-12-31 15:49:55 +0530 | [diff] [blame] | 37 | void disable_linefill_optimization(void); |
Andrew F. Davis | f0bcb66 | 2020-01-10 14:35:21 -0500 | [diff] [blame] | 38 | void remove_fwl_configs(struct fwl_data *fwl_data, size_t fwl_data_size); |
Keerthy | 7007adc | 2020-02-12 13:55:04 +0530 | [diff] [blame] | 39 | int load_firmware(char *name_fw, char *name_loadaddr, u32 *loadaddr); |
Lokesh Vutla | 5fafe44 | 2020-03-10 16:50:58 +0530 | [diff] [blame] | 40 | void k3_sysfw_print_ver(void); |
Joao Paulo Goncalves | fc3557f | 2023-11-13 16:07:21 -0300 | [diff] [blame] | 41 | void spl_enable_cache(void); |
Matthias Schiffer | 0262dcd | 2023-09-27 15:43:14 +0200 | [diff] [blame] | 42 | void mmr_unlock(uintptr_t base, u32 partition); |
Lokesh Vutla | 8be6bbf | 2020-08-05 22:44:23 +0530 | [diff] [blame] | 43 | bool is_rom_loaded_sysfw(struct rom_extended_boot_data *data); |
Andrew Davis | f8c9836 | 2022-07-15 11:34:32 -0500 | [diff] [blame] | 44 | enum k3_device_type get_device_type(void); |
Andrew Davis | 2dde9a7 | 2023-04-06 11:38:17 -0500 | [diff] [blame] | 45 | struct ti_sci_handle *get_ti_sci_handle(void); |
| 46 | void do_board_detect(void); |
Manorit Chawdhry | db01bcc | 2023-05-18 12:44:17 +0530 | [diff] [blame] | 47 | void ti_secure_image_check_binary(void **p_image, size_t *p_size); |
Aradhya Bhatia | 5b09538 | 2024-02-12 15:36:35 +0530 | [diff] [blame] | 48 | |
| 49 | #if (IS_ENABLED(CONFIG_K3_QOS)) |
| 50 | void setup_qos(void); |
| 51 | #else |
| 52 | static inline void setup_qos(void) |
| 53 | { |
| 54 | } |
| 55 | #endif |