xref: /openbmc/u-boot/drivers/serial/Kconfig (revision abeb9d78)
1#
2# Serial device configuration
3#
4
5menu "Serial drivers"
6
7config BAUDRATE
8	int "Default baudrate"
9	default 115200
10	help
11	  Select a default baudrate, where "default" has a driver-specific
12	  meaning of either setting the baudrate for the early debug UART
13	  in the SPL stage (most drivers) or for choosing a default baudrate
14	  in the absence of an environment setting (serial_mxc.c).
15
16config REQUIRE_SERIAL_CONSOLE
17	bool "Require a serial port for console"
18	# Running without a serial console is not supported by the
19	# non-dm serial code
20	depends on DM_SERIAL
21	default y
22	help
23	  Require a serial port for the console, and panic if none is found
24	  during serial port initialization (default y). Set this to n on
25	  boards which have no debug serial port whatsoever.
26
27config SPECIFY_CONSOLE_INDEX
28	bool "Specify the port number used for console"
29	default y if !DM_SERIAL || (SPL && !SPL_DM_SERIAL) || \
30		(TPL && !TPL_DM_SERIAL)
31	help
32	  In various cases, we need to specify which of the UART devices that
33	  a board or SoC has available are to be used for the console device
34	  in U-Boot.
35
36config SERIAL_PRESENT
37	bool "Provide a serial driver"
38	depends on DM_SERIAL
39	default y
40	help
41	  In very space-constrained devices even the full UART driver is too
42	  large. In this case the debug UART can still be used in some cases.
43	  This option enables the full UART in U-Boot, so if is it disabled,
44	  the full UART driver will be omitted, thus saving space.
45
46config SPL_SERIAL_PRESENT
47	bool "Provide a serial driver in SPL"
48	depends on DM_SERIAL
49	default y
50	help
51	  In very space-constrained devices even the full UART driver is too
52	  large. In this case the debug UART can still be used in some cases.
53	  This option enables the full UART in SPL, so if is it disabled,
54	  the full UART driver will be omitted, thus saving space.
55
56# Logic to allow us to use the imply keyword to set what the default port
57# should be.  The default is otherwise 1.
58config CONS_INDEX_0
59	bool
60
61config CONS_INDEX_2
62	bool
63
64config CONS_INDEX_3
65	bool
66
67config CONS_INDEX_4
68	bool
69
70config CONS_INDEX_5
71	bool
72
73config CONS_INDEX_6
74	bool
75
76config CONS_INDEX
77	int "UART used for console"
78	depends on SPECIFY_CONSOLE_INDEX
79	range 0 6
80	default 0 if CONS_INDEX_0
81	default 2 if CONS_INDEX_2
82	default 3 if CONS_INDEX_3
83	default 4 if CONS_INDEX_4
84	default 5 if CONS_INDEX_5
85	default 6 if CONS_INDEX_6
86	default 1
87	help
88	  Set this to match the UART number of the serial console.
89
90config DM_SERIAL
91	bool "Enable Driver Model for serial drivers"
92	depends on DM
93	help
94	  Enable driver model for serial. This replaces
95	  drivers/serial/serial.c with the serial uclass, which
96	  implements serial_putc() etc. The uclass interface is
97	  defined in include/serial.h.
98
99config SERIAL_RX_BUFFER
100	bool "Enable RX buffer for serial input"
101	depends on DM_SERIAL
102	help
103	  Enable RX buffer support for the serial driver. This enables
104	  pasting longer strings, even when the RX FIFO of the UART is
105	  not big enough (e.g. 16 bytes on the normal NS16550).
106
107config SERIAL_RX_BUFFER_SIZE
108	int "RX buffer size"
109	depends on SERIAL_RX_BUFFER
110	default 256
111	help
112	  The size of the RX buffer (needs to be power of 2)
113
114config SERIAL_SEARCH_ALL
115	bool "Search for serial devices after default one failed"
116	depends on DM_SERIAL
117	help
118	  The serial subsystem only searches for a single serial device
119	  that was instantiated, but does not check whether it was probed
120	  correctly. With this option set, we make successful probing
121	  mandatory and search for fallback serial devices if the default
122	  device does not work.
123
124	  If unsure, say N.
125
126config SPL_DM_SERIAL
127	bool "Enable Driver Model for serial drivers in SPL"
128	depends on DM_SERIAL && SPL_DM
129	default y
130	help
131	  Enable driver model for serial in SPL. This replaces
132	  drivers/serial/serial.c with the serial uclass, which
133	  implements serial_putc() etc. The uclass interface is
134	  defined in include/serial.h.
135
136config TPL_DM_SERIAL
137	bool "Enable Driver Model for serial drivers in TPL"
138	depends on DM_SERIAL
139	default y if TPL && DM_SERIAL
140	help
141	  Enable driver model for serial in TPL. This replaces
142	  drivers/serial/serial.c with the serial uclass, which
143	  implements serial_putc() etc. The uclass interface is
144	  defined in include/serial.h.
145
146config DEBUG_UART
147	bool "Enable an early debug UART for debugging"
148	help
149	  The debug UART is intended for use very early in U-Boot to debug
150	  problems when an ICE or other debug mechanism is not available.
151
152	  To use it you should:
153	  - Make sure your UART supports this interface
154	  - Enable CONFIG_DEBUG_UART
155	  - Enable the CONFIG for your UART to tell it to provide this interface
156	        (e.g. CONFIG_DEBUG_UART_NS16550)
157	  - Define the required settings as needed (see below)
158	  - Call debug_uart_init() before use
159	  - Call debug_uart_putc() to output a character
160
161	  Depending on your platform it may be possible to use this UART before
162	  a stack is available.
163
164	  If your UART does not support this interface you can probably add
165	  support quite easily. Remember that you cannot use driver model and
166	  it is preferred to use no stack.
167
168	  You must not use this UART once driver model is working and the
169	  serial drivers are up and running (done in serial_init()). Otherwise
170	  the drivers may conflict and you will get strange output.
171
172choice
173	prompt "Select which UART will provide the debug UART"
174	depends on DEBUG_UART
175	default DEBUG_UART_NS16550
176
177config DEBUG_UART_ALTERA_JTAGUART
178	bool "Altera JTAG UART"
179	help
180	  Select this to enable a debug UART using the altera_jtag_uart driver.
181	  You will need to provide parameters to make this work. The driver will
182	  be available until the real driver model serial is running.
183
184config DEBUG_UART_ALTERA_UART
185	bool "Altera UART"
186	help
187	  Select this to enable a debug UART using the altera_uart driver.
188	  You will need to provide parameters to make this work. The driver will
189	  be available until the real driver model serial is running.
190
191config DEBUG_UART_AR933X
192	bool "QCA/Atheros ar933x"
193	depends on AR933X_UART
194	help
195	  Select this to enable a debug UART using the ar933x uart driver.
196	  You will need to provide parameters to make this work. The
197	  driver will be available until the real driver model serial is
198	  running.
199
200config DEBUG_UART_ATMEL
201	bool "Atmel USART"
202	help
203	  Select this to enable a debug UART using the atmel usart driver. You
204	  will need to provide parameters to make this work. The driver will
205	  be available until the real driver-model serial is running.
206
207config DEBUG_UART_BCM6345
208	bool "BCM6345 UART"
209	depends on BCM6345_SERIAL
210	help
211	  Select this to enable a debug UART on BCM6345 SoCs. You
212	  will need to provide parameters to make this work. The driver will
213	  be available until the real driver model serial is running.
214
215config DEBUG_UART_NS16550
216	bool "ns16550"
217	help
218	  Select this to enable a debug UART using the ns16550 driver. You
219	  will need to provide parameters to make this work. The driver will
220	  be available until the real driver model serial is running.
221
222config DEBUG_EFI_CONSOLE
223	bool "EFI"
224	depends on EFI_APP
225	help
226	  Select this to enable a debug console which calls back to EFI to
227	  output to the console. This can be useful for early debugging of
228	  U-Boot when running on top of EFI (Extensive Firmware Interface).
229	  This is a type of BIOS used by PCs.
230
231config DEBUG_UART_S5P
232	bool "Samsung S5P"
233	help
234	  Select this to enable a debug UART using the serial_s5p driver. You
235	  will need to provide parameters to make this work. The driver will
236	  be available until the real driver-model serial is running.
237
238config DEBUG_UART_MESON
239	bool "Amlogic Meson"
240	depends on MESON_SERIAL
241	help
242	  Select this to enable a debug UART using the serial_meson driver. You
243	  will need to provide parameters to make this work. The driver will
244	  be available until the real driver-model serial is running.
245
246config DEBUG_UART_UARTLITE
247	bool "Xilinx Uartlite"
248	help
249	  Select this to enable a debug UART using the serial_uartlite driver.
250	  You will need to provide parameters to make this work. The driver will
251	  be available until the real driver-model serial is running.
252
253config DEBUG_UART_ARM_DCC
254	bool "ARM DCC"
255	help
256	  Select this to enable a debug UART using the ARM JTAG DCC port.
257	  The DCC port can be used for very early debugging and doesn't require
258	  any additional setting like address/baudrate/clock. On systems without
259	  any serial interface this is the easiest way how to get console.
260	  Every ARM core has own DCC port which is the part of debug interface.
261	  This port is available at least on ARMv6, ARMv7, ARMv8 and XScale
262	  architectures.
263
264config DEBUG_MVEBU_A3700_UART
265	bool "Marvell Armada 3700"
266	help
267	  Select this to enable a debug UART using the serial_mvebu driver. You
268	  will need to provide parameters to make this work. The driver will
269	  be available until the real driver-model serial is running.
270
271config DEBUG_UART_ZYNQ
272	bool "Xilinx Zynq"
273	help
274	  Select this to enable a debug UART using the serial_zynq driver. You
275	  will need to provide parameters to make this work. The driver will
276	  be available until the real driver-model serial is running.
277
278config DEBUG_UART_APBUART
279	depends on LEON3
280	bool "Gaisler APBUART"
281	help
282	  Select this to enable a debug UART using the serial_leon3 driver. You
283	  will need to provide parameters to make this work. The driver will
284	  be available until the real driver model serial is running.
285
286config DEBUG_UART_PL010
287	bool "pl010"
288	help
289	  Select this to enable a debug UART using the pl01x driver with the
290	  PL010 UART type. You will need to provide parameters to make this
291	  work. The driver will be available until the real driver model
292	  serial is running.
293
294config DEBUG_UART_PL011
295	bool "pl011"
296	help
297	  Select this to enable a debug UART using the pl01x driver with the
298	  PL011 UART type. You will need to provide parameters to make this
299	  work. The driver will be available until the real driver model
300	  serial is running.
301
302config DEBUG_UART_PIC32
303	bool "Microchip PIC32"
304	depends on PIC32_SERIAL
305	help
306	  Select this to enable a debug UART using the serial_pic32 driver. You
307	  will need to provide parameters to make this work. The driver will
308	  be available until the real driver model serial is running.
309
310config DEBUG_UART_MXC
311	bool "IMX Serial port"
312	depends on MXC_UART
313	help
314	  Select this to enable a debug UART using the serial_mxc driver. You
315	  will need to provide parameters to make this work. The driver will
316	  be available until the real driver model serial is running.
317
318config DEBUG_UART_UNIPHIER
319	bool "UniPhier on-chip UART"
320	depends on ARCH_UNIPHIER
321	help
322	  Select this to enable a debug UART using the UniPhier on-chip UART.
323	  You will need to provide DEBUG_UART_BASE to make this work.  The
324	  driver will be available until the real driver-model serial is
325	  running.
326
327config DEBUG_UART_OMAP
328	bool "OMAP uart"
329	help
330	  Select this to enable a debug UART using the omap ns16550 driver.
331	  You will need to provide parameters to make this work. The driver
332	  will be available until the real driver model serial is running.
333
334endchoice
335
336config DEBUG_UART_BASE
337	hex "Base address of UART"
338	depends on DEBUG_UART
339	help
340	  This is the base address of your UART for memory-mapped UARTs.
341
342	  A default should be provided by your board, but if not you will need
343	  to use the correct value here.
344
345config DEBUG_UART_CLOCK
346	int "UART input clock"
347	depends on DEBUG_UART
348	help
349	  The UART input clock determines the speed of the internal UART
350	  circuitry. The baud rate is derived from this by dividing the input
351	  clock down.
352
353	  A default should be provided by your board, but if not you will need
354	  to use the correct value here.
355
356config DEBUG_UART_SHIFT
357	int "UART register shift"
358	depends on DEBUG_UART
359	default 0 if DEBUG_UART
360	help
361	  Some UARTs (notably ns16550) support different register layouts
362	  where the registers are spaced either as bytes, words or some other
363	  value. Use this value to specify the shift to use, where 0=byte
364	  registers, 2=32-bit word registers, etc.
365
366config DEBUG_UART_BOARD_INIT
367	bool "Enable board-specific debug UART init"
368	depends on DEBUG_UART
369	help
370	  Some boards need to set things up before the debug UART can be used.
371	  On these boards a call to debug_uart_init() is insufficient. When
372	  this option is enabled, the function board_debug_uart_init() will
373	  be called when debug_uart_init() is called. You can put any code
374	  here that is needed to set up the UART ready for use, such as set
375	  pin multiplexing or enable clocks.
376
377config DEBUG_UART_ANNOUNCE
378	bool "Show a message when the debug UART starts up"
379	depends on DEBUG_UART
380	help
381	  Enable this option to show a message when the debug UART is ready
382	  for use. You will see a message like "<debug_uart> " as soon as
383	  U-Boot has the UART ready for use (i.e. your code calls
384	  debug_uart_init()). This can be useful just as a check that
385	  everything is working.
386
387config DEBUG_UART_SKIP_INIT
388	bool "Skip UART initialization"
389	help
390	  Select this if the UART you want to use for debug output is already
391	  initialized by the time U-Boot starts its execution.
392
393config ALTERA_JTAG_UART
394	bool "Altera JTAG UART support"
395	depends on DM_SERIAL
396	help
397	  Select this to enable an JTAG UART for Altera devices.The JTAG UART
398	  core implements a method to communicate serial character streams
399	  between a host PC and a Qsys system on an Altera FPGA. Please find
400	  details on the "Embedded Peripherals IP User Guide" of Altera.
401
402config ALTERA_JTAG_UART_BYPASS
403	bool "Bypass output when no connection"
404	depends on ALTERA_JTAG_UART
405	help
406	  Bypass console output and keep going even if there is no JTAG
407	  terminal connection with the host. The console output will resume
408	  once the JTAG terminal is connected. Without the bypass, the console
409	  output will wait forever until a JTAG terminal is connected. If you
410	  not are sure, say Y.
411
412config ALTERA_UART
413	bool "Altera UART support"
414	depends on DM_SERIAL
415	help
416	  Select this to enable an UART for Altera devices. Please find
417	  details on the "Embedded Peripherals IP User Guide" of Altera.
418
419config AR933X_UART
420	bool "QCA/Atheros ar933x UART support"
421	depends on DM_SERIAL && SOC_AR933X
422	help
423	  Select this to enable UART support for QCA/Atheros ar933x
424	  devices. This driver uses driver model and requires a device
425	  tree binding to operate, please refer to the document at
426	  doc/device-tree-bindings/serial/qca,ar9330-uart.txt.
427
428config ATMEL_USART
429	bool "Atmel USART support"
430	help
431	  Select this to enable USART support for Atmel SoCs. It can be
432	  configured in the device tree, and input clock frequency can
433	  be got from the clk node.
434
435config BCM283X_MU_SERIAL
436	bool "Support for BCM283x Mini-UART"
437	depends on DM_SERIAL && ARCH_BCM283X
438	default y
439	help
440	  Select this to enable Mini-UART support on BCM283X family of SoCs.
441
442config BCM283X_PL011_SERIAL
443	bool "Support for BCM283x PL011 UART"
444	depends on PL01X_SERIAL && ARCH_BCM283X
445	default y
446	help
447	  Select this to enable an overriding PL011 driver for BCM283X SoCs
448	  that supports automatic disable, so that it only gets used when
449	  the UART is actually muxed.
450
451config BCM6345_SERIAL
452	bool "Support for BCM6345 UART"
453	depends on DM_SERIAL && ARCH_BMIPS
454	help
455	  Select this to enable UART on BCM6345 SoCs.
456
457config FSL_LINFLEXUART
458	bool "Freescale Linflex UART support"
459	depends on DM_SERIAL
460	help
461	  Select this to enable the Linflex serial module found on some
462	  NXP SoCs like S32V234.
463
464config FSL_LPUART
465	bool "Freescale LPUART support"
466	help
467	  Select this to enable a Low Power UART for Freescale VF610 and
468	  QorIQ Layerscape devices.
469
470config MVEBU_A3700_UART
471	bool "UART support for Armada 3700"
472	default n
473	help
474	  Choose this option to add support for UART driver on the Marvell
475	  Armada 3700 SoC. The base address is configured via DT.
476
477config MXC_UART
478	bool "IMX serial port support"
479	depends on MX5 || MX6
480	help
481	  If you have a machine based on a Motorola IMX CPU you
482	  can enable its onboard serial port by enabling this option.
483
484config NULLDEV_SERIAL
485	bool "Null serial device"
486	help
487	  Select this to enable null serial device support. A null serial
488	  device merely acts as a placeholder for a serial device and does
489	  nothing for all it's operation.
490
491config PIC32_SERIAL
492	bool "Support for Microchip PIC32 on-chip UART"
493	depends on DM_SERIAL && MACH_PIC32
494	default y
495	help
496	  Support for the UART found on Microchip PIC32 SoC's.
497
498config SYS_NS16550
499	bool "NS16550 UART or compatible"
500	help
501	  Support NS16550 UART or compatible. This can be enabled in the
502	  device tree with the correct input clock frequency. If the input
503	  clock frequency is not defined in the device tree, the macro
504	  CONFIG_SYS_NS16550_CLK defined in a legacy board header file will
505	  be used. It can be a constant or a function to get clock, eg,
506	  get_serial_clock().
507
508config INTEL_MID_SERIAL
509	bool "Intel MID platform UART support"
510	depends on DM_SERIAL && OF_CONTROL
511	depends on INTEL_MID
512	select SYS_NS16550
513	help
514	  Select this to enable a UART for Intel MID platforms.
515	  This uses the ns16550 driver as a library.
516
517config PL010_SERIAL
518	bool "ARM PL010 driver"
519	depends on !DM_SERIAL
520	help
521	  Select this to enable a UART for platforms using PL010.
522
523config PL011_SERIAL
524	bool "ARM PL011 driver"
525	depends on !DM_SERIAL
526	help
527	  Select this to enable a UART for platforms using PL011.
528
529config PL01X_SERIAL
530	bool "ARM PL010 and PL011 driver"
531	depends on DM_SERIAL
532	help
533	  Select this to enable a UART for platforms using PL010 or PL011.
534
535config ROCKCHIP_SERIAL
536	bool "Rockchip on-chip UART support"
537	depends on DM_SERIAL && SPL_OF_PLATDATA
538	help
539	  Select this to enable a debug UART for Rockchip devices when using
540	  CONFIG_SPL_OF_PLATDATA (i.e. a compiled-in device tree replacemenmt).
541	  This uses the ns16550 driver, converting the platdata from of-platdata
542	  to the ns16550 format.
543
544config SANDBOX_SERIAL
545	bool "Sandbox UART support"
546	depends on SANDBOX
547	help
548	  Select this to enable a seral UART for sandbox. This is required to
549	  operate correctly, otherwise you will see no serial output from
550	  sandbox. The emulated UART will display to the console and console
551	  input will be fed into the UART. This allows you to interact with
552	  U-Boot.
553
554	  The operation of the console is controlled by the -t command-line
555	  flag. In raw mode, U-Boot sees all characters from the terminal
556	  before they are processed, including Ctrl-C. In cooked mode, Ctrl-C
557	  is processed by the terminal, and terminates U-Boot. Valid options
558	  are:
559
560	     -t raw-with-sigs	Raw mode, Ctrl-C will terminate U-Boot
561	     -t raw		Raw mode, Ctrl-C is processed by U-Boot
562	     -t cooked		Cooked mode, Ctrl-C terminates
563
564config SCIF_CONSOLE
565	bool "Renesas SCIF UART support"
566	depends on SH || ARCH_RMOBILE
567	help
568	  Select this to enable Renesas SCIF UART. To operate serial ports
569	  on systems with RCar or SH SoCs, say Y to this option. If unsure,
570	  say N.
571
572config UNIPHIER_SERIAL
573	bool "Support for UniPhier on-chip UART"
574	depends on ARCH_UNIPHIER
575	default y
576	help
577	  If you have a UniPhier based board and want to use the on-chip
578	  serial ports, say Y to this option. If unsure, say N.
579
580config XILINX_UARTLITE
581	bool "Xilinx Uarlite support"
582	depends on DM_SERIAL && (MICROBLAZE || ARCH_ZYNQ || ARCH_ZYNQMP || 4xx)
583	help
584	  If you have a Xilinx based board and want to use the uartlite
585	  serial ports, say Y to this option. If unsure, say N.
586
587config MESON_SERIAL
588	bool "Support for Amlogic Meson UART"
589	depends on DM_SERIAL && ARCH_MESON
590	help
591	  If you have an Amlogic Meson based board and want to use the on-chip
592	  serial ports, say Y to this option. If unsure, say N.
593
594config MSM_SERIAL
595	bool "Qualcomm on-chip UART"
596	depends on DM_SERIAL
597	help
598	  Support Data Mover UART used on Qualcomm Snapdragon SoCs.
599	  It should support all Qualcomm devices with UARTDM version 1.4,
600	  for example APQ8016 and MSM8916.
601	  Single baudrate is supported in current implementation (115200).
602
603config PXA_SERIAL
604	bool "PXA serial port support"
605	help
606	  If you have a machine based on a Marvell XScale PXA2xx CPU you
607	  can enable its onboard serial ports by enabling this option.
608
609config STI_ASC_SERIAL
610	bool "STMicroelectronics on-chip UART"
611	depends on DM_SERIAL && ARCH_STI
612	help
613	  Select this to enable Asynchronous Serial Controller available
614	  on STiH410 SoC. This is a basic implementation,  it supports
615	  following baudrate 9600, 19200, 38400, 57600 and 115200.
616
617config STM32_SERIAL
618	bool "STMicroelectronics STM32 SoCs on-chip UART"
619	depends on DM_SERIAL && (STM32F4 || STM32F7 || STM32H7 || ARCH_STM32MP)
620	help
621	  If you have a machine based on a STM32 F4, F7, H7 or MP1 SOC
622	  you can enable its onboard serial ports, say Y to this option.
623	  If unsure, say N.
624
625config ZYNQ_SERIAL
626	bool "Cadence (Xilinx Zynq) UART support"
627	depends on DM_SERIAL && (MICROBLAZE || ARCH_ZYNQ || ARCH_ZYNQMP)
628	help
629	  This driver supports the Cadence UART. It is found e.g. in Xilinx
630	  Zynq/ZynqMP.
631
632config MPC8XX_CONS
633	bool "Console driver for MPC8XX"
634	depends on MPC8xx
635	default y
636
637choice
638	prompt "Console port"
639	default 8xx_CONS_SMC1
640	depends on MPC8XX_CONS
641	help
642	  Depending on board, select one serial port
643	  (CONFIG_8xx_CONS_SMC1 or CONFIG_8xx_CONS_SMC2)
644
645config 8xx_CONS_SMC1
646	bool "SMC1"
647
648config 8xx_CONS_SMC2
649	bool "SMC2"
650
651endchoice
652
653config SYS_SMC_RXBUFLEN
654	int "Console Rx buffer length"
655	depends on MPC8XX_CONS
656	default 1
657	help
658	  With CONFIG_SYS_SMC_RXBUFLEN it is possible to define
659	  the maximum receive buffer length for the SMC.
660	  This option is actual only for 8xx possible.
661	  If using CONFIG_SYS_SMC_RXBUFLEN also CONFIG_SYS_MAXIDLE
662	  must be defined, to setup the maximum idle timeout for
663	  the SMC.
664
665config SYS_MAXIDLE
666	int "maximum idle timeout"
667	depends on MPC8XX_CONS
668	default 0
669
670config SYS_BRGCLK_PRESCALE
671	int "BRG Clock Prescale"
672	depends on MPC8XX_CONS
673	default 1
674
675config SYS_SDSR
676	hex "SDSR Value"
677	depends on MPC8XX_CONS
678	default 0x83
679
680config SYS_SDMR
681	hex "SDMR Value"
682	depends on MPC8XX_CONS
683	default 0
684
685endmenu
686