blob: 738b55e74aba83d477f28bcc782d2a97f74d9140 [file] [log] [blame]
Ian Campbell2c7e3b92014-10-24 21:20:44 +01001if ARCH_SUNXI
2
3choice
4 prompt "Sunxi SoC Variant"
5
Ian Campbellc3be2792014-10-24 21:20:45 +01006config MACH_SUN4I
Ian Campbell2c7e3b92014-10-24 21:20:44 +01007 bool "sun4i (Allwinner A10)"
8 select CPU_V7
9 select SUPPORT_SPL
10
Ian Campbellc3be2792014-10-24 21:20:45 +010011config MACH_SUN5I
Ian Campbell2c7e3b92014-10-24 21:20:44 +010012 bool "sun5i (Allwinner A13)"
13 select CPU_V7
14 select SUPPORT_SPL
15
Ian Campbellc3be2792014-10-24 21:20:45 +010016config MACH_SUN6I
Ian Campbell2c7e3b92014-10-24 21:20:44 +010017 bool "sun6i (Allwinner A31)"
18 select CPU_V7
Hans de Goede8c2c9cf2014-10-25 20:18:10 +020019 select SUPPORT_SPL
Ian Campbell2c7e3b92014-10-24 21:20:44 +010020
Ian Campbellc3be2792014-10-24 21:20:45 +010021config MACH_SUN7I
Ian Campbell2c7e3b92014-10-24 21:20:44 +010022 bool "sun7i (Allwinner A20)"
23 select CPU_V7
Hans de Goedeea624e12014-11-14 09:34:30 +010024 select CPU_V7_HAS_NONSEC
25 select CPU_V7_HAS_VIRT
Ian Campbell2c7e3b92014-10-24 21:20:44 +010026 select SUPPORT_SPL
Hans de Goedeb366fb92014-10-24 20:12:04 +020027 select ARMV7_BOOT_SEC_DEFAULT if OLD_SUNXI_KERNEL_COMPAT
Ian Campbell2c7e3b92014-10-24 21:20:44 +010028
Ian Campbellc3be2792014-10-24 21:20:45 +010029config MACH_SUN8I
Ian Campbell2c7e3b92014-10-24 21:20:44 +010030 bool "sun8i (Allwinner A23)"
31 select CPU_V7
Hans de Goede08fd1472014-12-07 14:34:27 +010032 select SUPPORT_SPL
Ian Campbell2c7e3b92014-10-24 21:20:44 +010033
34endchoice
Maxime Ripard8a6564d2014-10-03 20:16:29 +080035
Hans de Goede37781a12014-11-15 19:46:39 +010036config DRAM_CLK
Hans de Goede8ffc4872015-01-17 14:24:55 +010037 int "sunxi dram clock speed"
38 default 312 if MACH_SUN6I || MACH_SUN8I
39 default 360 if MACH_SUN4I || MACH_SUN5I || MACH_SUN7I
Hans de Goede37781a12014-11-15 19:46:39 +010040 ---help---
41 Set the dram clock speed, valid range 240 - 480, must be a multiple
Hans de Goede8ffc4872015-01-17 14:24:55 +010042 of 24. Note on sun4i / sun5i / sun7i this is only used by boards
43 which use dram autoconfig.
Hans de Goede37781a12014-11-15 19:46:39 +010044
45config DRAM_ZQ
Hans de Goede8ffc4872015-01-17 14:24:55 +010046 int "sunxi dram zq value"
47 default 123 if MACH_SUN4I || MACH_SUN5I || MACH_SUN6I || MACH_SUN8I
48 default 127 if MACH_SUN7I
Hans de Goede37781a12014-11-15 19:46:39 +010049 ---help---
Hans de Goede8ffc4872015-01-17 14:24:55 +010050 Set the dram zq value. Note on sun4i / sun5i / sun7i this is only
51 used by boards which use dram autoconfig.
Hans de Goede37781a12014-11-15 19:46:39 +010052
Hans de Goede8ffc4872015-01-17 14:24:55 +010053if MACH_SUN4I || MACH_SUN5I || MACH_SUN7I
54config DRAM_EMR1
55 int "sunxi dram emr1 value"
56 default 0 if MACH_SUN4I
57 default 4 if MACH_SUN5I || MACH_SUN7I
58 ---help---
59 Set the dram controller emr1 value. Note this is only used by boards
60 which use dram autoconfig.
Hans de Goede37781a12014-11-15 19:46:39 +010061endif
62
Maxime Ripard8a6564d2014-10-03 20:16:29 +080063config SYS_CONFIG_NAME
Ian Campbellc3be2792014-10-24 21:20:45 +010064 default "sun4i" if MACH_SUN4I
65 default "sun5i" if MACH_SUN5I
66 default "sun6i" if MACH_SUN6I
67 default "sun7i" if MACH_SUN7I
68 default "sun8i" if MACH_SUN8I
Hans de Goede6ae66f22014-08-01 09:28:24 +020069
Ian Campbelld9a20472014-10-24 21:20:49 +010070choice
71 prompt "Board"
72
Ian Campbelld9a20472014-10-24 21:20:49 +010073config TARGET_A10S_OLINUXINO_M
74 bool "A10S_OLINUXINO_M"
75 depends on MACH_SUN5I
76
77config TARGET_A13_OLINUXINOM
78 bool "A13_OLINUXINOM"
79 depends on MACH_SUN5I
80
81config TARGET_A13_OLINUXINO
82 bool "A13_OLINUXINO"
83 depends on MACH_SUN5I
84
85config TARGET_A20_OLINUXINO_L2
86 bool "A20_OLINUXINO_L2"
87 depends on MACH_SUN7I
88
89config TARGET_A20_OLINUXINO_L
90 bool "A20_OLINUXINO_L"
91 depends on MACH_SUN7I
92
93config TARGET_A20_OLINUXINO_M
94 bool "A20_OLINUXINO_M"
95 depends on MACH_SUN7I
96
97config TARGET_AUXTEK_T004
98 bool "AUXTEK_T004"
99 depends on MACH_SUN5I
100
101config TARGET_BANANAPI
102 bool "BANANAPI"
103 depends on MACH_SUN7I
104
Hans de Goede81ec1002014-12-31 11:30:26 +0100105config TARGET_BANANAPRO
106 bool "BANANAPRO"
107 depends on MACH_SUN7I
108
Ian Campbelld9a20472014-10-24 21:20:49 +0100109config TARGET_CUBIEBOARD2
110 bool "CUBIEBOARD2"
111 depends on MACH_SUN7I
112
Ian Campbelld9a20472014-10-24 21:20:49 +0100113config TARGET_CUBIETRUCK
114 bool "CUBIETRUCK"
115 depends on MACH_SUN7I
116
Ian Campbelld9a20472014-10-24 21:20:49 +0100117config TARGET_PCDUINO3
118 bool "PCDUINO3"
119 depends on MACH_SUN7I
120
Ian Campbelld9a20472014-10-24 21:20:49 +0100121config TARGET_MELE_M3
122 bool "MELE_M3"
123 depends on MACH_SUN7I
124
Hans de Goede6c46c8e2015-01-17 22:31:30 +0100125config TARGET_MK802_A10S
126 bool "MK802_A10S"
127 depends on MACH_SUN5I
128
Siarhei Siamashkaf4f0df02014-12-27 09:38:57 +0200129config TARGET_MSI_PRIMO73
130 bool "MSI Primo73 (7\" tablet)"
131 depends on MACH_SUN7I
132 ---help---
133 The MSI Primo73 is an A20 based tablet, with 1G RAM, 16G NAND,
134 1024x600 TN LCD display, mono speaker, 0.3 MP front camera, 2.0 MP
135 rear camera, 3000 mAh battery, gt911 touchscreen, mma8452 accelerometer
136 and rtl8188etv usb wifi. Has "power", "volume+" and "volume-" buttons
137 (both volume buttons are also connected to the UBOOT_SEL pin). The
138 external connectors are represented by MicroSD slot, MiniHDMI, MicroUSB
139 OTG and 3.5mm headphone jack. More details are available at
140 http://linux-sunxi.org/MSI_Primo73
141
Ian Campbelld9a20472014-10-24 21:20:49 +0100142config TARGET_I12_TVBOX
143 bool "I12_TVBOX"
144 depends on MACH_SUN7I
145
Ian Campbelld9a20472014-10-24 21:20:49 +0100146config TARGET_R7DONGLE
147 bool "R7DONGLE"
148 depends on MACH_SUN5I
149
150endchoice
151
Masahiro Yamadadd840582014-07-30 14:08:14 +0900152config SYS_BOARD
Masahiro Yamadadd840582014-07-30 14:08:14 +0900153 default "sunxi"
154
155config SYS_SOC
Masahiro Yamadadd840582014-07-30 14:08:14 +0900156 default "sunxi"
157
Ian Campbell4ce99412014-10-24 21:20:46 +0100158config SPL_FEL
159 bool "SPL/FEL mode support"
160 depends on SPL
161 default n
162
Siarhei Siamashkaf0ce28e2014-12-25 02:34:47 +0200163config UART0_PORT_F
164 bool "UART0 on MicroSD breakout board"
165 depends on SPL_FEL
166 default n
167 ---help---
168 Repurpose the SD card slot for getting access to the UART0 serial
169 console. Primarily useful only for low level u-boot debugging on
170 tablets, where normal UART0 is difficult to access and requires
171 device disassembly and/or soldering. As the SD card can't be used
172 at the same time, the system can be only booted in the FEL mode.
173 Only enable this if you really know what you are doing.
174
Ian Campbell98e214d2014-08-31 13:13:43 +0100175config FDTFILE
176 string "Default fdtfile env setting for this board"
Hans de Goede846e3252014-08-01 09:37:58 +0200177
Hans de Goedeaccc9e42014-10-22 14:56:36 +0200178config OLD_SUNXI_KERNEL_COMPAT
179 boolean "Enable workarounds for booting old kernels"
180 default n
181 ---help---
182 Set this to enable various workarounds for old kernels, this results in
183 sub-optimal settings for newer kernels, only enable if needed.
184
Hans de Goedecd821132014-10-02 20:29:26 +0200185config MMC0_CD_PIN
186 string "Card detect pin for mmc0"
187 default ""
188 ---help---
189 Set the card detect pin for mmc0, leave empty to not use cd. This
190 takes a string in the format understood by sunxi_name_to_gpio, e.g.
191 PH1 for pin 1 of port H.
192
193config MMC1_CD_PIN
194 string "Card detect pin for mmc1"
195 default ""
196 ---help---
197 See MMC0_CD_PIN help text.
198
199config MMC2_CD_PIN
200 string "Card detect pin for mmc2"
201 default ""
202 ---help---
203 See MMC0_CD_PIN help text.
204
205config MMC3_CD_PIN
206 string "Card detect pin for mmc3"
207 default ""
208 ---help---
209 See MMC0_CD_PIN help text.
210
Hans de Goede2ccfac02014-10-02 20:43:50 +0200211config MMC_SUNXI_SLOT_EXTRA
212 int "mmc extra slot number"
213 default -1
214 ---help---
215 sunxi builds always enable mmc0, some boards also have a second sdcard
216 slot or emmc on mmc1 - mmc3. Setting this to 1, 2 or 3 will enable
217 support for this.
218
Hans de Goede4458b7a2015-01-07 15:26:06 +0100219config USB0_VBUS_PIN
220 string "Vbus enable pin for usb0 (otg)"
221 default ""
222 ---help---
223 Set the Vbus enable pin for usb0 (otg). This takes a string in the
224 format understood by sunxi_name_to_gpio, e.g. PH1 for pin 1 of port H.
225
Hans de Goede115200c2014-11-07 16:09:00 +0100226config USB1_VBUS_PIN
227 string "Vbus enable pin for usb1 (ehci0)"
228 default "PH6" if MACH_SUN4I || MACH_SUN7I
Hans de Goede76946df2014-11-07 14:51:12 +0100229 default "PH27" if MACH_SUN6I
Hans de Goede115200c2014-11-07 16:09:00 +0100230 ---help---
231 Set the Vbus enable pin for usb1 (ehci0, usb0 is the otg). This takes
232 a string in the format understood by sunxi_name_to_gpio, e.g.
233 PH1 for pin 1 of port H.
234
235config USB2_VBUS_PIN
236 string "Vbus enable pin for usb2 (ehci1)"
237 default "PH3" if MACH_SUN4I || MACH_SUN7I
Hans de Goede76946df2014-11-07 14:51:12 +0100238 default "PH24" if MACH_SUN6I
Hans de Goede115200c2014-11-07 16:09:00 +0100239 ---help---
240 See USB1_VBUS_PIN help text.
241
Luc Verhaegen7f2c5212014-08-13 07:55:06 +0200242config VIDEO
Hans de Goede2dae8002014-12-21 16:28:32 +0100243 boolean "Enable graphical uboot console on HDMI, LCD or VGA"
Luc Verhaegen7f2c5212014-08-13 07:55:06 +0200244 default y
245 ---help---
Hans de Goede2dae8002014-12-21 16:28:32 +0100246 Say Y here to add support for using a cfb console on the HDMI, LCD
247 or VGA output found on most sunxi devices. See doc/README.video for
248 info on how to select the video output and mode.
249
Hans de Goede2fbf0912014-12-23 23:04:35 +0100250config VIDEO_HDMI
251 boolean "HDMI output support"
252 depends on VIDEO && !MACH_SUN8I
253 default y
254 ---help---
255 Say Y here to add support for outputting video over HDMI.
256
Hans de Goeded9786d22014-12-25 13:58:06 +0100257config VIDEO_VGA
258 boolean "VGA output support"
259 depends on VIDEO && (MACH_SUN4I || MACH_SUN7I)
260 default n
261 ---help---
262 Say Y here to add support for outputting video over VGA.
263
Hans de Goedee2bbdfb2014-12-24 12:17:07 +0100264config VIDEO_VGA_VIA_LCD
265 boolean "VGA via LCD controller support"
Chen-Yu Tsai2583d5b2015-01-12 18:02:10 +0800266 depends on VIDEO && (MACH_SUN5I || MACH_SUN6I || MACH_SUN8I)
Hans de Goedee2bbdfb2014-12-24 12:17:07 +0100267 default n
268 ---help---
269 Say Y here to add support for external DACs connected to the parallel
270 LCD interface driving a VGA connector, such as found on the
271 Olimex A13 boards.
272
Chen-Yu Tsai507e27d2015-01-12 18:02:11 +0800273config VIDEO_VGA_EXTERNAL_DAC_EN
274 string "LCD panel power enable pin"
275 depends on VIDEO_VGA_VIA_LCD
276 default ""
277 ---help---
278 Set the enable pin for the external VGA DAC. This takes a string in the
279 format understood by sunxi_name_to_gpio, e.g. PH1 for pin 1 of port H.
280
Hans de Goede2dae8002014-12-21 16:28:32 +0100281config VIDEO_LCD_MODE
282 string "LCD panel timing details"
283 depends on VIDEO
284 default ""
285 ---help---
286 LCD panel timing details string, leave empty if there is no LCD panel.
287 This is in drivers/video/videomodes.c: video_get_params() format, e.g.
288 x:800,y:480,depth:18,pclk_khz:33000,le:16,ri:209,up:22,lo:22,hs:30,vs:1,sync:0,vmode:0
289
Hans de Goede65150322015-01-13 13:21:46 +0100290config VIDEO_LCD_DCLK_PHASE
291 int "LCD panel display clock phase"
292 depends on VIDEO
293 default 1
294 ---help---
295 Select LCD panel display clock phase shift, range 0-3.
296
Hans de Goede2dae8002014-12-21 16:28:32 +0100297config VIDEO_LCD_POWER
298 string "LCD panel power enable pin"
299 depends on VIDEO
300 default ""
301 ---help---
302 Set the power enable pin for the LCD panel. This takes a string in the
303 format understood by sunxi_name_to_gpio, e.g. PH1 for pin 1 of port H.
304
305config VIDEO_LCD_BL_EN
306 string "LCD panel backlight enable pin"
307 depends on VIDEO
308 default ""
309 ---help---
310 Set the backlight enable pin for the LCD panel. This takes a string in the
311 the format understood by sunxi_name_to_gpio, e.g. PH1 for pin 1 of
312 port H.
313
314config VIDEO_LCD_BL_PWM
315 string "LCD panel backlight pwm pin"
316 depends on VIDEO
317 default ""
318 ---help---
319 Set the backlight pwm pin for the LCD panel. This takes a string in the
320 format understood by sunxi_name_to_gpio, e.g. PH1 for pin 1 of port H.
Luc Verhaegen7f2c5212014-08-13 07:55:06 +0200321
Hans de Goedea7403ae2015-01-22 21:02:42 +0100322config VIDEO_LCD_BL_PWM_ACTIVE_LOW
323 bool "LCD panel backlight pwm is inverted"
324 depends on VIDEO
325 default y
326 ---help---
327 Set this if the backlight pwm output is active low.
328
Hans de Goede213480e2015-01-01 22:04:34 +0100329
330# Note only one of these may be selected at a time! But hidden choices are
331# not supported by Kconfig
332config VIDEO_LCD_IF_PARALLEL
333 bool
334
335config VIDEO_LCD_IF_LVDS
336 bool
337
338
339choice
340 prompt "LCD panel support"
341 depends on VIDEO
342 ---help---
343 Select which type of LCD panel to support.
344
345config VIDEO_LCD_PANEL_PARALLEL
346 bool "Generic parallel interface LCD panel"
347 select VIDEO_LCD_IF_PARALLEL
348
349config VIDEO_LCD_PANEL_LVDS
350 bool "Generic lvds interface LCD panel"
351 select VIDEO_LCD_IF_LVDS
352
Siarhei Siamashka97ece832015-01-19 05:23:33 +0200353config VIDEO_LCD_PANEL_MIPI_4_LANE_513_MBPS_VIA_SSD2828
354 bool "MIPI 4-lane, 513Mbps LCD panel via SSD2828 bridge chip"
355 select VIDEO_LCD_SSD2828
356 select VIDEO_LCD_IF_PARALLEL
357 ---help---
358 7.85" 768x1024 LCD panels, such as LG LP079X01 or AUO B079XAN01.0
359
Hans de Goede27515b22015-01-20 09:23:36 +0100360config VIDEO_LCD_PANEL_HITACHI_TX18D42VM
361 bool "Hitachi tx18d42vm LCD panel"
362 select VIDEO_LCD_HITACHI_TX18D42VM
363 select VIDEO_LCD_IF_LVDS
364 ---help---
365 7.85" 1024x768 Hitachi tx18d42vm LCD panel support
366
Hans de Goede213480e2015-01-01 22:04:34 +0100367endchoice
368
369
Hans de Goede1a800f72015-01-11 17:17:00 +0100370config USB_MUSB_SUNXI
371 bool "Enable sunxi OTG / DRC USB controller in host mode"
372 default n
373 ---help---
374 Say y here to enable support for the sunxi OTG / DRC USB controller
375 used on almost all sunxi boards. Note currently u-boot can only have
376 one usb host controller enabled at a time, so enabling this on boards
377 which also use the ehci host controller will result in build errors.
378
Hans de Goede86b49092014-09-18 21:03:34 +0200379config USB_KEYBOARD
380 boolean "Enable USB keyboard support"
381 default y
382 ---help---
383 Say Y here to add support for using a USB keyboard (typically used
Hans de Goede2dae8002014-12-21 16:28:32 +0100384 in combination with a graphical console).
Hans de Goede86b49092014-09-18 21:03:34 +0200385
Masahiro Yamadadd840582014-07-30 14:08:14 +0900386endif