~funderscore blog cgit wiki get in touch
aboutsummaryrefslogtreecommitdiff
blob: 2d2c71ad4c495996015de0c792c7063a73a8516a (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
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Copyright (C) 2018 MediaTek Inc.
 */

#ifndef __PRELOADER_H_
#define __PRELOADER_H_

enum forbidden_mode {
	F_FACTORY_MODE = 0x0001
};

union lk_hdr {
	struct {
		u32 magic;
		u32 size;
		char name[32];
		u32 loadaddr;
	};

	u8 data[512];
};

struct sec_limit {
	unsigned int magic_num;
	enum forbidden_mode forbid_mode;
};

enum bootmode {
	NORMAL_BOOT = 0,
	META_BOOT = 1,
	RECOVERY_BOOT = 2,
	SW_REBOOT = 3,
	FACTORY_BOOT = 4,
	ADVMETA_BOOT = 5,
	ATE_FACTORY_BOOT = 6,
	ALARM_BOOT = 7,

	KERNEL_POWER_OFF_CHARGING_BOOT = 8,
	LOW_POWER_OFF_CHARGING_BOOT = 9,

	FAST_BOOT = 99,
	DOWNLOAD_BOOT = 100,
	UNKNOWN_BOOT
};

enum boot_reason {
	BR_POWER_KEY = 0,
	BR_USB,
	BR_RTC,
	BR_WDT,
	BR_WDT_BY_PASS_PWK,
	BR_TOOL_BY_PASS_PWK,
	BR_2SEC_REBOOT,
	BR_UNKNOWN
};

enum meta_com_type {
	META_UNKNOWN_COM = 0,
	META_UART_COM,
	META_USB_COM
};

struct da_info_t {
	u32 addr;
	u32 arg1;
	u32 arg2;
	u32 len;
	u32 sig_len;
};

struct boot_argument {
	u32 magic;
	enum bootmode boot_mode;
	u32 e_flag;
	u32 log_port;
	u32 log_baudrate;
	u8 log_enable;
	u8 part_num;
	u8 reserved[2];
	u32 dram_rank_num;
	u32 dram_rank_size[4];
	u32 boot_reason;
	enum meta_com_type meta_com_type;
	u32 meta_com_id;
	u32 boot_time;
	struct da_info_t da_info;
	struct sec_limit sec_limit;
	union lk_hdr *part_info;
	u8 md_type[4];
	u32 ddr_reserve_enable;
	u32 ddr_reserve_success;
	u32 chip_ver;
	char pl_version[8];
};

#define BOOT_ARGUMENT_MAGIC	0x504c504c

#endif /* __PRELOADER_H_ */