1 /* SPDX-License-Identifier: GPL-2.0+ */
3 * Configuration for the SEI510
5 * Copyright (C) 2019 Baylibre, SAS
6 * Author: Jerome Brunet <jbrunet@baylibre.com>
12 #define CONFIG_SYS_MMC_ENV_DEV 2
13 #define CONFIG_SYS_MMC_ENV_PART 1
14 #define CONFIG_ENV_SIZE 0x10000
15 #define CONFIG_ENV_OFFSET (-0x10000)
17 #define LOGO_UUID "43a3305d-150f-4cc9-bd3b-38fca8693846;"
18 #define CACHE_UUID "99207ae6-5207-11e9-999e-6f77a3612069;"
19 #define SYSTEM_UUID "99f9b7ac-5207-11e9-8507-c3c037e393f3;"
20 #define VENDOR_UUID "9d082802-5207-11e9-954c-cbbce08ba108;"
21 #define USERDATA_UUID "9b976e42-5207-11e9-8f16-ff47ac594b22;"
22 #define ROOT_UUID "ddb8c3f6-d94d-4394-b633-3134139cc2e0;"
24 #define PARTS_DEFAULT \
25 "uuid_disk=${uuid_gpt_disk};" \
26 "name=boot,size=64M,bootable,uuid=${uuid_gpt_boot};" \
27 "name=logo,size=2M,uuid=" LOGO_UUID \
28 "name=cache,size=256M,uuid=" CACHE_UUID \
29 "name=system,size=1536M,uuid=" SYSTEM_UUID \
30 "name=vendor,size=256M,uuid=" VENDOR_UUID \
31 "name=userdata,size=4746M,uuid=" USERDATA_UUID \
32 "name=rootfs,size=-,uuid=" ROOT_UUID
34 #define BOOTENV_DEV_FASTBOOT(devtypeu, devtypel, instance) \
36 "sm reboot_reason reason;" \
37 "setenv run_fastboot 0;" \
38 "if gpt verify mmc ${mmcdev} ${partitions}; then; " \
40 "echo Broken MMC partition scheme;" \
41 "setenv run_fastboot 1;" \
43 "if test \"${reason}\" = \"bootloader\" -o " \
44 "\"${reason}\" = \"fastboot\"; then " \
45 "echo Fastboot asked by reboot reason;" \
46 "setenv run_fastboot 1;" \
48 "if test \"${skip_fastboot}\" -eq 1; then " \
49 "echo Fastboot skipped by environment;" \
50 "setenv run_fastboot 0;" \
52 "if test \"${force_fastboot}\" -eq 1; then " \
53 "echo Fastboot forced by environment;" \
54 "setenv run_fastboot 1;" \
56 "if test \"${run_fastboot}\" -eq 1; then " \
57 "echo Running Fastboot...;" \
61 #define BOOTENV_DEV_NAME_FASTBOOT(devtypeu, devtypel, instance) \
64 /* TOFIX: Run actual recovery instead of fastboot */
65 #define BOOTENV_DEV_RECOVERY(devtypeu, devtypel, instance) \
67 "pinmux dev pinctrl@14;" \
68 "pinmux dev pinctrl@40;" \
69 "sm reboot_reason reason;" \
70 "setenv run_recovery 0;" \
71 "if run check_button; then " \
72 "echo Recovery button is pressed;" \
73 "setenv run_recovery 1;" \
74 "elif test \"${reason}\" = \"recovery\" -o " \
75 "\"${reason}\" = \"update\"; then " \
76 "echo Recovery asked by reboot reason;" \
77 "setenv run_recovery 1;" \
79 "if test \"${skip_recovery}\" -eq 1; then " \
80 "echo Recovery skipped by environment;" \
81 "setenv run_recovery 0;" \
83 "if test \"${force_recovery}\" -eq 1; then " \
84 "echo Recovery forced by environment;" \
85 "setenv run_recovery 1;" \
87 "if test \"${run_recovery}\" -eq 1; then " \
88 "echo Running Recovery...;" \
92 #define BOOTENV_DEV_NAME_RECOVERY(devtypeu, devtypel, instance) \
95 #define BOOTENV_DEV_SYSTEM(devtypeu, devtypel, instance) \
97 "echo Loading Android boot partition...;" \
98 "mmc dev ${mmcdev};" \
99 "setenv bootargs ${bootargs} console=${console} androidboot.serialno=${serial#};" \
100 "part start mmc ${mmcdev} ${bootpart} boot_start;" \
101 "part size mmc ${mmcdev} ${bootpart} boot_size;" \
102 "if mmc read ${loadaddr} ${boot_start} ${boot_size}; then " \
103 "echo Running Android...;" \
104 "bootm ${loadaddr};" \
106 "echo Failed to boot Android...;" \
109 #define BOOTENV_DEV_NAME_SYSTEM(devtypeu, devtypel, instance) \
112 #define BOOT_TARGET_DEVICES(func) \
113 func(ROMUSB, romusb, na) \
114 func(FASTBOOT, fastboot, na) \
115 func(RECOVERY, recovery, na) \
116 func(SYSTEM, system, na) \
118 #define PREBOOT_LOAD_LOGO \
119 "mmc dev ${mmcdev};" \
120 "part start mmc ${mmcdev} ${logopart} boot_start;" \
121 "part size mmc ${mmcdev} ${logopart} boot_size;" \
122 "if mmc read ${loadaddr} ${boot_start} ${boot_size}; then " \
123 "bmp display ${loadaddr} m m;" \
126 #define CONFIG_EXTRA_ENV_SETTINGS \
127 "partitions=" PARTS_DEFAULT "\0" \
131 "gpio_recovery=88\0" \
132 "check_button=gpio input ${gpio_recovery};test $? -eq 0;\0" \
133 "load_logo=" PREBOOT_LOAD_LOGO "\0" \
134 "console=/dev/ttyAML0\0" \
135 "bootargs=no_console_suspend\0" \
136 "stdin=" STDIN_CFG "\0" \
137 "stdout=" STDOUT_CFG "\0" \
138 "stderr=" STDOUT_CFG "\0" \
139 "loadaddr=0x01000000\0" \
140 "fdt_addr_r=0x01000000\0" \
141 "scriptaddr=0x08000000\0" \
142 "kernel_addr_r=0x01080000\0" \
143 "pxefile_addr_r=0x01080000\0" \
144 "ramdisk_addr_r=0x13000000\0" \
145 "fdtfile=amlogic/" CONFIG_DEFAULT_DEVICE_TREE ".dtb\0" BOOTENV
147 #include <configs/meson64.h>
149 #endif /* __CONFIG_H */