summaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-nexell/cmd_boot_linux.c
blob: 9b38d38ddb5b323784dc4b03294319dd772a7bca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
// SPDX-License-Identifier: GPL-2.0+
/*
 * (C) Copyright 2016 nexell
 * jhkim <jhkim@nexell.co.kr>
 */

#include <common.h>
#include <bootm.h>
#include <command.h>
#include <environment.h>
#include <errno.h>
#include <image.h>
#include <fdt_support.h>
#include <asm/global_data.h>

#if !defined(CONFIG_SPL_BUILD) || defined(CONFIG_SPL_CLI_FRAMEWORK)

DECLARE_GLOBAL_DATA_PTR;

static bootm_headers_t linux_images;

static void boot_go_set_os(cmd_tbl_t *cmdtp, int flag, int argc,
			   char * const argv[],
			   bootm_headers_t *images)
{
	char * const img_addr = argv[0];

	images->os.type = IH_TYPE_KERNEL;
	images->os.comp = IH_COMP_NONE;
	images->os.os = IH_OS_LINUX;
	images->os.load = simple_strtoul(img_addr, NULL, 16);
	images->ep = images->os.load;
#if defined(CONFIG_ARM)
	images->os.arch = IH_ARCH_ARM;
#elif defined(CONFIG_ARM64)
	images->os.arch = IH_ARCH_ARM64;
#else
	#error "Not support architecture ..."
#endif
	if (!IS_ENABLED(CONFIG_OF_LIBFDT) && !IS_ENABLED(CONFIG_SPL_BUILD)) {
		/* set DTB address for linux kernel */
		if (argc > 2) {
			unsigned long ft_addr;

			ft_addr = simple_strtol(argv[2], NULL, 16);
			images->ft_addr = (char *)ft_addr;

			/*
			 * if not defined IMAGE_ENABLE_OF_LIBFDT,
			 * must be set to fdt address
			 */
			if (!IMAGE_ENABLE_OF_LIBFDT)
				gd->bd->bi_boot_params = ft_addr;

			debug("## set ft:%08lx and boot params:%08lx [control of:%s]"
			      "...\n", ft_addr, gd->bd->bi_boot_params,
			      IMAGE_ENABLE_OF_LIBFDT ? "on" : "off");
		}
	}
}

#if defined(CONFIG_OF_LIBFDT) && defined(CONFIG_LMB)
static void boot_start_lmb(bootm_headers_t *images)
{
	ulong		mem_start;
	phys_size_t	mem_size;

	lmb_init(&images->lmb);

	mem_start = getenv_bootm_low();
	mem_size = getenv_bootm_size();

	lmb_add(&images->lmb, (phys_addr_t)mem_start, mem_size);

	arch_lmb_reserve(&images->lmb);
	board_lmb_reserve(&images->lmb);
}
#else
#define lmb_reserve(lmb, base, size)
static inline void boot_start_lmb(bootm_headers_t *images) { }
#endif

int do_boot_linux(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
	boot_os_fn *boot_fn;
	bootm_headers_t *images = &linux_images;
	int flags;
	int ret;

	boot_start_lmb(images);

	flags  = BOOTM_STATE_START;

	argc--; argv++;
	boot_go_set_os(cmdtp, flag, argc, argv, images);

	if (IS_ENABLED(CONFIG_OF_LIBFDT)) {
		/* find flattened device tree */
		ret = boot_get_fdt(flag, argc, argv, IH_ARCH_DEFAULT, images,
				   &images->ft_addr, &images->ft_len);
		if (ret) {
			puts("Could not find a valid device tree\n");
			return 1;
		}
		set_working_fdt_addr((ulong)images->ft_addr);
	}

	if (!IS_ENABLED(CONFIG_OF_LIBFDT))
		flags |= BOOTM_STATE_OS_GO;

	boot_fn = do_bootm_linux;
	ret = boot_fn(flags, argc, argv, images);

	if (ret == BOOTM_ERR_UNIMPLEMENTED)
		show_boot_progress(BOOTSTAGE_ID_DECOMP_UNIMPL);
	else if (ret == BOOTM_ERR_RESET)
		do_reset(cmdtp, flag, argc, argv);

	return ret;
}

U_BOOT_CMD(bootl, CONFIG_SYS_MAXARGS, 1, do_boot_linux,
	   "boot linux image from memory",
	   "[addr [arg ...]]\n    - boot linux image stored in memory\n"
	   "\tuse a '-' for the DTB address\n"
);
#endif

#if defined(CONFIG_CMD_BOOTD) && !defined(CONFIG_CMD_BOOTM)
int do_bootd(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
	return run_command(env_get("bootcmd"), flag);
}

U_BOOT_CMD(boot, 1, 1, do_bootd,
	   "boot default, i.e., run 'bootcmd'",
	   ""
);

/* keep old command name "bootd" for backward compatibility */
U_BOOT_CMD(bootd, 1,	1,	do_bootd,
	   "boot default, i.e., run 'bootcmd'",
	   ""
);
#endif