Merge https://gitlab.denx.de/u-boot/custodians/u-boot-imx
[platform/kernel/u-boot.git] / include / configs / meson64_android.h
1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * Configuration for Android Amlogic Meson 64bits SoCs
4  *
5  * Copyright (C) 2019 Baylibre, SAS
6  * Author: Jerome Brunet <jbrunet@baylibre.com>
7  */
8
9 #ifndef __MESON64_ANDROID_CONFIG_H
10 #define __MESON64_ANDROID_CONFIG_H
11
12
13 #define BOOTENV_DEV_FASTBOOT(devtypeu, devtypel, instance) \
14         "bootcmd_fastboot=" \
15                 "sm reboot_reason reason;" \
16                 "setenv run_fastboot 0;" \
17                 "if test \"${boot_source}\" = \"usb\"; then " \
18                         "echo Fastboot forced by usb rom boot;" \
19                         "setenv run_fastboot 1;" \
20                 "fi;" \
21                 "if gpt verify mmc ${mmcdev} ${partitions}; then; " \
22                 "else " \
23                         "echo Broken MMC partition scheme;" \
24                         "setenv run_fastboot 1;" \
25                 "fi;" \
26                 "if test \"${reason}\" = \"bootloader\" -o " \
27                         "\"${reason}\" = \"fastboot\"; then " \
28                         "echo Fastboot asked by reboot reason;" \
29                         "setenv run_fastboot 1;" \
30                 "fi;" \
31                 "if test \"${skip_fastboot}\" -eq 1; then " \
32                         "echo Fastboot skipped by environment;" \
33                         "setenv run_fastboot 0;" \
34                 "fi;" \
35                 "if test \"${force_fastboot}\" -eq 1; then " \
36                         "echo Fastboot forced by environment;" \
37                         "setenv run_fastboot 1;" \
38                 "fi;" \
39                 "if test \"${run_fastboot}\" -eq 1; then " \
40                         "echo Running Fastboot...;" \
41                         "fastboot 0;" \
42                 "fi\0"
43
44 #define BOOTENV_DEV_NAME_FASTBOOT(devtypeu, devtypel, instance) \
45                 "fastboot "
46
47 /* TOFIX: Run actual recovery instead of fastboot */
48 #define BOOTENV_DEV_RECOVERY(devtypeu, devtypel, instance) \
49         "bootcmd_recovery=" \
50                 "pinmux dev pinctrl@14;" \
51                 "pinmux dev pinctrl@40;" \
52                 "sm reboot_reason reason;" \
53                 "setenv run_recovery 0;" \
54                 "if run check_button; then " \
55                         "echo Recovery button is pressed;" \
56                         "setenv run_recovery 1;" \
57                 "elif test \"${reason}\" = \"recovery\" -o " \
58                           "\"${reason}\" = \"update\"; then " \
59                         "echo Recovery asked by reboot reason;" \
60                         "setenv run_recovery 1;" \
61                 "fi;" \
62                 "if test \"${skip_recovery}\" -eq 1; then " \
63                         "echo Recovery skipped by environment;" \
64                         "setenv run_recovery 0;" \
65                 "fi;" \
66                 "if test \"${force_recovery}\" -eq 1; then " \
67                         "echo Recovery forced by environment;" \
68                         "setenv run_recovery 1;" \
69                 "fi;" \
70                 "if test \"${run_recovery}\" -eq 1; then " \
71                         "echo Running Recovery...;" \
72                         "fastboot 0;" \
73                 "fi\0"
74
75 #define BOOTENV_DEV_NAME_RECOVERY(devtypeu, devtypel, instance) \
76                 "recovery "
77
78 #define BOOTENV_DEV_SYSTEM(devtypeu, devtypel, instance) \
79         "bootcmd_system=" \
80                 "echo Loading Android boot partition...;" \
81                 "mmc dev ${mmcdev};" \
82                 "setenv bootargs ${bootargs} console=${console} androidboot.serialno=${serial#};" \
83                 "part start mmc ${mmcdev} ${bootpart} boot_start;" \
84                 "part size mmc ${mmcdev} ${bootpart} boot_size;" \
85                 "if mmc read ${loadaddr} ${boot_start} ${boot_size}; then " \
86                         "echo Running Android...;" \
87                         "bootm ${loadaddr};" \
88                 "fi;" \
89                 "echo Failed to boot Android...;" \
90                 "reset\0"
91
92 #define BOOTENV_DEV_NAME_SYSTEM(devtypeu, devtypel, instance)   \
93                 "system "
94
95 #define BOOT_TARGET_DEVICES(func) \
96         func(FASTBOOT, fastboot, na) \
97         func(RECOVERY, recovery, na) \
98         func(SYSTEM, system, na) \
99
100 #define PREBOOT_LOAD_LOGO \
101         "if test \"${boot_source}\" != \"usb\" && " \
102                 "gpt verify mmc ${mmcdev} ${partitions}; then; " \
103                 "mmc dev ${mmcdev};" \
104                 "part start mmc ${mmcdev} ${logopart} boot_start;" \
105                 "part size mmc ${mmcdev} ${logopart} boot_size;" \
106                 "if mmc read ${loadaddr} ${boot_start} ${boot_size}; then " \
107                         "bmp display ${loadaddr} m m;" \
108                 "fi;" \
109         "fi;"
110
111 #define CONFIG_EXTRA_ENV_SETTINGS                                     \
112         "partitions=" PARTS_DEFAULT "\0"                              \
113         "mmcdev=2\0"                                                  \
114         "bootpart=1\0"                                                \
115         "logopart=2\0"                                                \
116         "gpio_recovery=88\0"                                          \
117         "check_button=gpio input ${gpio_recovery};test $? -eq 0;\0"   \
118         "load_logo=" PREBOOT_LOAD_LOGO "\0"                           \
119         "console=/dev/ttyAML0\0"                                      \
120         "bootargs=no_console_suspend\0"                               \
121         "stdin=" STDIN_CFG "\0"                                       \
122         "stdout=" STDOUT_CFG "\0"                                     \
123         "stderr=" STDOUT_CFG "\0"                                     \
124         "loadaddr=0x01000000\0"                                       \
125         "fdt_addr_r=0x01000000\0"                                     \
126         "scriptaddr=0x08000000\0"                                     \
127         "kernel_addr_r=0x01080000\0"                                  \
128         "pxefile_addr_r=0x01080000\0"                                 \
129         "ramdisk_addr_r=0x13000000\0"                                 \
130         "fdtfile=amlogic/" CONFIG_DEFAULT_DEVICE_TREE ".dtb\0" BOOTENV
131
132 #include <configs/meson64.h>
133
134 #endif /* __MESON64_ANDROID_CONFIG_H */