1 /* SPDX-License-Identifier: GPL-2.0+ */ 2 /* 3 * (C) Copyright 2014 - 2015 Xilinx, Inc. 4 * Michal Simek <michal.simek@xilinx.com> 5 */ 6 7 #ifndef _ASM_ARCH_SYS_PROTO_H 8 #define _ASM_ARCH_SYS_PROTO_H 9 10 #define PAYLOAD_ARG_CNT 5 11 12 #define ZYNQMP_CSU_SILICON_VER_MASK 0xF 13 #define ZYNQMP_SIP_SVC_PM_SECURE_IMG_LOAD 0xC200002D 14 #define KEY_PTR_LEN 32 15 16 #define ZYNQMP_FPGA_BIT_AUTH_DDR 1 17 #define ZYNQMP_FPGA_BIT_AUTH_OCM 2 18 #define ZYNQMP_FPGA_BIT_ENC_USR_KEY 3 19 #define ZYNQMP_FPGA_BIT_ENC_DEV_KEY 4 20 #define ZYNQMP_FPGA_BIT_NS 5 21 22 #define ZYNQMP_FPGA_AUTH_DDR 1 23 24 enum { 25 IDCODE, 26 VERSION, 27 IDCODE2, 28 }; 29 30 enum { 31 ZYNQMP_SILICON_V1, 32 ZYNQMP_SILICON_V2, 33 ZYNQMP_SILICON_V3, 34 ZYNQMP_SILICON_V4, 35 }; 36 37 enum { 38 TCM_LOCK, 39 TCM_SPLIT, 40 }; 41 42 int zynq_board_read_rom_ethaddr(unsigned char *ethaddr); 43 unsigned int zynqmp_get_silicon_version(void); 44 45 void handoff_setup(void); 46 47 void zynqmp_pmufw_version(void); 48 int zynqmp_mmio_write(const u32 address, const u32 mask, const u32 value); 49 int zynqmp_mmio_read(const u32 address, u32 *value); 50 int invoke_smc(u32 pm_api_id, u32 arg0, u32 arg1, u32 arg2, u32 arg3, 51 u32 *ret_payload); 52 53 void initialize_tcm(bool mode); 54 void mem_map_fill(void); 55 int chip_id(unsigned char id); 56 57 #endif /* _ASM_ARCH_SYS_PROTO_H */ 58