xref: /rk3399_rockchip-uboot/cmd/load_android.c (revision 76e2a5a6c67043440fb0ea4942cde9b08e260a9d)
183a51ebaSAlex Deymo /*
2*76e2a5a6SAlex Deymo  * Copyright (C) 2016 The Android Open Source Project
383a51ebaSAlex Deymo  *
483a51ebaSAlex Deymo  * SPDX-License-Identifier: BSD-2-Clause
583a51ebaSAlex Deymo  */
683a51ebaSAlex Deymo 
783a51ebaSAlex Deymo #include <common.h>
883a51ebaSAlex Deymo #include <command.h>
983a51ebaSAlex Deymo 
do_load_android(cmd_tbl_t * cmdtp,int flag,int argc,char * const argv[])1083a51ebaSAlex Deymo static int do_load_android(cmd_tbl_t *cmdtp, int flag, int argc,
1183a51ebaSAlex Deymo 			   char * const argv[])
1283a51ebaSAlex Deymo {
1383a51ebaSAlex Deymo 	int boot_partition;
14*76e2a5a6SAlex Deymo 	unsigned long load_address;
1583a51ebaSAlex Deymo 	char *addr_arg_endp, *addr_str;
1683a51ebaSAlex Deymo 	struct blk_desc *dev_desc;
1783a51ebaSAlex Deymo 	disk_partition_t part_info;
1883a51ebaSAlex Deymo 
1983a51ebaSAlex Deymo 	if (argc < 2)
2083a51ebaSAlex Deymo 		return CMD_RET_USAGE;
2183a51ebaSAlex Deymo 	if (argc > 4)
2283a51ebaSAlex Deymo 		return CMD_RET_USAGE;
2383a51ebaSAlex Deymo 
2483a51ebaSAlex Deymo 	if (argc >= 4) {
2583a51ebaSAlex Deymo 		load_address = simple_strtoul(argv[3], &addr_arg_endp, 16);
2683a51ebaSAlex Deymo 		if (addr_arg_endp == argv[3] || *addr_arg_endp != '\0')
2783a51ebaSAlex Deymo 			return CMD_RET_USAGE;
2883a51ebaSAlex Deymo 	} else {
2983a51ebaSAlex Deymo 		addr_str = env_get("loadaddr");
3083a51ebaSAlex Deymo 		if (addr_str != NULL)
3183a51ebaSAlex Deymo 			load_address = simple_strtoul(addr_str, NULL, 16);
3283a51ebaSAlex Deymo 		else
3383a51ebaSAlex Deymo 			load_address = CONFIG_SYS_LOAD_ADDR;
3483a51ebaSAlex Deymo 	}
3583a51ebaSAlex Deymo 
3683a51ebaSAlex Deymo 	boot_partition = blk_get_device_part_str(argv[1],
3783a51ebaSAlex Deymo 						 (argc >= 3) ? argv[2] : NULL,
3883a51ebaSAlex Deymo 						 &dev_desc, &part_info, 1);
3983a51ebaSAlex Deymo 	if (boot_partition < 0)
4083a51ebaSAlex Deymo 		return CMD_RET_FAILURE;
4183a51ebaSAlex Deymo 
42*76e2a5a6SAlex Deymo 	if (android_image_load(dev_desc, &part_info, load_address, -1UL) < 0) {
43*76e2a5a6SAlex Deymo 		printf("Error loading Android Image from %s %d:%d to 0x%lx.\n",
44*76e2a5a6SAlex Deymo 		       argv[1], dev_desc->devnum, boot_partition, load_address);
45*76e2a5a6SAlex Deymo 		return CMD_RET_FAILURE;
46*76e2a5a6SAlex Deymo 	}
47*76e2a5a6SAlex Deymo 	return CMD_RET_SUCCESS;
4883a51ebaSAlex Deymo }
4983a51ebaSAlex Deymo 
5083a51ebaSAlex Deymo U_BOOT_CMD(
5183a51ebaSAlex Deymo 	load_android, 4, 0, do_load_android,
5283a51ebaSAlex Deymo 	"load Android Boot image from storage.",
5383a51ebaSAlex Deymo 	"<interface> [<dev[:part]> [<addr>]]\n"
5483a51ebaSAlex Deymo 	"    - Load a binary Android Boot image from the partition 'part' on\n"
5583a51ebaSAlex Deymo 	"      device type 'interface' instance 'dev' to address 'addr'."
5683a51ebaSAlex Deymo );
57