2018-11-02 14:21:03 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
|
|
/*
|
|
|
|
* K3: Architecture common definitions
|
|
|
|
*
|
2023-11-01 20:56:03 +00:00
|
|
|
* Copyright (C) 2018 Texas Instruments Incorporated - https://www.ti.com/
|
2018-11-02 14:21:03 +00:00
|
|
|
* Lokesh Vutla <lokeshvutla@ti.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <asm/armv7_mpu.h>
|
2020-08-05 17:14:23 +00:00
|
|
|
#include <asm/hardware.h>
|
2018-11-02 14:21:03 +00:00
|
|
|
|
2023-07-14 05:52:27 +00:00
|
|
|
#define K3_FIREWALL_BACKGROUND_BIT (8)
|
2023-05-05 10:24:00 +00:00
|
|
|
|
2020-01-10 19:35:21 +00:00
|
|
|
struct fwl_data {
|
|
|
|
const char *name;
|
|
|
|
u16 fwl_id;
|
|
|
|
u16 regions;
|
|
|
|
};
|
|
|
|
|
2023-05-05 10:24:00 +00:00
|
|
|
enum k3_firewall_region_type {
|
|
|
|
K3_FIREWALL_REGION_FOREGROUND,
|
|
|
|
K3_FIREWALL_REGION_BACKGROUND
|
|
|
|
};
|
|
|
|
|
2022-07-15 16:34:32 +00:00
|
|
|
enum k3_device_type {
|
|
|
|
K3_DEVICE_TYPE_BAD,
|
|
|
|
K3_DEVICE_TYPE_GP,
|
|
|
|
K3_DEVICE_TYPE_TEST,
|
|
|
|
K3_DEVICE_TYPE_EMU,
|
|
|
|
K3_DEVICE_TYPE_HS_FS,
|
|
|
|
K3_DEVICE_TYPE_HS_SE,
|
|
|
|
};
|
|
|
|
|
2018-11-02 14:21:03 +00:00
|
|
|
void setup_k3_mpu_regions(void);
|
2019-08-15 20:55:28 +00:00
|
|
|
int early_console_init(void);
|
2019-12-31 10:19:55 +00:00
|
|
|
void disable_linefill_optimization(void);
|
2020-01-10 19:35:21 +00:00
|
|
|
void remove_fwl_configs(struct fwl_data *fwl_data, size_t fwl_data_size);
|
2020-02-12 08:25:04 +00:00
|
|
|
int load_firmware(char *name_fw, char *name_loadaddr, u32 *loadaddr);
|
2020-03-10 11:20:58 +00:00
|
|
|
void k3_sysfw_print_ver(void);
|
2023-11-13 19:07:21 +00:00
|
|
|
void spl_enable_cache(void);
|
2023-09-27 13:43:14 +00:00
|
|
|
void mmr_unlock(uintptr_t base, u32 partition);
|
2020-08-05 17:14:23 +00:00
|
|
|
bool is_rom_loaded_sysfw(struct rom_extended_boot_data *data);
|
2022-07-15 16:34:32 +00:00
|
|
|
enum k3_device_type get_device_type(void);
|
2021-06-11 08:45:19 +00:00
|
|
|
void ti_secure_image_post_process(void **p_image, size_t *p_size);
|
2023-04-06 16:38:17 +00:00
|
|
|
struct ti_sci_handle *get_ti_sci_handle(void);
|
|
|
|
void do_board_detect(void);
|
2023-05-18 07:14:17 +00:00
|
|
|
void ti_secure_image_check_binary(void **p_image, size_t *p_size);
|