1 /*
2  * Copyright (C) 2016 Stefan Roese <sr@denx.de>
3  *
4  * SPDX-License-Identifier:	GPL-2.0+
5  */
6 
7 /*
8  * Common options, macros and default environment for all
9  * theadorable x86 based boards
10  */
11 
12 #ifndef __THEADORABLE_X86_COMMON_H
13 #define __THEADORABLE_X86_COMMON_H
14 
15 #define CONFIG_SYS_MONITOR_LEN		(1 << 20)
16 
17 #define CONFIG_PREBOOT
18 
19 #define CONFIG_STD_DEVICES_SETTINGS     "stdin=serial\0" \
20 					"stdout=serial\0" \
21 					"stderr=serial\0"
22 
23 #define CONFIG_USB_ETHER_ASIX
24 #define CONFIG_USB_ETHER_SMSC95XX
25 #define CONFIG_USB_ETHER_MCS7830
26 #define CONFIG_USB_ETHER_RTL8152
27 
28 #define VIDEO_IO_OFFSET				0
29 #define CONFIG_X86EMU_RAW_IO
30 #define CONFIG_CMD_BMP
31 #define CONFIG_BMP_16BPP
32 
33 /* Environment settings */
34 #define CONFIG_SYS_REDUNDAND_ENVIRONMENT
35 #undef CONFIG_ENV_SIZE
36 #define CONFIG_ENV_SIZE			0x2000
37 #define CONFIG_ENV_SECT_SIZE		0x1000
38 #define CONFIG_ENV_OFFSET		0x006ec000
39 #define CONFIG_ENV_OFFSET_REDUND	\
40 	(CONFIG_ENV_OFFSET + CONFIG_ENV_SIZE)
41 
42 #undef CONFIG_BOOTCOMMAND
43 #undef CONFIG_EXTRA_ENV_SETTINGS
44 
45 #define CONFIG_EXTRA_ENV_SETTINGS				\
46 	"tftpdir=" DEF_ENV_TFTPDIR "\0"				\
47 	"eth_init=" DEF_ENV_ETH_INIT "\0"			\
48 	"ubuntu_part=" __stringify(DEF_ENV_UBUNTU_PART) "\0"	\
49 	"yocto_part=" __stringify(DEF_ENV_YOCTO_PART) "\0"	\
50 	"ubuntu_tty=" __stringify(DEF_ENV_UBUNTU_TTY) "\0"	\
51 	"yocto_tty=" __stringify(DEF_ENV_YOCTO_TTY) "\0"	\
52 	"start_eth=if test -n \"${eth_init}\";"			\
53 		"then run eth_init;else sleep 0;fi\0"		\
54 	"kernel-ver=4.8.0-54\0"					\
55 	"boot=zboot 03000000 0 04000000 ${filesize}\0"		\
56 	"mtdparts=mtdparts=intel-spi:4k(descriptor),7084k(me)," \
57 		"8k(env1),8k(env2),64k(mrc),640k(u-boot),"	\
58 		"64k(vga),-(fsp)\0"				\
59 	"addtty_ubuntu=setenv bootargs ${bootargs} "		\
60 		"console=ttyS${ubuntu_tty},${baudrate}\0"	\
61 	"addtty_yocto=setenv bootargs ${bootargs} "		\
62 		"console=ttyS${yocto_tty},${baudrate}\0"	\
63 	"addmtd=setenv bootargs ${bootargs} ${mtdparts}\0"	\
64 	"addmisc=setenv bootargs ${bootargs} "			\
65 		"intel-spi.writeable=1 vmalloc=300M "		\
66 		"pci=realloc=on,hpmemsize=0x12000000\0"		\
67 	"bootcmd=if env exists recovery_status;"		\
68 		"then run swupdate;"				\
69 		"else run yocto_boot;run swupdate;"		\
70 		"fi\0"						\
71 	"ubuntu_args=setenv bootargs "				\
72 		"root=/dev/sda${ubuntu_part} ro\0"		\
73 	"ubuntu_args_quiet=setenv bootargs "			\
74 		"root=/dev/sda${ubuntu_part} ro quiet\0"	\
75 	"ubuntu_load=load scsi 0:${ubuntu_part} 03000000 "	\
76 		"/boot/vmlinuz-${kernel-ver}-generic;"		\
77 		"load scsi 0:${ubuntu_part} 04000000 "		\
78 		"/boot/initrd.img-${kernel-ver}-generic\0"	\
79 	"ubuntu_boot=run ubuntu_args_quiet addmtd addmisc "	\
80 		"ubuntu_load boot\0"				\
81 	"ubuntu_boot_console=run ubuntu_args addtty_ubuntu "	\
82 		"addmtd addmisc ubuntu_load boot\0"		\
83 	"net_args=setenv bootargs root=/dev/sda${ubuntu_part} ro\0" \
84 	"net_boot=run start_eth net_args addtty_yocto addmtd addmisc;" \
85 		"tftp 03000000 ${tftpdir}/bzImage;"		\
86 		"load scsi 0:${ubuntu_part} 04000000 "		\
87 		"/boot/initrd.img-${kernel-ver}-generic;"	\
88 		"run boot\0"					\
89 	"yocto_args=setenv bootargs root=/dev/sda${yocto_part} " \
90 		"panic=1\0"				\
91 	"yocto_args_fast=setenv bootargs root=/dev/sda${yocto_part} " \
92 		"quiet panic=1\0"				\
93 	"yocto_boot=run yocto_args addmtd addmisc addtty_yocto;" \
94 		"if run yocto_load;then zboot 03000000;fi\0"	\
95 	"yocto_boot_fast=run yocto_args_fast addmtd addmisc "	\
96 		"addtty_yocto yocto_load;zboot 03000000\0"	\
97 	"yocto_boot_tftp=run yocto_args addmtd addmisc addtty_yocto " \
98 		"start_eth yocto_load_tftp;zboot 03000000\0"	\
99 	"yocto_kernel=bzImage\0"				\
100 	"yocto_load=load scsi 0:${yocto_part} 03000000 "	\
101 		"/boot/${yocto_kernel}\0"			\
102 	"yocto_load_tftp=tftp 03000000 dfi/bzImage\0"		\
103 	"swupdate=if env exists swupdate_factory;"		\
104 		"then run swupdate_usb;run swupdate_run;"	\
105 		"else setenv swupdate_part 2;run swupdate_mmc;" \
106 			"run swupdate_run;setenv swupdate_part 1;" \
107 			"run swupdate_mmc;run swupdate_usb;"	\
108 			"run swupdate_run;"			\
109 		"fi\0"						\
110 	"swupdate-initrd=/boot/swupdate-image-theadorable.ext4.gz\0" \
111 	"swupdate-kernel=/boot/bzImage\0"			\
112 	"swupdate_args=setenv bootargs root=/dev/ram rw panic=1\0" \
113 	"swupdate_dev=0\0"					\
114 	"swupdate_factory=0\0"					\
115 	"swupdate_interface=usb\0"				\
116 	"swupdate_kernel=vmlinuz-4.4.0-28-generic\0"		\
117 	"swupdate_load=load ${swupdate_interface} ${swupdate_dev}:" \
118 		"${swupdate_part} 03000000 ${swupdate-kernel}"	\
119 		" && load ${swupdate_interface} ${swupdate_dev}:" \
120 		"${swupdate_part} 04000000 ${swupdate-initrd}\0" \
121 	"swupdate_mmc=setenv swupdate_interface mmc;"		\
122 		"setenv swupdate_dev ${swupdate_mmcdev};"	\
123 		"setenv swupdate_part 1;"			\
124 		"mmc dev ${swupdate_dev};mmc rescan\0"		\
125 	"swupdate_mmcdev=0\0"					\
126 	"swupdate_part=1\0"					\
127 	"swupdate_run=run swupdate_args addtty_yocto addmtd addmisc;" \
128 		"if run swupdate_load;then run boot;"		\
129 		"else echo SWUpdate cannot be started from "	\
130 		"${swupdate_interface};"			\
131 		"fi\0"						\
132 	"swupdate_usb=setenv swupdate_interface usb;"		\
133 		"setenv swupdate_dev 0;setenv swupdate_part 1;"	\
134 		"usb start\0"					\
135 	"logo_tftp=tftp ${loadaddr} ${tftpdir}/logo.bmp;"	\
136 		"bmp display ${loadaddr}\0"			\
137 	"preboot=scsi scan;load scsi 0:${ubuntu_part} ${loadaddr} " \
138 		"/boot/logo/logo.bmp;bmp display ${loadaddr}\0" \
139 	"rootpath=/tftpboot/theadorable-x86-conga/work/"	\
140 		"rootfs-yocto-swupdate-2017-03-29\0"		\
141 	"addip=setenv bootargs ${bootargs} ip=${ipaddr}:${serverip}:" \
142 		"${gatewayip}:${netmask}:${hostname}:eth0:off\0" \
143 	"set_bootargs_nfs=setenv bootargs root=/dev/nfs rw "	\
144 		"nfsroot=${serverip}:${rootpath},tcp,nfsvers=3\0" \
145 	"net_nfs=run start_eth set_bootargs_nfs addtty_yocto addip " \
146 		"addmtd addmisc;tftp 03000000 ${tftpdir}/bzImage;" \
147 		"zboot 03000000\0"				\
148 	"load_uboot=tftp ${loadaddr} ${tftpdir}/u-boot.rom\0"	\
149 	"update_uboot=sf probe;"				\
150 		"sf update ${loadaddr} 0 800000;saveenv\0"	\
151 	"upd_uboot=run start_eth load_uboot update_uboot\0"
152 
153 #endif /* __THEADORABLE_X86_COMMON_H */
154