/* SPDX-License-Identifier: GPL-2.0+ */ /* * K3: Architecture common definitions * * Copyright (C) 2018 Texas Instruments Incorporated - https://www.ti.com/ * Lokesh Vutla */ #include #include #define K3_FIREWALL_BACKGROUND_BIT (8) struct fwl_data { const char *name; u16 fwl_id; u16 regions; }; enum k3_firewall_region_type { K3_FIREWALL_REGION_FOREGROUND, K3_FIREWALL_REGION_BACKGROUND }; 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, }; void setup_k3_mpu_regions(void); int early_console_init(void); void disable_linefill_optimization(void); void remove_fwl_configs(struct fwl_data *fwl_data, size_t fwl_data_size); int load_firmware(char *name_fw, char *name_loadaddr, u32 *loadaddr); void k3_sysfw_print_ver(void); void spl_enable_cache(void); void mmr_unlock(uintptr_t base, u32 partition); bool is_rom_loaded_sysfw(struct rom_extended_boot_data *data); enum k3_device_type get_device_type(void); void ti_secure_image_post_process(void **p_image, size_t *p_size); struct ti_sci_handle *get_ti_sci_handle(void); void do_board_detect(void); void ti_secure_image_check_binary(void **p_image, size_t *p_size);