mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-18 18:59:44 +00:00
37e3a36a54
This patch basically adds two new commands for loadig secure images. 1. zynq rsa adds support to load secure image which can be both authenticated or encrypted or both authenticated and encrypted image in xilinx bootimage(BOOT.bin) format. 2. zynq aes command adds support to decrypt and load encrypted image back to DDR as per destination address. The image has to be encrypted using xilinx bootgen tool and to get only the encrypted image from tool use -split option while invoking bootgen. Signed-off-by: Siva Durga Prasad Paladugu <siva.durga.paladugu@xilinx.com> Signed-off-by: Michal Simek <michal.simek@xilinx.com>
68 lines
1.8 KiB
C
68 lines
1.8 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* (C) Copyright 2012-2013, Xilinx, Michal Simek
|
|
*
|
|
* (C) Copyright 2012
|
|
* Joe Hershberger <joe.hershberger@ni.com>
|
|
*/
|
|
|
|
#ifndef _ZYNQPL_H_
|
|
#define _ZYNQPL_H_
|
|
|
|
#include <xilinx.h>
|
|
|
|
#ifdef CONFIG_CMD_ZYNQ_AES
|
|
int zynq_decrypt_load(u32 srcaddr, u32 dstaddr, u32 srclen, u32 dstlen);
|
|
#endif
|
|
|
|
extern struct xilinx_fpga_op zynq_op;
|
|
|
|
#define XILINX_ZYNQ_XC7Z007S 0x3
|
|
#define XILINX_ZYNQ_XC7Z010 0x2
|
|
#define XILINX_ZYNQ_XC7Z012S 0x1c
|
|
#define XILINX_ZYNQ_XC7Z014S 0x8
|
|
#define XILINX_ZYNQ_XC7Z015 0x1b
|
|
#define XILINX_ZYNQ_XC7Z020 0x7
|
|
#define XILINX_ZYNQ_XC7Z030 0xc
|
|
#define XILINX_ZYNQ_XC7Z035 0x12
|
|
#define XILINX_ZYNQ_XC7Z045 0x11
|
|
#define XILINX_ZYNQ_XC7Z100 0x16
|
|
|
|
/* Device Image Sizes */
|
|
#define XILINX_XC7Z007S_SIZE 16669920/8
|
|
#define XILINX_XC7Z010_SIZE 16669920/8
|
|
#define XILINX_XC7Z012S_SIZE 28085344/8
|
|
#define XILINX_XC7Z014S_SIZE 32364512/8
|
|
#define XILINX_XC7Z015_SIZE 28085344/8
|
|
#define XILINX_XC7Z020_SIZE 32364512/8
|
|
#define XILINX_XC7Z030_SIZE 47839328/8
|
|
#define XILINX_XC7Z035_SIZE 106571232/8
|
|
#define XILINX_XC7Z045_SIZE 106571232/8
|
|
#define XILINX_XC7Z100_SIZE 139330784/8
|
|
|
|
/* Device Names */
|
|
#define XILINX_XC7Z007S_NAME "7z007s"
|
|
#define XILINX_XC7Z010_NAME "7z010"
|
|
#define XILINX_XC7Z012S_NAME "7z012s"
|
|
#define XILINX_XC7Z014S_NAME "7z014s"
|
|
#define XILINX_XC7Z015_NAME "7z015"
|
|
#define XILINX_XC7Z020_NAME "7z020"
|
|
#define XILINX_XC7Z030_NAME "7z030"
|
|
#define XILINX_XC7Z035_NAME "7z035"
|
|
#define XILINX_XC7Z045_NAME "7z045"
|
|
#define XILINX_XC7Z100_NAME "7z100"
|
|
|
|
#if defined(CONFIG_FPGA)
|
|
#define ZYNQ_DESC(name) { \
|
|
.idcode = XILINX_ZYNQ_XC##name, \
|
|
.fpga_size = XILINX_XC##name##_SIZE, \
|
|
.devicename = XILINX_XC##name##_NAME \
|
|
}
|
|
#else
|
|
#define ZYNQ_DESC(name) { \
|
|
.idcode = XILINX_ZYNQ_XC##name, \
|
|
.devicename = XILINX_XC##name##_NAME \
|
|
}
|
|
#endif
|
|
|
|
#endif /* _ZYNQPL_H_ */
|