2018-05-06 17:58:06 -04:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
2015-01-15 10:01:51 +01:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2014 - 2015 Xilinx, Inc.
|
|
|
|
* Michal Simek <michal.simek@xilinx.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ASM_ARCH_SYS_PROTO_H
|
|
|
|
#define _ASM_ARCH_SYS_PROTO_H
|
|
|
|
|
2017-07-25 11:51:36 +05:30
|
|
|
#define ZYNQMP_CSU_SILICON_VER_MASK 0xF
|
2018-02-28 13:26:53 +05:30
|
|
|
#define KEY_PTR_LEN 32
|
2018-09-06 16:34:44 +05:30
|
|
|
#define IV_SIZE 12
|
2019-01-07 17:05:10 +05:30
|
|
|
#define RSA_KEY_SIZE 512
|
|
|
|
#define MODULUS_LEN 512
|
|
|
|
#define PRIV_EXPO_LEN 512
|
|
|
|
#define PUB_EXPO_LEN 4
|
2017-07-25 11:51:36 +05:30
|
|
|
|
2019-01-07 17:05:11 +05:30
|
|
|
#define ZYNQMP_SHA3_INIT 1
|
|
|
|
#define ZYNQMP_SHA3_UPDATE 2
|
|
|
|
#define ZYNQMP_SHA3_FINAL 4
|
|
|
|
#define ZYNQMP_SHA3_SIZE 48
|
|
|
|
|
2018-05-31 15:10:23 +05:30
|
|
|
#define ZYNQMP_FPGA_BIT_AUTH_DDR 1
|
|
|
|
#define ZYNQMP_FPGA_BIT_AUTH_OCM 2
|
|
|
|
#define ZYNQMP_FPGA_BIT_ENC_USR_KEY 3
|
|
|
|
#define ZYNQMP_FPGA_BIT_ENC_DEV_KEY 4
|
2018-03-01 17:44:47 +05:30
|
|
|
#define ZYNQMP_FPGA_BIT_NS 5
|
|
|
|
|
2018-05-31 15:10:23 +05:30
|
|
|
#define ZYNQMP_FPGA_AUTH_DDR 1
|
|
|
|
|
2017-07-25 11:51:36 +05:30
|
|
|
enum {
|
|
|
|
IDCODE,
|
|
|
|
VERSION,
|
2017-08-22 14:58:53 +02:00
|
|
|
IDCODE2,
|
2017-07-25 11:51:36 +05:30
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
ZYNQMP_SILICON_V1,
|
|
|
|
ZYNQMP_SILICON_V2,
|
|
|
|
ZYNQMP_SILICON_V3,
|
|
|
|
ZYNQMP_SILICON_V4,
|
|
|
|
};
|
|
|
|
|
2017-07-13 19:01:09 +05:30
|
|
|
enum {
|
|
|
|
TCM_LOCK,
|
|
|
|
TCM_SPLIT,
|
|
|
|
};
|
|
|
|
|
2019-09-27 11:36:56 +01:00
|
|
|
struct zynqmp_ipi_msg {
|
|
|
|
size_t len;
|
|
|
|
u32 *buf;
|
|
|
|
};
|
|
|
|
|
2017-07-31 10:37:09 +02:00
|
|
|
int zynq_board_read_rom_ethaddr(unsigned char *ethaddr);
|
2015-01-15 10:01:51 +01:00
|
|
|
unsigned int zynqmp_get_silicon_version(void);
|
|
|
|
|
2017-02-02 01:10:46 +05:30
|
|
|
int zynqmp_mmio_write(const u32 address, const u32 mask, const u32 value);
|
|
|
|
int zynqmp_mmio_read(const u32 address, u32 *value);
|
|
|
|
|
2017-07-13 19:01:09 +05:30
|
|
|
void initialize_tcm(bool mode);
|
2018-04-20 12:30:40 +05:30
|
|
|
void mem_map_fill(void);
|
2018-10-05 15:09:05 +05:30
|
|
|
#if defined(CONFIG_SYS_MEM_RSVD_FOR_MMU) || defined(CONFIG_DEFINE_TCM_OCM_MMAP)
|
|
|
|
void tcm_init(u8 mode);
|
|
|
|
#endif
|
2017-07-25 11:51:38 +05:30
|
|
|
|
2015-01-15 10:01:51 +01:00
|
|
|
#endif /* _ASM_ARCH_SYS_PROTO_H */
|