1# SPDX-License-Identifier: GPL-2.0 2 3config ARM_PTDUMP_CORE 4 def_bool n 5 6config ARM_PTDUMP_DEBUGFS 7 bool "Export kernel pagetable layout to userspace via debugfs" 8 depends on DEBUG_KERNEL 9 depends on MMU 10 select ARM_PTDUMP_CORE 11 select DEBUG_FS 12 help 13 Say Y here if you want to show the kernel pagetable layout in a 14 debugfs file. This information is only useful for kernel developers 15 who are working in architecture specific areas of the kernel. 16 It is probably not a good idea to enable this feature in a production 17 kernel. 18 If in doubt, say "N" 19 20config DEBUG_WX 21 bool "Warn on W+X mappings at boot" 22 depends on MMU 23 select ARM_PTDUMP_CORE 24 help 25 Generate a warning if any W+X mappings are found at boot. 26 27 This is useful for discovering cases where the kernel is leaving 28 W+X mappings after applying NX, as such mappings are a security risk. 29 30 Look for a message in dmesg output like this: 31 32 arm/mm: Checked W+X mappings: passed, no W+X pages found. 33 34 or like this, if the check failed: 35 36 arm/mm: Checked W+X mappings: FAILED, <N> W+X pages found. 37 38 Note that even if the check fails, your kernel is possibly 39 still fine, as W+X mappings are not a security hole in 40 themselves, what they do is that they make the exploitation 41 of other unfixed kernel bugs easier. 42 43 There is no runtime or memory usage effect of this option 44 once the kernel has booted up - it's a one time check. 45 46 If in doubt, say "Y". 47 48choice 49 prompt "Choose kernel unwinder" 50 default UNWINDER_ARM if AEABI 51 default UNWINDER_FRAME_POINTER if !AEABI 52 help 53 This determines which method will be used for unwinding kernel stack 54 traces for panics, oopses, bugs, warnings, perf, /proc/<pid>/stack, 55 livepatch, lockdep, and more. 56 57config UNWINDER_FRAME_POINTER 58 bool "Frame pointer unwinder" 59 depends on !THUMB2_KERNEL 60 select ARCH_WANT_FRAME_POINTERS 61 select FRAME_POINTER 62 help 63 This option enables the frame pointer unwinder for unwinding 64 kernel stack traces. 65 66config UNWINDER_ARM 67 bool "ARM EABI stack unwinder" 68 depends on AEABI && !FUNCTION_GRAPH_TRACER 69 select ARM_UNWIND 70 help 71 This option enables stack unwinding support in the kernel 72 using the information automatically generated by the 73 compiler. The resulting kernel image is slightly bigger but 74 the performance is not affected. Currently, this feature 75 only works with EABI compilers. 76 77endchoice 78 79config ARM_UNWIND 80 bool 81 82config BACKTRACE_VERBOSE 83 bool "Verbose backtrace" 84 depends on EXPERT 85 help 86 When the kernel produces a warning or oops, the kernel prints a 87 trace of the call chain. This option controls whether we include 88 the numeric addresses or only include the symbolic information. 89 90 In most cases, say N here, unless you are intending to debug the 91 kernel and have access to the kernel binary image. 92 93config FRAME_POINTER 94 bool 95 96config DEBUG_USER 97 bool "Verbose user fault messages" 98 help 99 When a user program crashes due to an exception, the kernel can 100 print a brief message explaining what the problem was. This is 101 sometimes helpful for debugging but serves no purpose on a 102 production system. Most people should say N here. 103 104 In addition, you need to pass user_debug=N on the kernel command 105 line to enable this feature. N consists of the sum of: 106 107 1 - undefined instruction events 108 2 - system calls 109 4 - invalid data aborts 110 8 - SIGSEGV faults 111 16 - SIGBUS faults 112 113# These options are only for real kernel hackers who want to get their hands dirty. 114config DEBUG_LL 115 bool "Kernel low-level debugging functions (read help!)" 116 depends on DEBUG_KERNEL 117 help 118 Say Y here to include definitions of printascii, printch, printhex 119 in the kernel. This is helpful if you are debugging code that 120 executes before the console is initialized. 121 122 Note that selecting this option will limit the kernel to a single 123 UART definition, as specified below. Attempting to boot the kernel 124 image on a different platform *will not work*, so this option should 125 not be enabled for kernels that are intended to be portable. 126 127choice 128 prompt "Kernel low-level debugging port" 129 depends on DEBUG_LL 130 131 config DEBUG_ALPINE_UART0 132 bool "Kernel low-level debugging messages via Alpine UART0" 133 depends on ARCH_ALPINE 134 select DEBUG_UART_8250 135 help 136 Say Y here if you want kernel low-level debugging support 137 on Alpine based platforms. 138 139 config DEBUG_ASM9260_UART 140 bool "Kernel low-level debugging via asm9260 UART" 141 depends on MACH_ASM9260 142 help 143 Say Y here if you want the debug print routines to direct 144 their output to an UART or USART port on asm9260 based 145 machines. 146 147 DEBUG_UART_PHYS | DEBUG_UART_VIRT 148 149 0x80000000 | 0xf0000000 | UART0 150 0x80004000 | 0xf0004000 | UART1 151 0x80008000 | 0xf0008000 | UART2 152 0x8000c000 | 0xf000c000 | UART3 153 0x80010000 | 0xf0010000 | UART4 154 0x80014000 | 0xf0014000 | UART5 155 0x80018000 | 0xf0018000 | UART6 156 0x8001c000 | 0xf001c000 | UART7 157 0x80020000 | 0xf0020000 | UART8 158 0x80024000 | 0xf0024000 | UART9 159 160 config DEBUG_AT91_RM9200_DBGU 161 bool "Kernel low-level debugging on AT91RM9200, AT91SAM9, SAM9X60 DBGU" 162 select DEBUG_AT91_UART 163 depends on SOC_AT91RM9200 || SOC_AT91SAM9 || SOC_SAM9X60 164 help 165 Say Y here if you want kernel low-level debugging support 166 on the DBGU port of: 167 at91rm9200, at91sam9260, at91sam9g20, at91sam9261, 168 at91sam9g10, at91sam9n12, at91sam9rl64, at91sam9x5, sam9x60 169 170 config DEBUG_AT91_SAM9263_DBGU 171 bool "Kernel low-level debugging on AT91SAM{9263,9G45,A5D3} DBGU" 172 select DEBUG_AT91_UART 173 depends on SOC_AT91SAM9 || SOC_SAMA5D3 174 help 175 Say Y here if you want kernel low-level debugging support 176 on the DBGU port of: 177 at91sam9263, at91sam9g45, at91sam9m10, 178 sama5d3 179 180 config DEBUG_AT91_SAMA5D2_UART1 181 bool "Kernel low-level debugging on SAMA5D2 UART1" 182 select DEBUG_AT91_UART 183 depends on SOC_SAMA5D2 184 help 185 Say Y here if you want kernel low-level debugging support 186 on the UART1 port of sama5d2. 187 188 config DEBUG_AT91_SAMA5D4_USART3 189 bool "Kernel low-level debugging on SAMA5D4 USART3" 190 select DEBUG_AT91_UART 191 depends on SOC_SAMA5D4 192 help 193 Say Y here if you want kernel low-level debugging support 194 on the USART3 port of sama5d4. 195 196 config DEBUG_AT91_SAMV7_USART1 197 bool "Kernel low-level debugging via SAMV7 USART1" 198 select DEBUG_AT91_UART 199 depends on SOC_SAMV7 200 help 201 Say Y here if you want the debug print routines to direct 202 their output to the USART1 port on SAMV7 based 203 machines. 204 205 config DEBUG_AT91_SAMA7G5_FLEXCOM3 206 bool "Kernel low-level debugging on SAMA7G5 FLEXCOM3" 207 select DEBUG_AT91_UART 208 depends on SOC_SAMA7G5 209 help 210 Say Y here if you want kernel low-level debugging support 211 on the FLEXCOM3 port of SAMA7G5. 212 213 config DEBUG_BCM2835 214 bool "Kernel low-level debugging on BCM2835 PL011 UART" 215 depends on ARCH_BCM2835 && ARCH_MULTI_V6 216 select DEBUG_UART_PL01X 217 218 config DEBUG_BCM2836 219 bool "Kernel low-level debugging on BCM2836 PL011 UART" 220 depends on ARCH_BCM2835 && ARCH_MULTI_V7 221 select DEBUG_UART_PL01X 222 223 config DEBUG_BCM_5301X 224 bool "Kernel low-level debugging on BCM5301X/NSP UART1" 225 depends on ARCH_BCM_5301X || ARCH_BCM_NSP 226 select DEBUG_UART_8250 227 228 config DEBUG_BCM_HR2 229 bool "Kernel low-level debugging on Hurricane 2 UART2" 230 depends on ARCH_BCM_HR2 231 select DEBUG_UART_8250 232 233 config DEBUG_BCM_IPROC_UART3 234 bool "Kernel low-level debugging on BCM IPROC UART3" 235 depends on ARCH_BCM_CYGNUS 236 select DEBUG_UART_8250 237 help 238 Say Y here if you want the debug print routines to direct 239 their output to the third serial port on these devices. 240 241 config DEBUG_BCM_KONA_UART 242 bool "Kernel low-level debugging messages via BCM KONA UART" 243 depends on ARCH_BCM_MOBILE 244 select DEBUG_UART_8250 245 help 246 Say Y here if you want kernel low-level debugging support 247 on Broadcom SoC platforms. 248 This low level debug works for Broadcom 249 mobile SoCs in the Kona family of chips (e.g. bcm28155, 250 bcm11351, etc...) 251 252 config DEBUG_BCM63XX_UART 253 bool "Kernel low-level debugging on BCM63XX UART" 254 depends on ARCH_BCM_63XX 255 256 config DEBUG_BERLIN_UART 257 bool "Marvell Berlin SoC Debug UART" 258 depends on ARCH_BERLIN 259 select DEBUG_UART_8250 260 help 261 Say Y here if you want kernel low-level debugging support 262 on Marvell Berlin SoC based platforms. 263 264 config DEBUG_BRCMSTB_UART 265 bool "Use BRCMSTB UART for low-level debug" 266 depends on ARCH_BRCMSTB 267 help 268 Say Y here if you want the debug print routines to direct 269 their output to the first serial port on these devices. The 270 UART physical and virtual address is automatically provided 271 based on the chip identification register value. 272 273 If you have a Broadcom STB chip and would like early print 274 messages to appear over the UART, select this option. 275 276 config DEBUG_CLPS711X_UART1 277 bool "Kernel low-level debugging messages via UART1" 278 depends on ARCH_CLPS711X 279 help 280 Say Y here if you want the debug print routines to direct 281 their output to the first serial port on these devices. 282 283 config DEBUG_CLPS711X_UART2 284 bool "Kernel low-level debugging messages via UART2" 285 depends on ARCH_CLPS711X 286 help 287 Say Y here if you want the debug print routines to direct 288 their output to the second serial port on these devices. 289 290 config DEBUG_CNS3XXX 291 bool "Kernel Kernel low-level debugging on Cavium Networks CNS3xxx" 292 depends on ARCH_CNS3XXX 293 select DEBUG_UART_8250 294 help 295 Say Y here if you want the debug print routines to direct 296 their output to the CNS3xxx UART0. 297 298 config DEBUG_DAVINCI_DA8XX_UART1 299 bool "Kernel low-level debugging on DaVinci DA8XX using UART1" 300 depends on ARCH_DAVINCI_DA8XX 301 select DEBUG_UART_8250 302 help 303 Say Y here if you want the debug print routines to direct 304 their output to UART1 serial port on DaVinci DA8XX devices. 305 306 config DEBUG_DAVINCI_DA8XX_UART2 307 bool "Kernel low-level debugging on DaVinci DA8XX using UART2" 308 depends on ARCH_DAVINCI_DA8XX 309 select DEBUG_UART_8250 310 help 311 Say Y here if you want the debug print routines to direct 312 their output to UART2 serial port on DaVinci DA8XX devices. 313 314 config DEBUG_DAVINCI_DMx_UART0 315 bool "Kernel low-level debugging on DaVinci DMx using UART0" 316 depends on ARCH_DAVINCI_DMx 317 select DEBUG_UART_8250 318 help 319 Say Y here if you want the debug print routines to direct 320 their output to UART0 serial port on DaVinci DMx devices. 321 322 config DEBUG_DC21285_PORT 323 bool "Kernel low-level debugging messages via footbridge serial port" 324 depends on FOOTBRIDGE 325 help 326 Say Y here if you want the debug print routines to direct 327 their output to the serial port in the DC21285 (Footbridge). 328 329 config DEBUG_DIGICOLOR_UA0 330 bool "Kernel low-level debugging messages via Digicolor UA0" 331 depends on ARCH_DIGICOLOR 332 help 333 Say Y here if you want the debug print routines to direct 334 their output to the UA0 serial port in the CX92755. 335 336 config DEBUG_EP93XX 337 bool "Kernel low-level debugging messages via ep93xx UART" 338 depends on ARCH_EP93XX 339 select DEBUG_UART_PL01X 340 help 341 Say Y here if you want kernel low-level debugging support 342 on Cirrus Logic EP93xx based platforms. 343 344 config DEBUG_FOOTBRIDGE_COM1 345 bool "Kernel low-level debugging messages via footbridge 8250 at PCI COM1" 346 depends on FOOTBRIDGE 347 select DEBUG_UART_8250 348 help 349 Say Y here if you want the debug print routines to direct 350 their output to the 8250 at PCI COM1. 351 352 config DEBUG_GEMINI 353 bool "Kernel low-level debugging messages via Cortina Systems Gemini UART" 354 depends on ARCH_GEMINI 355 select DEBUG_UART_8250 356 help 357 Say Y here if you want kernel low-level debugging support 358 on Cortina Gemini based platforms. 359 360 config DEBUG_HI3620_UART 361 bool "Hisilicon HI3620 Debug UART" 362 depends on ARCH_HI3xxx 363 select DEBUG_UART_PL01X 364 help 365 Say Y here if you want kernel low-level debugging support 366 on HI3620 UART. 367 368 config DEBUG_HIGHBANK_UART 369 bool "Kernel low-level debugging messages via Highbank UART" 370 depends on ARCH_HIGHBANK 371 select DEBUG_UART_PL01X 372 help 373 Say Y here if you want the debug print routines to direct 374 their output to the UART on Highbank based devices. 375 376 config DEBUG_HIP01_UART 377 bool "Hisilicon Hip01 Debug UART" 378 depends on ARCH_HIP01 379 select DEBUG_UART_8250 380 help 381 Say Y here if you want kernel low-level debugging support 382 on HIP01 UART. 383 384 config DEBUG_HIP04_UART 385 bool "Hisilicon HiP04 Debug UART" 386 depends on ARCH_HIP04 387 select DEBUG_UART_8250 388 help 389 Say Y here if you want kernel low-level debugging support 390 on HIP04 UART. 391 392 config DEBUG_HIX5HD2_UART 393 bool "Hisilicon Hix5hd2 Debug UART" 394 depends on ARCH_HIX5HD2 395 select DEBUG_UART_PL01X 396 help 397 Say Y here if you want kernel low-level debugging support 398 on Hix5hd2 UART. 399 400 config DEBUG_IMX1_UART 401 bool "i.MX1 Debug UART" 402 depends on SOC_IMX1 403 help 404 Say Y here if you want kernel low-level debugging support 405 on i.MX1. 406 407 config DEBUG_IMX23_UART 408 bool "i.MX23 Debug UART" 409 depends on SOC_IMX23 410 select DEBUG_UART_PL01X 411 help 412 Say Y here if you want kernel low-level debugging support 413 on i.MX23. 414 415 config DEBUG_IMX25_UART 416 bool "i.MX25 Debug UART" 417 depends on SOC_IMX25 418 help 419 Say Y here if you want kernel low-level debugging support 420 on i.MX25. 421 422 config DEBUG_IMX27_UART 423 bool "i.MX27 Debug UART" 424 depends on SOC_IMX27 425 help 426 Say Y here if you want kernel low-level debugging support 427 on i.MX27. 428 429 config DEBUG_IMX28_UART 430 bool "i.MX28 Debug UART" 431 depends on SOC_IMX28 432 select DEBUG_UART_PL01X 433 help 434 Say Y here if you want kernel low-level debugging support 435 on i.MX28. 436 437 config DEBUG_IMX31_UART 438 bool "i.MX31 Debug UART" 439 depends on SOC_IMX31 440 help 441 Say Y here if you want kernel low-level debugging support 442 on i.MX31. 443 444 config DEBUG_IMX35_UART 445 bool "i.MX35 Debug UART" 446 depends on SOC_IMX35 447 help 448 Say Y here if you want kernel low-level debugging support 449 on i.MX35. 450 451 config DEBUG_IMX50_UART 452 bool "i.MX50 Debug UART" 453 depends on SOC_IMX50 454 help 455 Say Y here if you want kernel low-level debugging support 456 on i.MX50. 457 458 config DEBUG_IMX51_UART 459 bool "i.MX51 Debug UART" 460 depends on SOC_IMX51 461 help 462 Say Y here if you want kernel low-level debugging support 463 on i.MX51. 464 465 config DEBUG_IMX53_UART 466 bool "i.MX53 Debug UART" 467 depends on SOC_IMX53 468 help 469 Say Y here if you want kernel low-level debugging support 470 on i.MX53. 471 472 config DEBUG_IMX6Q_UART 473 bool "i.MX6Q/DL Debug UART" 474 depends on SOC_IMX6Q 475 help 476 Say Y here if you want kernel low-level debugging support 477 on i.MX6Q/DL. 478 479 config DEBUG_IMX6SL_UART 480 bool "i.MX6SL Debug UART" 481 depends on SOC_IMX6SL 482 help 483 Say Y here if you want kernel low-level debugging support 484 on i.MX6SL. 485 486 config DEBUG_IMX6SX_UART 487 bool "i.MX6SX Debug UART" 488 depends on SOC_IMX6SX 489 help 490 Say Y here if you want kernel low-level debugging support 491 on i.MX6SX. 492 493 config DEBUG_IMX6UL_UART 494 bool "i.MX6UL Debug UART" 495 depends on SOC_IMX6UL 496 help 497 Say Y here if you want kernel low-level debugging support 498 on i.MX6UL. 499 500 config DEBUG_IMX7D_UART 501 bool "i.MX7D Debug UART" 502 depends on SOC_IMX7D 503 help 504 Say Y here if you want kernel low-level debugging support 505 on i.MX7D. 506 507 config DEBUG_INTEGRATOR 508 bool "Kernel low-level debugging messages via ARM Integrator UART" 509 depends on ARCH_INTEGRATOR 510 select DEBUG_UART_PL01X 511 help 512 Say Y here if you want kernel low-level debugging support 513 on ARM Integrator platforms. 514 515 config DEBUG_KEYSTONE_UART0 516 bool "Kernel low-level debugging on KEYSTONE2 using UART0" 517 depends on ARCH_KEYSTONE 518 select DEBUG_UART_8250 519 help 520 Say Y here if you want the debug print routines to direct 521 their output to UART0 serial port on KEYSTONE2 devices. 522 523 config DEBUG_KEYSTONE_UART1 524 bool "Kernel low-level debugging on KEYSTONE2 using UART1" 525 depends on ARCH_KEYSTONE 526 select DEBUG_UART_8250 527 help 528 Say Y here if you want the debug print routines to direct 529 their output to UART1 serial port on KEYSTONE2 devices. 530 531 config DEBUG_LPC18XX_UART0 532 bool "Kernel low-level debugging via LPC18xx/43xx UART0" 533 depends on ARCH_LPC18XX 534 select DEBUG_UART_8250 535 help 536 Say Y here if you want kernel low-level debugging support 537 on NXP LPC18xx/43xx UART0. 538 539 config DEBUG_LPC32XX 540 bool "Kernel low-level debugging messages via NXP LPC32xx UART" 541 depends on ARCH_LPC32XX 542 select DEBUG_UART_8250 543 help 544 Say Y here if you want kernel low-level debugging support 545 on NXP LPC32xx based platforms. 546 547 config DEBUG_MESON_UARTAO 548 bool "Kernel low-level debugging via Meson6 UARTAO" 549 depends on ARCH_MESON 550 help 551 Say Y here if you want kernel low-lever debugging support 552 on Amlogic Meson6 based platforms on the UARTAO. 553 554 config DEBUG_MMP_UART2 555 bool "Kernel low-level debugging message via MMP UART2" 556 depends on ARCH_MMP 557 select DEBUG_UART_8250 558 help 559 Say Y here if you want kernel low-level debugging support 560 on MMP UART2. 561 562 config DEBUG_MMP_UART3 563 bool "Kernel low-level debugging message via MMP UART3" 564 depends on ARCH_MMP 565 select DEBUG_UART_8250 566 help 567 Say Y here if you want kernel low-level debugging support 568 on MMP UART3. 569 570 config DEBUG_MVEBU_UART0 571 bool "Kernel low-level debugging messages via MVEBU UART0 (old bootloaders)" 572 depends on ARCH_MVEBU 573 depends on ARCH_MVEBU && CPU_V7 574 select DEBUG_UART_8250 575 help 576 Say Y here if you want kernel low-level debugging support 577 on MVEBU based platforms on UART0. 578 579 This option should be used with the old bootloaders 580 that left the internal registers mapped at 581 0xd0000000. As of today, this is the case on 582 platforms such as the Globalscale Mirabox or the 583 Plathome OpenBlocks AX3, when using the original 584 bootloader. 585 586 This option will not work on older Marvell platforms 587 (Kirkwood, Dove, MV78xx0, Orion5x), which should pick 588 the "new bootloader" variant. 589 590 If the wrong DEBUG_MVEBU_UART* option is selected, 591 when u-boot hands over to the kernel, the system 592 silently crashes, with no serial output at all. 593 594 config DEBUG_MVEBU_UART0_ALTERNATE 595 bool "Kernel low-level debugging messages via MVEBU UART0 (new bootloaders)" 596 depends on ARCH_MVEBU || ARCH_DOVE || ARCH_MV78XX0 || ARCH_ORION5X 597 select DEBUG_UART_8250 598 help 599 Say Y here if you want kernel low-level debugging support 600 on MVEBU based platforms on UART0. (Armada XP, Armada 3xx, 601 Kirkwood, Dove, MV78xx0, Orion5x). 602 603 604 This option should be used with the new bootloaders 605 that remap the internal registers at 0xf1000000. 606 607 If the wrong DEBUG_MVEBU_UART* option is selected, 608 when u-boot hands over to the kernel, the system 609 silently crashes, with no serial output at all. 610 611 config DEBUG_MVEBU_UART1_ALTERNATE 612 bool "Kernel low-level debugging messages via MVEBU UART1 (new bootloaders)" 613 depends on ARCH_MVEBU 614 select DEBUG_UART_8250 615 help 616 Say Y here if you want kernel low-level debugging support 617 on MVEBU based platforms on UART1. (Armada XP, Armada 3xx, 618 Kirkwood, Dove, MV78xx0, Orion5x). 619 620 This option should be used with the new bootloaders 621 that remap the internal registers at 0xf1000000. 622 All of the older (pre Armada XP/370) platforms also use 623 this address, regardless of the boot loader version. 624 625 If the wrong DEBUG_MVEBU_UART* option is selected, 626 when u-boot hands over to the kernel, the system 627 silently crashes, with no serial output at all. 628 629 config DEBUG_MSTARV7_PMUART 630 bool "Kernel low-level debugging messages via MSTARV7 PM UART" 631 depends on ARCH_MSTARV7 632 select DEBUG_UART_8250 633 help 634 Say Y here if you want kernel low-level debugging support 635 for MSTAR ARMv7-based platforms on PM UART. 636 637 config DEBUG_MT6589_UART0 638 bool "Mediatek mt6589 UART0" 639 depends on ARCH_MEDIATEK 640 select DEBUG_UART_8250 641 help 642 Say Y here if you want kernel low-level debugging support 643 for Mediatek mt6589 based platforms on UART0. 644 645 config DEBUG_MT8127_UART0 646 bool "Mediatek mt8127/mt6592 UART0" 647 depends on ARCH_MEDIATEK 648 select DEBUG_UART_8250 649 help 650 Say Y here if you want kernel low-level debugging support 651 for Mediatek mt8127 based platforms on UART0. 652 653 config DEBUG_MT8135_UART3 654 bool "Mediatek mt8135 UART3" 655 depends on ARCH_MEDIATEK 656 select DEBUG_UART_8250 657 help 658 Say Y here if you want kernel low-level debugging support 659 for Mediatek mt8135 based platforms on UART3. 660 661 config DEBUG_NOMADIK_UART 662 bool "Kernel low-level debugging messages via NOMADIK UART" 663 depends on ARCH_NOMADIK 664 select DEBUG_UART_PL01X 665 help 666 Say Y here if you want kernel low-level debugging support 667 on NOMADIK based platforms. 668 669 config DEBUG_NSPIRE_CLASSIC_UART 670 bool "Kernel low-level debugging via TI-NSPIRE 8250 UART" 671 depends on ARCH_NSPIRE 672 select DEBUG_UART_8250 673 help 674 Say Y here if you want kernel low-level debugging support 675 on TI-NSPIRE classic models. 676 677 config DEBUG_NSPIRE_CX_UART 678 bool "Kernel low-level debugging via TI-NSPIRE PL011 UART" 679 depends on ARCH_NSPIRE 680 select DEBUG_UART_PL01X 681 help 682 Say Y here if you want kernel low-level debugging support 683 on TI-NSPIRE CX models. 684 685 config DEBUG_OMAP1UART1 686 bool "Kernel low-level debugging via OMAP1 UART1" 687 depends on ARCH_OMAP1 688 select DEBUG_UART_8250 689 help 690 Say Y here if you want kernel low-level debugging support 691 on OMAP1 based platforms (except OMAP730) on the UART1. 692 693 config DEBUG_OMAP1UART2 694 bool "Kernel low-level debugging via OMAP1 UART2" 695 depends on ARCH_OMAP1 696 select DEBUG_UART_8250 697 help 698 Say Y here if you want kernel low-level debugging support 699 on OMAP1 based platforms (except OMAP730) on the UART2. 700 701 config DEBUG_OMAP1UART3 702 bool "Kernel low-level debugging via OMAP1 UART3" 703 depends on ARCH_OMAP1 704 select DEBUG_UART_8250 705 help 706 Say Y here if you want kernel low-level debugging support 707 on OMAP1 based platforms (except OMAP730) on the UART3. 708 709 config DEBUG_OMAP2UART1 710 bool "OMAP2/3/4 UART1 (omap2/3 sdp boards and some omap3 boards)" 711 depends on ARCH_OMAP2PLUS 712 select DEBUG_UART_8250 713 help 714 This covers at least h4, 2430sdp, 3430sdp, 3630sdp, 715 omap3 torpedo and 3530 lv som. 716 717 config DEBUG_OMAP2UART2 718 bool "Kernel low-level debugging messages via OMAP2/3/4 UART2" 719 depends on ARCH_OMAP2PLUS 720 select DEBUG_UART_8250 721 722 config DEBUG_OMAP2UART3 723 bool "Kernel low-level debugging messages via OMAP2 UART3 (n8x0)" 724 depends on ARCH_OMAP2PLUS 725 select DEBUG_UART_8250 726 727 config DEBUG_OMAP3UART3 728 bool "Kernel low-level debugging messages via OMAP3 UART3 (most omap3 boards)" 729 depends on ARCH_OMAP2PLUS 730 select DEBUG_UART_8250 731 help 732 This covers at least cm_t3x, beagle, crane, devkit8000, 733 igep00x0, ldp, n900, n9(50), pandora, overo, touchbook, 734 and 3517evm. 735 736 config DEBUG_OMAP4UART3 737 bool "Kernel low-level debugging messages via OMAP4/5 UART3 (omap4 blaze, panda, omap5 sevm)" 738 depends on ARCH_OMAP2PLUS 739 select DEBUG_UART_8250 740 741 config DEBUG_OMAP3UART4 742 bool "Kernel low-level debugging messages via OMAP36XX UART4" 743 depends on ARCH_OMAP2PLUS 744 select DEBUG_UART_8250 745 746 config DEBUG_OMAP4UART4 747 bool "Kernel low-level debugging messages via OMAP4/5 UART4" 748 depends on ARCH_OMAP2PLUS 749 select DEBUG_UART_8250 750 751 config DEBUG_OMAP7XXUART1 752 bool "Kernel low-level debugging via OMAP730 UART1" 753 depends on ARCH_OMAP730 754 select DEBUG_UART_8250 755 help 756 Say Y here if you want kernel low-level debugging support 757 on OMAP730 based platforms on the UART1. 758 759 config DEBUG_OMAP7XXUART2 760 bool "Kernel low-level debugging via OMAP730 UART2" 761 depends on ARCH_OMAP730 762 select DEBUG_UART_8250 763 help 764 Say Y here if you want kernel low-level debugging support 765 on OMAP730 based platforms on the UART2. 766 767 config DEBUG_OMAP7XXUART3 768 bool "Kernel low-level debugging via OMAP730 UART3" 769 depends on ARCH_OMAP730 770 select DEBUG_UART_8250 771 help 772 Say Y here if you want kernel low-level debugging support 773 on OMAP730 based platforms on the UART3. 774 775 config DEBUG_TI81XXUART1 776 bool "Kernel low-level debugging messages via TI81XX UART1 (ti8148evm)" 777 depends on ARCH_OMAP2PLUS 778 select DEBUG_UART_8250 779 780 config DEBUG_TI81XXUART2 781 bool "Kernel low-level debugging messages via TI81XX UART2" 782 depends on ARCH_OMAP2PLUS 783 select DEBUG_UART_8250 784 785 config DEBUG_TI81XXUART3 786 bool "Kernel low-level debugging messages via TI81XX UART3 (ti8168evm)" 787 depends on ARCH_OMAP2PLUS 788 select DEBUG_UART_8250 789 790 config DEBUG_AM33XXUART1 791 bool "Kernel low-level debugging messages via AM33XX UART1" 792 depends on ARCH_OMAP2PLUS 793 select DEBUG_UART_8250 794 795 config DEBUG_ZOOM_UART 796 bool "Kernel low-level debugging messages via Zoom2/3 UART" 797 depends on ARCH_OMAP2PLUS 798 select DEBUG_OMAP2PLUS_UART 799 800 config DEBUG_PXA_UART1 801 depends on ARCH_PXA 802 bool "Use PXA UART1 for low-level debug" 803 select DEBUG_UART_8250 804 help 805 Say Y here if you want kernel low-level debugging support 806 on PXA UART1. 807 808 config DEBUG_QCOM_UARTDM 809 bool "Kernel low-level debugging messages via QCOM UARTDM" 810 depends on ARCH_QCOM 811 help 812 Say Y here if you want the debug print routines to direct 813 their output to the serial port on Qualcomm devices. 814 815 ARCH DEBUG_UART_PHYS DEBUG_UART_VIRT 816 APQ8064 0x16640000 0xf0040000 817 APQ8084 0xf995e000 0xfa75e000 818 IPQ4019 0x078af000 0xf78af000 819 MSM8X60 0x19c40000 0xf0040000 820 MSM8960 0x16440000 0xf0040000 821 MSM8974 0xf991e000 0xfa71e000 822 823 Please adjust DEBUG_UART_PHYS and DEBUG_UART_BASE configuration 824 options based on your needs. 825 826 config DEBUG_REALVIEW_STD_PORT 827 bool "RealView Default UART" 828 depends on ARCH_REALVIEW 829 select DEBUG_UART_PL01X 830 help 831 Say Y here if you want the debug print routines to direct 832 their output to the serial port on RealView EB, PB11MP, PBA8 833 and PBX platforms. 834 835 config DEBUG_REALVIEW_PB1176_PORT 836 bool "RealView PB1176 UART" 837 depends on MACH_REALVIEW_PB1176 838 select DEBUG_UART_PL01X 839 help 840 Say Y here if you want the debug print routines to direct 841 their output to the standard serial port on the RealView 842 PB1176 platform. 843 844 config DEBUG_RV1108_UART0 845 bool "Kernel low-level debugging messages via Rockchip RV1108 UART0" 846 depends on ARCH_ROCKCHIP 847 select DEBUG_UART_8250 848 help 849 Say Y here if you want kernel low-level debugging support 850 on Rockchip RV1108 based platforms. 851 852 config DEBUG_RV1108_UART1 853 bool "Kernel low-level debugging messages via Rockchip RV1108 UART1" 854 depends on ARCH_ROCKCHIP 855 select DEBUG_UART_8250 856 help 857 Say Y here if you want kernel low-level debugging support 858 on Rockchip RV1108 based platforms. 859 860 config DEBUG_RV1108_UART2 861 bool "Kernel low-level debugging messages via Rockchip RV1108 UART2" 862 depends on ARCH_ROCKCHIP 863 select DEBUG_UART_8250 864 help 865 Say Y here if you want kernel low-level debugging support 866 on Rockchip RV1108 based platforms. 867 868 config DEBUG_RK29_UART0 869 bool "Kernel low-level debugging messages via Rockchip RK29 UART0" 870 depends on ARCH_ROCKCHIP 871 select DEBUG_UART_8250 872 help 873 Say Y here if you want kernel low-level debugging support 874 on Rockchip based platforms. 875 876 config DEBUG_RK29_UART1 877 bool "Kernel low-level debugging messages via Rockchip RK29 UART1" 878 depends on ARCH_ROCKCHIP 879 select DEBUG_UART_8250 880 help 881 Say Y here if you want kernel low-level debugging support 882 on Rockchip based platforms. 883 884 config DEBUG_RK29_UART2 885 bool "Kernel low-level debugging messages via Rockchip RK29 UART2" 886 depends on ARCH_ROCKCHIP 887 select DEBUG_UART_8250 888 help 889 Say Y here if you want kernel low-level debugging support 890 on Rockchip based platforms. 891 892 config DEBUG_RK3X_UART0 893 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART0" 894 depends on ARCH_ROCKCHIP 895 select DEBUG_UART_8250 896 help 897 Say Y here if you want kernel low-level debugging support 898 on Rockchip based platforms. 899 900 config DEBUG_RK3X_UART1 901 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART1" 902 depends on ARCH_ROCKCHIP 903 select DEBUG_UART_8250 904 help 905 Say Y here if you want kernel low-level debugging support 906 on Rockchip based platforms. 907 908 config DEBUG_RK3X_UART2 909 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART2" 910 depends on ARCH_ROCKCHIP 911 select DEBUG_UART_8250 912 help 913 Say Y here if you want kernel low-level debugging support 914 on Rockchip based platforms. 915 916 config DEBUG_RK3X_UART3 917 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART3" 918 depends on ARCH_ROCKCHIP 919 select DEBUG_UART_8250 920 help 921 Say Y here if you want kernel low-level debugging support 922 on Rockchip based platforms. 923 924 config DEBUG_RK32_UART2 925 bool "Kernel low-level debugging messages via Rockchip RK32 UART2" 926 depends on ARCH_ROCKCHIP 927 select DEBUG_UART_8250 928 help 929 Say Y here if you want kernel low-level debugging support 930 on Rockchip RK32xx based platforms. 931 932 config DEBUG_R7S72100_SCIF2 933 bool "Kernel low-level debugging messages via SCIF2 on R7S72100" 934 depends on ARCH_R7S72100 935 help 936 Say Y here if you want kernel low-level debugging support 937 via SCIF2 on Renesas RZ/A1H (R7S72100). 938 939 config DEBUG_R7S9210_SCIF2 940 bool "Kernel low-level debugging messages via SCIF2 on R7S9210" 941 depends on ARCH_R7S9210 942 help 943 Say Y here if you want kernel low-level debugging support 944 via SCIF2 on Renesas RZ/A2M (R7S9210). 945 946 config DEBUG_R7S9210_SCIF4 947 bool "Kernel low-level debugging messages via SCIF4 on R7S9210" 948 depends on ARCH_R7S9210 949 help 950 Say Y here if you want kernel low-level debugging support 951 via SCIF4 on Renesas RZ/A2M (R7S9210). 952 953 config DEBUG_RCAR_GEN1_SCIF0 954 bool "Kernel low-level debugging messages via SCIF0 on R8A7778" 955 depends on ARCH_R8A7778 956 help 957 Say Y here if you want kernel low-level debugging support 958 via SCIF0 on Renesas R-Car M1A (R8A7778). 959 960 config DEBUG_RCAR_GEN1_SCIF2 961 bool "Kernel low-level debugging messages via SCIF2 on R8A7779" 962 depends on ARCH_R8A7779 963 help 964 Say Y here if you want kernel low-level debugging support 965 via SCIF2 on Renesas R-Car H1 (R8A7779). 966 967 config DEBUG_RCAR_GEN2_SCIF0 968 bool "Kernel low-level debugging messages via SCIF0 on R-Car Gen2 and RZ/G1" 969 depends on ARCH_R8A7743 || ARCH_R8A7744 || ARCH_R8A7790 || \ 970 ARCH_R8A7791 || ARCH_R8A7792 || ARCH_R8A7793 971 help 972 Say Y here if you want kernel low-level debugging support 973 via SCIF0 on Renesas RZ/G1M (R8A7743), RZ/G1N (R8A7744), 974 R-Car H2 (R8A7790), M2-W (R8A7791), V2H (R8A7792), or 975 M2-N (R8A7793). 976 977 config DEBUG_RCAR_GEN2_SCIF1 978 bool "Kernel low-level debugging messages via SCIF1 on R8A77470" 979 depends on ARCH_R8A77470 980 help 981 Say Y here if you want kernel low-level debugging support 982 via SCIF1 on Renesas RZ/G1C (R8A77470). 983 984 config DEBUG_RCAR_GEN2_SCIF2 985 bool "Kernel low-level debugging messages via SCIF2 on R8A7794" 986 depends on ARCH_R8A7794 987 help 988 Say Y here if you want kernel low-level debugging support 989 via SCIF2 on Renesas R-Car E2 (R8A7794). 990 991 config DEBUG_RCAR_GEN2_SCIF4 992 bool "Kernel low-level debugging messages via SCIF4 on R8A7745" 993 depends on ARCH_R8A7745 994 help 995 Say Y here if you want kernel low-level debugging support 996 via SCIF4 on Renesas RZ/G1E (R8A7745). 997 998 config DEBUG_RCAR_GEN2_SCIFA2 999 bool "Kernel low-level debugging messages via SCIFA2 on R8A7742" 1000 depends on ARCH_R8A7742 1001 help 1002 Say Y here if you want kernel low-level debugging support 1003 via SCIFA2 on Renesas RZ/G1H (R8A7742). 1004 1005 config DEBUG_RMOBILE_SCIFA0 1006 bool "Kernel low-level debugging messages via SCIFA0 on R8A73A4" 1007 depends on ARCH_R8A73A4 1008 help 1009 Say Y here if you want kernel low-level debugging support 1010 via SCIFA0 on Renesas R-Mobile APE6 (R8A73A4). 1011 1012 config DEBUG_RMOBILE_SCIFA1 1013 bool "Kernel low-level debugging messages via SCIFA1 on R8A7740" 1014 depends on ARCH_R8A7740 1015 help 1016 Say Y here if you want kernel low-level debugging support 1017 via SCIFA1 on Renesas R-Mobile A1 (R8A7740). 1018 1019 config DEBUG_RMOBILE_SCIFA4 1020 bool "Kernel low-level debugging messages via SCIFA4 on SH73A0" 1021 depends on ARCH_SH73A0 1022 help 1023 Say Y here if you want kernel low-level debugging support 1024 via SCIFA4 on Renesas SH-Mobile AG5 (SH73A0). 1025 1026 config DEBUG_S3C_UART0 1027 depends on PLAT_SAMSUNG || ARCH_S5PV210 || ARCH_EXYNOS 1028 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 1029 select DEBUG_S3C24XX_UART if ARCH_S3C24XX 1030 select DEBUG_S3C64XX_UART if ARCH_S3C64XX 1031 select DEBUG_S5PV210_UART if ARCH_S5PV210 1032 bool "Use Samsung S3C UART 0 for low-level debug" 1033 help 1034 Say Y here if you want the debug print routines to direct 1035 their output to UART 0. The port must have been initialised 1036 by the boot-loader before use. 1037 1038 config DEBUG_S3C_UART1 1039 depends on PLAT_SAMSUNG || ARCH_S5PV210 || ARCH_EXYNOS 1040 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 1041 select DEBUG_S3C24XX_UART if ARCH_S3C24XX 1042 select DEBUG_S3C64XX_UART if ARCH_S3C64XX 1043 select DEBUG_S5PV210_UART if ARCH_S5PV210 1044 bool "Use Samsung S3C UART 1 for low-level debug" 1045 help 1046 Say Y here if you want the debug print routines to direct 1047 their output to UART 1. The port must have been initialised 1048 by the boot-loader before use. 1049 1050 config DEBUG_S3C_UART2 1051 depends on PLAT_SAMSUNG || ARCH_S5PV210 || ARCH_EXYNOS 1052 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 1053 select DEBUG_S3C24XX_UART if ARCH_S3C24XX 1054 select DEBUG_S3C64XX_UART if ARCH_S3C64XX 1055 select DEBUG_S5PV210_UART if ARCH_S5PV210 1056 bool "Use Samsung S3C UART 2 for low-level debug" 1057 help 1058 Say Y here if you want the debug print routines to direct 1059 their output to UART 2. The port must have been initialised 1060 by the boot-loader before use. 1061 1062 config DEBUG_S3C_UART3 1063 depends on ARCH_EXYNOS || ARCH_S5PV210 1064 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 1065 select DEBUG_S3C64XX_UART if ARCH_S3C64XX 1066 select DEBUG_S5PV210_UART if ARCH_S5PV210 1067 bool "Use Samsung S3C UART 3 for low-level debug" 1068 help 1069 Say Y here if you want the debug print routines to direct 1070 their output to UART 3. The port must have been initialised 1071 by the boot-loader before use. 1072 1073 config DEBUG_S3C2410_UART0 1074 depends on ARCH_S3C24XX 1075 select DEBUG_S3C2410_UART 1076 bool "Use S3C2410/S3C2412 UART 0 for low-level debug" 1077 help 1078 Say Y here if you want the debug print routines to direct 1079 their output to UART 0. The port must have been initialised 1080 by the boot-loader before use. 1081 1082 config DEBUG_S3C2410_UART1 1083 depends on ARCH_S3C24XX 1084 select DEBUG_S3C2410_UART 1085 bool "Use S3C2410/S3C2412 UART 1 for low-level debug" 1086 help 1087 Say Y here if you want the debug print routines to direct 1088 their output to UART 1. The port must have been initialised 1089 by the boot-loader before use. 1090 1091 config DEBUG_S3C2410_UART2 1092 depends on ARCH_S3C24XX 1093 select DEBUG_S3C2410_UART 1094 bool "Use S3C2410/S3C2412 UART 2 for low-level debug" 1095 help 1096 Say Y here if you want the debug print routines to direct 1097 their output to UART 2. The port must have been initialised 1098 by the boot-loader before use. 1099 1100 config DEBUG_SA1100 1101 depends on ARCH_SA1100 1102 bool "Use SA1100 UARTs for low-level debug" 1103 help 1104 Say Y here if you want kernel low-level debugging support 1105 on SA-11x0 UART ports. The kernel will check for the first 1106 enabled UART in a sequence 3-1-2. 1107 1108 config DEBUG_SD5203_UART 1109 bool "Hisilicon SD5203 Debug UART" 1110 depends on ARCH_SD5203 1111 select DEBUG_UART_8250 1112 help 1113 Say Y here if you want kernel low-level debugging support 1114 on SD5203 UART. 1115 1116 config DEBUG_SOCFPGA_UART0 1117 depends on ARCH_INTEL_SOCFPGA 1118 bool "Use SOCFPGA UART0 for low-level debug" 1119 select DEBUG_UART_8250 1120 help 1121 Say Y here if you want kernel low-level debugging support 1122 on SOCFPGA(Cyclone 5 and Arria 5) based platforms. 1123 1124 config DEBUG_SOCFPGA_ARRIA10_UART1 1125 depends on ARCH_INTEL_SOCFPGA 1126 bool "Use SOCFPGA Arria10 UART1 for low-level debug" 1127 select DEBUG_UART_8250 1128 help 1129 Say Y here if you want kernel low-level debugging support 1130 on SOCFPGA(Arria 10) based platforms. 1131 1132 config DEBUG_SOCFPGA_CYCLONE5_UART1 1133 depends on ARCH_INTEL_SOCFPGA 1134 bool "Use SOCFPGA Cyclone 5 UART1 for low-level debug" 1135 select DEBUG_UART_8250 1136 help 1137 Say Y here if you want kernel low-level debugging support 1138 on SOCFPGA(Cyclone 5 and Arria 5) based platforms. 1139 1140 config DEBUG_SUN9I_UART0 1141 bool "Kernel low-level debugging messages via sun9i UART0" 1142 depends on MACH_SUN9I 1143 select DEBUG_UART_8250 1144 help 1145 Say Y here if you want kernel low-level debugging support 1146 on Allwinner A80 based platforms on the UART0. 1147 1148 config DEBUG_SUNXI_UART0 1149 bool "Kernel low-level debugging messages via sunXi UART0" 1150 depends on ARCH_SUNXI 1151 select DEBUG_UART_8250 1152 help 1153 Say Y here if you want kernel low-level debugging support 1154 on Allwinner A1X based platforms on the UART0. 1155 1156 config DEBUG_SUNXI_UART1 1157 bool "Kernel low-level debugging messages via sunXi UART1" 1158 depends on ARCH_SUNXI 1159 select DEBUG_UART_8250 1160 help 1161 Say Y here if you want kernel low-level debugging support 1162 on Allwinner A1X based platforms on the UART1. 1163 1164 config DEBUG_SUNXI_R_UART 1165 bool "Kernel low-level debugging messages via sunXi R_UART" 1166 depends on MACH_SUN6I || MACH_SUN8I 1167 select DEBUG_UART_8250 1168 help 1169 Say Y here if you want kernel low-level debugging support 1170 on Allwinner A31/A23 based platforms on the R_UART. 1171 1172 config DEBUG_SPEAR3XX 1173 bool "Kernel low-level debugging messages via ST SPEAr 3xx/6xx UART" 1174 depends on ARCH_SPEAR3XX || ARCH_SPEAR6XX 1175 select DEBUG_UART_PL01X 1176 help 1177 Say Y here if you want kernel low-level debugging support 1178 on ST SPEAr based platforms. 1179 1180 config DEBUG_SPEAR13XX 1181 bool "Kernel low-level debugging messages via ST SPEAr 13xx UART" 1182 depends on ARCH_SPEAR13XX 1183 select DEBUG_UART_PL01X 1184 help 1185 Say Y here if you want kernel low-level debugging support 1186 on ST SPEAr13xx based platforms. 1187 1188 config DEBUG_STIH41X_ASC2 1189 bool "Use StiH415/416 ASC2 UART for low-level debug" 1190 depends on ARCH_STI 1191 help 1192 Say Y here if you want kernel low-level debugging support 1193 on STiH415/416 based platforms like b2000, which has 1194 default UART wired up to ASC2. 1195 1196 If unsure, say N. 1197 1198 config DEBUG_STIH41X_SBC_ASC1 1199 bool "Use StiH415/416 SBC ASC1 UART for low-level debug" 1200 depends on ARCH_STI 1201 help 1202 Say Y here if you want kernel low-level debugging support 1203 on STiH415/416 based platforms like b2020. which has 1204 default UART wired up to SBC ASC1. 1205 1206 If unsure, say N. 1207 1208 config DEBUG_STIH418_SBC_ASC0 1209 bool "Use StiH418 SBC ASC0 UART for low-level debug" 1210 depends on ARCH_STI 1211 help 1212 Say Y here if you want kernel low-level debugging support 1213 on STiH418 based platforms which has default UART wired 1214 up to SBC ASC0. 1215 1216 If unsure, say N. 1217 1218 config STM32F4_DEBUG_UART 1219 bool "Use STM32F4 UART for low-level debug" 1220 depends on MACH_STM32F429 || MACH_STM32F469 1221 select DEBUG_STM32_UART 1222 help 1223 Say Y here if you want kernel low-level debugging support 1224 on STM32F4 based platforms, which default UART is wired on 1225 USART1, but another UART instance can be selected by modifying 1226 CONFIG_DEBUG_UART_PHYS. 1227 1228 If unsure, say N. 1229 1230 config STM32F7_DEBUG_UART 1231 bool "Use STM32F7 UART for low-level debug" 1232 depends on MACH_STM32F746 || MACH_STM32F769 1233 select DEBUG_STM32_UART 1234 help 1235 Say Y here if you want kernel low-level debugging support 1236 on STM32F7 based platforms, which default UART is wired on 1237 USART1, but another UART instance can be selected by modifying 1238 CONFIG_DEBUG_UART_PHYS. 1239 1240 If unsure, say N. 1241 1242 config STM32H7_DEBUG_UART 1243 bool "Use STM32H7 UART for low-level debug" 1244 depends on MACH_STM32H743 1245 select DEBUG_STM32_UART 1246 help 1247 Say Y here if you want kernel low-level debugging support 1248 on STM32H7 based platforms, which default UART is wired on 1249 USART1, but another UART instance can be selected by modifying 1250 CONFIG_DEBUG_UART_PHYS. 1251 1252 If unsure, say N. 1253 1254 config STM32MP1_DEBUG_UART 1255 bool "Use STM32MP1 UART for low-level debug" 1256 depends on MACH_STM32MP157 1257 select DEBUG_STM32_UART 1258 help 1259 Say Y here if you want kernel low-level debugging support 1260 on STM32MP1 based platforms, wich default UART is wired on 1261 UART4, but another UART instance can be selected by modifying 1262 CONFIG_DEBUG_UART_PHYS and CONFIG_DEBUG_UART_VIRT. 1263 1264 If unsure, say N. 1265 1266 config TEGRA_DEBUG_UART_AUTO_ODMDATA 1267 bool "Kernel low-level debugging messages via Tegra UART via ODMDATA" 1268 depends on ARCH_TEGRA 1269 select DEBUG_TEGRA_UART 1270 help 1271 Automatically determines which UART to use for low-level 1272 debug based on the ODMDATA value. This value is part of 1273 the BCT, and is written to the boot memory device using 1274 nvflash, or other flashing tool. When bits 19:18 are 3, 1275 then bits 17:15 indicate which UART to use; 0/1/2/3/4 1276 are UART A/B/C/D/E. 1277 1278 config TEGRA_DEBUG_UARTA 1279 bool "Kernel low-level debugging messages via Tegra UART A" 1280 depends on ARCH_TEGRA 1281 select DEBUG_TEGRA_UART 1282 help 1283 Say Y here if you want kernel low-level debugging support 1284 on Tegra based platforms. 1285 1286 config TEGRA_DEBUG_UARTB 1287 bool "Kernel low-level debugging messages via Tegra UART B" 1288 depends on ARCH_TEGRA 1289 select DEBUG_TEGRA_UART 1290 help 1291 Say Y here if you want kernel low-level debugging support 1292 on Tegra based platforms. 1293 1294 config TEGRA_DEBUG_UARTC 1295 bool "Kernel low-level debugging messages via Tegra UART C" 1296 depends on ARCH_TEGRA 1297 select DEBUG_TEGRA_UART 1298 help 1299 Say Y here if you want kernel low-level debugging support 1300 on Tegra based platforms. 1301 1302 config TEGRA_DEBUG_UARTD 1303 bool "Kernel low-level debugging messages via Tegra UART D" 1304 depends on ARCH_TEGRA 1305 select DEBUG_TEGRA_UART 1306 help 1307 Say Y here if you want kernel low-level debugging support 1308 on Tegra based platforms. 1309 1310 config TEGRA_DEBUG_UARTE 1311 bool "Kernel low-level debugging messages via Tegra UART E" 1312 depends on ARCH_TEGRA 1313 select DEBUG_TEGRA_UART 1314 help 1315 Say Y here if you want kernel low-level debugging support 1316 on Tegra based platforms. 1317 1318 config DEBUG_UX500_UART 1319 depends on ARCH_U8500 1320 bool "Use Ux500 UART for low-level debug" 1321 help 1322 Say Y here if you want kernel low-level debugging support 1323 on Ux500 based platforms. 1324 1325 config DEBUG_VERSATILE 1326 bool "Kernel low-level debugging messages via ARM Versatile UART" 1327 depends on ARCH_VERSATILE 1328 select DEBUG_UART_PL01X 1329 help 1330 Say Y here if you want kernel low-level debugging support 1331 on ARM Versatile platforms. 1332 1333 config DEBUG_VEXPRESS_UART0_DETECT 1334 bool "Autodetect UART0 on Versatile Express Cortex-A core tiles" 1335 depends on ARCH_VEXPRESS && CPU_CP15_MMU 1336 help 1337 This option enables a simple heuristic which tries to determine 1338 the motherboard's memory map variant (original or RS1) and then 1339 choose the relevant UART0 base address. 1340 1341 Note that this will only work with standard A-class core tiles, 1342 and may fail with non-standard SMM or custom software models. 1343 1344 config DEBUG_VEXPRESS_UART0_CA9 1345 bool "Use PL011 UART0 at 0x10009000 (V2P-CA9 core tile)" 1346 depends on ARCH_VEXPRESS 1347 select DEBUG_UART_PL01X 1348 help 1349 This option selects UART0 at 0x10009000. Except for custom models, 1350 this applies only to the V2P-CA9 tile. 1351 1352 config DEBUG_VEXPRESS_UART0_RS1 1353 bool "Use PL011 UART0 at 0x1c090000 (RS1 complaint tiles)" 1354 depends on ARCH_VEXPRESS 1355 select DEBUG_UART_PL01X 1356 help 1357 This option selects UART0 at 0x1c090000. This applies to most 1358 of the tiles using the RS1 memory map, including all new A-class 1359 core tiles, FPGA-based SMMs and software models. 1360 1361 config DEBUG_VEXPRESS_UART0_CRX 1362 bool "Use PL011 UART0 at 0xb0090000 (Cortex-R compliant tiles)" 1363 depends on ARCH_VEXPRESS && !MMU 1364 select DEBUG_UART_PL01X 1365 help 1366 This option selects UART0 at 0xb0090000. This is appropriate for 1367 Cortex-R series tiles and SMMs, such as Cortex-R5 and Cortex-R7 1368 1369 config DEBUG_VF_UART 1370 bool "Vybrid UART" 1371 depends on SOC_VF610 1372 help 1373 Say Y here if you want kernel low-level debugging support 1374 on Vybrid based platforms. 1375 1376 config DEBUG_VT8500_UART0 1377 bool "Use UART0 on VIA/Wondermedia SoCs" 1378 depends on ARCH_VT8500 1379 help 1380 This option selects UART0 on VIA/Wondermedia System-on-a-chip 1381 devices, including VT8500, WM8505, WM8650 and WM8850. 1382 1383 config DEBUG_ZYNQ_UART0 1384 bool "Kernel low-level debugging on Xilinx Zynq using UART0" 1385 depends on ARCH_ZYNQ 1386 help 1387 Say Y here if you want the debug print routines to direct 1388 their output to UART0 on the Zynq platform. 1389 1390 config DEBUG_ZYNQ_UART1 1391 bool "Kernel low-level debugging on Xilinx Zynq using UART1" 1392 depends on ARCH_ZYNQ 1393 help 1394 Say Y here if you want the debug print routines to direct 1395 their output to UART1 on the Zynq platform. 1396 1397 If you have a ZC702 board and want early boot messages to 1398 appear on the USB serial adaptor, select this option. 1399 1400 config DEBUG_ICEDCC 1401 bool "Kernel low-level debugging via EmbeddedICE DCC channel" 1402 help 1403 Say Y here if you want the debug print routines to direct 1404 their output to the EmbeddedICE macrocell's DCC channel using 1405 co-processor 14. This is known to work on the ARM9 style ICE 1406 channel and on the XScale with the PEEDI. 1407 1408 Note that the system will appear to hang during boot if there 1409 is nothing connected to read from the DCC. 1410 1411 config DEBUG_SEMIHOSTING 1412 bool "Kernel low-level debug output via semihosting I/O" 1413 help 1414 Semihosting enables code running on an ARM target to use 1415 the I/O facilities on a host debugger/emulator through a 1416 simple SVC call. The host debugger or emulator must have 1417 semihosting enabled for the special svc call to be trapped 1418 otherwise the kernel will crash. 1419 1420 This is known to work with OpenOCD, as well as 1421 ARM's Fast Models, or any other controlling environment 1422 that implements semihosting. 1423 1424 For more details about semihosting, please see 1425 chapter 8 of DUI0203I_rvct_developer_guide.pdf from ARM Ltd. 1426 1427 config DEBUG_LL_UART_8250 1428 bool "Kernel low-level debugging via 8250 UART" 1429 help 1430 Say Y here if you wish the debug print routes to direct 1431 their output to an 8250 UART. You can use this option 1432 to provide the parameters for the 8250 UART rather than 1433 selecting one of the platform specific options above if 1434 you know the parameters for the port. 1435 1436 This option is preferred over the platform specific 1437 options; the platform specific options are deprecated 1438 and will be soon removed. 1439 1440 config DEBUG_LL_UART_PL01X 1441 bool "Kernel low-level debugging via ARM Ltd PL01x Primecell UART" 1442 help 1443 Say Y here if you wish the debug print routes to direct 1444 their output to a PL01x Primecell UART. You can use 1445 this option to provide the parameters for the UART 1446 rather than selecting one of the platform specific 1447 options above if you know the parameters for the port. 1448 1449 This option is preferred over the platform specific 1450 options; the platform specific options are deprecated 1451 and will be soon removed. 1452 1453endchoice 1454 1455config DEBUG_AT91_UART 1456 bool 1457 depends on ARCH_AT91 1458 1459config DEBUG_EXYNOS_UART 1460 bool 1461 1462config DEBUG_S3C2410_UART 1463 bool 1464 select DEBUG_S3C24XX_UART 1465 1466config DEBUG_S3C24XX_UART 1467 bool 1468 1469config DEBUG_S3C64XX_UART 1470 bool 1471 1472config DEBUG_S5PV210_UART 1473 bool 1474 1475config DEBUG_S3C_UART 1476 depends on DEBUG_S3C2410_UART || DEBUG_S3C24XX_UART || \ 1477 DEBUG_S3C64XX_UART || DEBUG_S5PV210_UART || \ 1478 DEBUG_EXYNOS_UART 1479 int 1480 default "0" if DEBUG_S3C_UART0 1481 default "1" if DEBUG_S3C_UART1 1482 default "2" if DEBUG_S3C_UART2 1483 default "3" if DEBUG_S3C_UART3 1484 1485config DEBUG_OMAP2PLUS_UART 1486 bool 1487 depends on ARCH_OMAP2PLUS 1488 1489config DEBUG_IMX_UART_PORT 1490 int "i.MX Debug UART Port Selection" 1491 depends on DEBUG_IMX1_UART || \ 1492 DEBUG_IMX25_UART || \ 1493 DEBUG_IMX27_UART || \ 1494 DEBUG_IMX31_UART || \ 1495 DEBUG_IMX35_UART || \ 1496 DEBUG_IMX50_UART || \ 1497 DEBUG_IMX51_UART || \ 1498 DEBUG_IMX53_UART || \ 1499 DEBUG_IMX6Q_UART || \ 1500 DEBUG_IMX6SL_UART || \ 1501 DEBUG_IMX6SX_UART || \ 1502 DEBUG_IMX6UL_UART || \ 1503 DEBUG_IMX7D_UART 1504 default 1 1505 help 1506 Choose UART port on which kernel low-level debug messages 1507 should be output. 1508 1509config DEBUG_VF_UART_PORT 1510 int "Vybrid Debug UART Port Selection" if DEBUG_VF_UART 1511 default 1 1512 range 0 3 1513 depends on SOC_VF610 1514 help 1515 Choose UART port on which kernel low-level debug messages 1516 should be output. 1517 1518config DEBUG_TEGRA_UART 1519 bool 1520 depends on ARCH_TEGRA 1521 1522config DEBUG_STM32_UART 1523 bool 1524 depends on ARCH_STM32 1525 1526config DEBUG_UART_FLOW_CONTROL 1527 bool "Enable flow control (CTS) for the debug UART" 1528 depends on DEBUG_LL 1529 default y if DEBUG_FOOTBRIDGE_COM1 || DEBUG_GEMINI || ARCH_RPC 1530 help 1531 Some UART ports are connected to terminals that will use modem 1532 control signals to indicate whether they are ready to receive text. 1533 In practice this means that the terminal is asserting the special 1534 control signal CTS (Clear To Send). If your debug UART supports 1535 this and your debug terminal will require it, enable this option. 1536 1537config DEBUG_LL_INCLUDE 1538 string 1539 default "debug/sa1100.S" if DEBUG_SA1100 1540 default "debug/palmchip.S" if DEBUG_UART_8250_PALMCHIP 1541 default "debug/8250.S" if DEBUG_LL_UART_8250 || DEBUG_UART_8250 1542 default "debug/at91.S" if DEBUG_AT91_UART 1543 default "debug/asm9260.S" if DEBUG_ASM9260_UART 1544 default "debug/clps711x.S" if DEBUG_CLPS711X_UART1 || DEBUG_CLPS711X_UART2 1545 default "debug/dc21285.S" if DEBUG_DC21285_PORT 1546 default "debug/meson.S" if DEBUG_MESON_UARTAO 1547 default "debug/pl01x.S" if DEBUG_LL_UART_PL01X || DEBUG_UART_PL01X 1548 default "debug/exynos.S" if DEBUG_EXYNOS_UART 1549 default "debug/icedcc.S" if DEBUG_ICEDCC 1550 default "debug/imx.S" if DEBUG_IMX1_UART || \ 1551 DEBUG_IMX25_UART || \ 1552 DEBUG_IMX27_UART || \ 1553 DEBUG_IMX31_UART || \ 1554 DEBUG_IMX35_UART || \ 1555 DEBUG_IMX50_UART || \ 1556 DEBUG_IMX51_UART || \ 1557 DEBUG_IMX53_UART || \ 1558 DEBUG_IMX6Q_UART || \ 1559 DEBUG_IMX6SL_UART || \ 1560 DEBUG_IMX6SX_UART || \ 1561 DEBUG_IMX6UL_UART || \ 1562 DEBUG_IMX7D_UART 1563 default "debug/msm.S" if DEBUG_QCOM_UARTDM 1564 default "debug/omap2plus.S" if DEBUG_OMAP2PLUS_UART 1565 default "debug/renesas-scif.S" if DEBUG_R7S72100_SCIF2 1566 default "debug/renesas-scif.S" if DEBUG_R7S9210_SCIF2 1567 default "debug/renesas-scif.S" if DEBUG_R7S9210_SCIF4 1568 default "debug/renesas-scif.S" if DEBUG_RCAR_GEN1_SCIF0 1569 default "debug/renesas-scif.S" if DEBUG_RCAR_GEN1_SCIF2 1570 default "debug/renesas-scif.S" if DEBUG_RCAR_GEN2_SCIF0 1571 default "debug/renesas-scif.S" if DEBUG_RCAR_GEN2_SCIF1 1572 default "debug/renesas-scif.S" if DEBUG_RCAR_GEN2_SCIF2 1573 default "debug/renesas-scif.S" if DEBUG_RCAR_GEN2_SCIF4 1574 default "debug/renesas-scif.S" if DEBUG_RCAR_GEN2_SCIFA2 1575 default "debug/renesas-scif.S" if DEBUG_RMOBILE_SCIFA0 1576 default "debug/renesas-scif.S" if DEBUG_RMOBILE_SCIFA1 1577 default "debug/renesas-scif.S" if DEBUG_RMOBILE_SCIFA4 1578 default "debug/s3c24xx.S" if DEBUG_S3C24XX_UART || DEBUG_S3C64XX_UART 1579 default "debug/s5pv210.S" if DEBUG_S5PV210_UART 1580 default "debug/sti.S" if DEBUG_STIH41X_ASC2 1581 default "debug/sti.S" if DEBUG_STIH41X_SBC_ASC1 1582 default "debug/sti.S" if DEBUG_STIH418_SBC_ASC0 1583 default "debug/stm32.S" if DEBUG_STM32_UART 1584 default "debug/tegra.S" if DEBUG_TEGRA_UART 1585 default "debug/ux500.S" if DEBUG_UX500_UART 1586 default "debug/vexpress.S" if DEBUG_VEXPRESS_UART0_DETECT 1587 default "debug/vf.S" if DEBUG_VF_UART 1588 default "debug/vt8500.S" if DEBUG_VT8500_UART0 1589 default "debug/zynq.S" if DEBUG_ZYNQ_UART0 || DEBUG_ZYNQ_UART1 1590 default "debug/bcm63xx.S" if DEBUG_BCM63XX_UART 1591 default "debug/digicolor.S" if DEBUG_DIGICOLOR_UA0 1592 default "debug/brcmstb.S" if DEBUG_BRCMSTB_UART 1593 default "mach/debug-macro.S" 1594 1595# Compatibility options for PL01x 1596config DEBUG_UART_PL01X 1597 bool 1598 1599# Compatibility options for 8250 1600config DEBUG_UART_8250 1601 def_bool ARCH_IOP32X || ARCH_IXP4XX || ARCH_RPC 1602 1603config DEBUG_UART_PHYS 1604 hex "Physical base address of debug UART" 1605 default 0x01c20000 if DEBUG_DAVINCI_DMx_UART0 1606 default 0x01c28000 if DEBUG_SUNXI_UART0 1607 default 0x01c28400 if DEBUG_SUNXI_UART1 1608 default 0x01d0c000 if DEBUG_DAVINCI_DA8XX_UART1 1609 default 0x01d0d000 if DEBUG_DAVINCI_DA8XX_UART2 1610 default 0x01f02800 if DEBUG_SUNXI_R_UART 1611 default 0x02530c00 if DEBUG_KEYSTONE_UART0 1612 default 0x02531000 if DEBUG_KEYSTONE_UART1 1613 default 0x03010fe0 if ARCH_RPC 1614 default 0x07000000 if DEBUG_SUN9I_UART0 1615 default 0x09530000 if DEBUG_STIH418_SBC_ASC0 1616 default 0x10009000 if DEBUG_REALVIEW_STD_PORT || \ 1617 DEBUG_VEXPRESS_UART0_CA9 1618 default 0x1010c000 if DEBUG_REALVIEW_PB1176_PORT 1619 default 0x10124000 if DEBUG_RK3X_UART0 1620 default 0x10126000 if DEBUG_RK3X_UART1 1621 default 0x101f1000 if DEBUG_VERSATILE 1622 default 0x101fb000 if DEBUG_NOMADIK_UART 1623 default 0x10210000 if DEBUG_RV1108_UART2 1624 default 0x10220000 if DEBUG_RV1108_UART1 1625 default 0x10230000 if DEBUG_RV1108_UART0 1626 default 0x11002000 if DEBUG_MT8127_UART0 1627 default 0x11006000 if DEBUG_MT6589_UART0 1628 default 0x11009000 if DEBUG_MT8135_UART3 1629 default 0x16000000 if DEBUG_INTEGRATOR 1630 default 0x1600d000 if DEBUG_SD5203_UART 1631 default 0x18000300 if DEBUG_BCM_5301X 1632 default 0x18000400 if DEBUG_BCM_HR2 1633 default 0x18023000 if DEBUG_BCM_IPROC_UART3 1634 default 0x1c090000 if DEBUG_VEXPRESS_UART0_RS1 1635 default 0x1f221000 if DEBUG_MSTARV7_PMUART 1636 default 0x20001000 if DEBUG_HIP01_UART 1637 default 0x20060000 if DEBUG_RK29_UART0 1638 default 0x20064000 if DEBUG_RK29_UART1 || DEBUG_RK3X_UART2 1639 default 0x20068000 if DEBUG_RK29_UART2 || DEBUG_RK3X_UART3 1640 default 0x20201000 if DEBUG_BCM2835 1641 default 0x3e000000 if DEBUG_BCM_KONA_UART 1642 default 0x3f201000 if DEBUG_BCM2836 1643 default 0x40010000 if STM32MP1_DEBUG_UART 1644 default 0x40011000 if STM32F4_DEBUG_UART || STM32F7_DEBUG_UART || \ 1645 STM32H7_DEBUG_UART 1646 default 0x40028000 if DEBUG_AT91_SAMV7_USART1 1647 default 0x40081000 if DEBUG_LPC18XX_UART0 1648 default 0x40090000 if DEBUG_LPC32XX 1649 default 0x40100000 if DEBUG_PXA_UART1 1650 default 0x42000000 if DEBUG_GEMINI 1651 default 0x44e09000 if DEBUG_AM33XXUART1 1652 default 0x48020000 if DEBUG_OMAP4UART3 || DEBUG_TI81XXUART1 1653 default 0x48022000 if DEBUG_TI81XXUART2 1654 default 0x48024000 if DEBUG_TI81XXUART3 1655 default 0x4806a000 if DEBUG_OMAP2UART1 || DEBUG_OMAP3UART1 || \ 1656 DEBUG_OMAP4UART1 || DEBUG_OMAP5UART1 1657 default 0x4806c000 if DEBUG_OMAP2UART2 || DEBUG_OMAP3UART2 || \ 1658 DEBUG_OMAP4UART2 || DEBUG_OMAP5UART2 1659 default 0x4806e000 if DEBUG_OMAP2UART3 || DEBUG_OMAP4UART4 1660 default 0x49020000 if DEBUG_OMAP3UART3 1661 default 0x49042000 if DEBUG_OMAP3UART4 1662 default 0x50000000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART0 || \ 1663 DEBUG_S3C2410_UART0) 1664 default 0x50004000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART1 || \ 1665 DEBUG_S3C2410_UART1) 1666 default 0x50008000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART2 || \ 1667 DEBUG_S3C2410_UART2) 1668 default 0x78000000 if DEBUG_CNS3XXX 1669 default 0x7c0003f8 if DEBUG_FOOTBRIDGE_COM1 1670 default 0x7f005000 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART0 1671 default 0x7f005400 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART1 1672 default 0x7f005800 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART2 1673 default 0x7f005c00 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART3 1674 default 0x80010000 if DEBUG_ASM9260_UART 1675 default 0x80070000 if DEBUG_IMX23_UART 1676 default 0x80074000 if DEBUG_IMX28_UART 1677 default 0x808c0000 if DEBUG_EP93XX || ARCH_EP93XX 1678 default 0x90020000 if DEBUG_NSPIRE_CLASSIC_UART || DEBUG_NSPIRE_CX_UART 1679 default 0xb0090000 if DEBUG_VEXPRESS_UART0_CRX 1680 default 0xc8000000 if ARCH_IXP4XX && !CPU_BIG_ENDIAN 1681 default 0xc8000003 if ARCH_IXP4XX && CPU_BIG_ENDIAN 1682 default 0xd0000000 if DEBUG_SPEAR3XX 1683 default 0xd0012000 if DEBUG_MVEBU_UART0 1684 default 0xc81004c0 if DEBUG_MESON_UARTAO 1685 default 0xd4017000 if DEBUG_MMP_UART2 1686 default 0xd4018000 if DEBUG_MMP_UART3 1687 default 0xe0000000 if DEBUG_SPEAR13XX 1688 default 0xe1824200 if DEBUG_AT91_SAMA7G5_FLEXCOM3 1689 default 0xe4007000 if DEBUG_HIP04_UART 1690 default 0xe6c40000 if DEBUG_RMOBILE_SCIFA0 1691 default 0xe6c50000 if DEBUG_RMOBILE_SCIFA1 1692 default 0xe6c60000 if DEBUG_RCAR_GEN2_SCIFA2 1693 default 0xe6c80000 if DEBUG_RMOBILE_SCIFA4 1694 default 0xe6e58000 if DEBUG_RCAR_GEN2_SCIF2 1695 default 0xe6e60000 if DEBUG_RCAR_GEN2_SCIF0 1696 default 0xe6e68000 if DEBUG_RCAR_GEN2_SCIF1 1697 default 0xe6ee0000 if DEBUG_RCAR_GEN2_SCIF4 1698 default 0xe8008000 if DEBUG_R7S72100_SCIF2 || DEBUG_R7S9210_SCIF2 1699 default 0xe8009000 if DEBUG_R7S9210_SCIF4 1700 default 0xf0000000 if DEBUG_DIGICOLOR_UA0 1701 default 0xf1012000 if DEBUG_MVEBU_UART0_ALTERNATE 1702 default 0xf1012100 if DEBUG_MVEBU_UART1_ALTERNATE 1703 default 0xf7fc9000 if DEBUG_BERLIN_UART 1704 default 0xf8020000 if DEBUG_AT91_SAMA5D2_UART1 1705 default 0xf8b00000 if DEBUG_HIX5HD2_UART 1706 default 0xf991e000 if DEBUG_QCOM_UARTDM 1707 default 0xfc00c000 if DEBUG_AT91_SAMA5D4_USART3 1708 default 0xfcb00000 if DEBUG_HI3620_UART 1709 default 0xfd883000 if DEBUG_ALPINE_UART0 1710 default 0xfe531000 if DEBUG_STIH41X_SBC_ASC1 1711 default 0xfe800000 if ARCH_IOP32X 1712 default 0xfed32000 if DEBUG_STIH41X_ASC2 1713 default 0xff690000 if DEBUG_RK32_UART2 1714 default 0xffc02000 if DEBUG_SOCFPGA_UART0 1715 default 0xffc02100 if DEBUG_SOCFPGA_ARRIA10_UART1 1716 default 0xffc03000 if DEBUG_SOCFPGA_CYCLONE5_UART1 1717 default 0xffe40000 if DEBUG_RCAR_GEN1_SCIF0 1718 default 0xffe42000 if DEBUG_RCAR_GEN1_SCIF2 1719 default 0xfff36000 if DEBUG_HIGHBANK_UART 1720 default 0xfffb0000 if DEBUG_OMAP1UART1 || DEBUG_OMAP7XXUART1 1721 default 0xfffb0800 if DEBUG_OMAP1UART2 || DEBUG_OMAP7XXUART2 1722 default 0xfffb9800 if DEBUG_OMAP1UART3 || DEBUG_OMAP7XXUART3 1723 default 0xfffe8600 if DEBUG_BCM63XX_UART 1724 default 0xffffee00 if DEBUG_AT91_SAM9263_DBGU 1725 default 0xfffff200 if DEBUG_AT91_RM9200_DBGU 1726 depends on ARCH_EP93XX || \ 1727 DEBUG_LL_UART_8250 || DEBUG_LL_UART_PL01X || \ 1728 DEBUG_UART_8250 || DEBUG_UART_PL01X || DEBUG_MESON_UARTAO || \ 1729 DEBUG_QCOM_UARTDM || DEBUG_R7S72100_SCIF2 || \ 1730 DEBUG_R7S9210_SCIF2 || DEBUG_R7S9210_SCIF4 || \ 1731 DEBUG_RCAR_GEN1_SCIF0 || DEBUG_RCAR_GEN1_SCIF2 || \ 1732 DEBUG_RCAR_GEN2_SCIF0 || DEBUG_RCAR_GEN2_SCIF1 || \ 1733 DEBUG_RCAR_GEN2_SCIF2 || DEBUG_RCAR_GEN2_SCIF4 || \ 1734 DEBUG_RCAR_GEN2_SCIFA2 || \ 1735 DEBUG_RMOBILE_SCIFA0 || DEBUG_RMOBILE_SCIFA1 || \ 1736 DEBUG_RMOBILE_SCIFA4 || DEBUG_S3C24XX_UART || \ 1737 DEBUG_S3C64XX_UART || \ 1738 DEBUG_BCM63XX_UART || DEBUG_ASM9260_UART || \ 1739 DEBUG_DIGICOLOR_UA0 || \ 1740 DEBUG_AT91_UART || DEBUG_STM32_UART || \ 1741 DEBUG_STIH41X_ASC2 || DEBUG_STIH41X_SBC_ASC1 || \ 1742 DEBUG_STIH418_SBC_ASC0 1743 1744config DEBUG_UART_VIRT 1745 hex "Virtual base address of debug UART" 1746 default 0xc881f000 if DEBUG_RV1108_UART2 1747 default 0xc8821000 if DEBUG_RV1108_UART1 1748 default 0xc8912000 if DEBUG_RV1108_UART0 1749 default 0xe0010fe0 if ARCH_RPC 1750 default 0xe0824200 if DEBUG_AT91_SAMA7G5_FLEXCOM3 1751 default 0xf0010000 if DEBUG_ASM9260_UART 1752 default 0xf0100000 if DEBUG_DIGICOLOR_UA0 1753 default 0xf01fb000 if DEBUG_NOMADIK_UART 1754 default 0xf0201000 if DEBUG_BCM2835 || DEBUG_BCM2836 1755 default 0xf0221000 if DEBUG_MSTARV7_PMUART 1756 default 0xf1000300 if DEBUG_BCM_5301X 1757 default 0xf1000400 if DEBUG_BCM_HR2 1758 default 0xf1002000 if DEBUG_MT8127_UART0 1759 default 0xf1006000 if DEBUG_MT6589_UART0 1760 default 0xf1009000 if DEBUG_MT8135_UART3 1761 default 0xf1023000 if DEBUG_BCM_IPROC_UART3 1762 default 0xf11f1000 if DEBUG_VERSATILE 1763 default 0xf1600000 if DEBUG_INTEGRATOR 1764 default 0xf1c28000 if DEBUG_SUNXI_UART0 1765 default 0xf1c28400 if DEBUG_SUNXI_UART1 1766 default 0xf1f02800 if DEBUG_SUNXI_R_UART 1767 default 0xf31004c0 if DEBUG_MESON_UARTAO 1768 default 0xf4090000 if DEBUG_LPC32XX 1769 default 0xf4200000 if DEBUG_GEMINI 1770 default 0xf6200000 if DEBUG_PXA_UART1 1771 default 0xf7000000 if DEBUG_SUN9I_UART0 1772 default 0xf7000000 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART0 1773 default 0xf7000000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART0 || \ 1774 DEBUG_S3C2410_UART0) 1775 default 0xf7000400 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART1 1776 default 0xf7000800 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART2 1777 default 0xf7000c00 if DEBUG_S3C64XX_UART && DEBUG_S3C_UART3 1778 default 0xf7004000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART1 || \ 1779 DEBUG_S3C2410_UART1) 1780 default 0xf7008000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART2 || \ 1781 DEBUG_S3C2410_UART2) 1782 default 0xf7020000 if DEBUG_AT91_SAMA5D2_UART1 1783 default 0xf7fc9000 if DEBUG_BERLIN_UART 1784 default 0xf8007000 if DEBUG_HIP04_UART 1785 default 0xf8009000 if DEBUG_VEXPRESS_UART0_CA9 1786 default 0xf8090000 if DEBUG_VEXPRESS_UART0_RS1 1787 default 0xf8ffee00 if DEBUG_AT91_SAM9263_DBGU 1788 default 0xf8fff200 if DEBUG_AT91_RM9200_DBGU 1789 default 0xf9530000 if DEBUG_STIH418_SBC_ASC0 1790 default 0xf9e09000 if DEBUG_AM33XXUART1 1791 default 0xfa020000 if DEBUG_OMAP4UART3 || DEBUG_TI81XXUART1 1792 default 0xfa022000 if DEBUG_TI81XXUART2 1793 default 0xfa024000 if DEBUG_TI81XXUART3 1794 default 0xfa06a000 if DEBUG_OMAP2UART1 || DEBUG_OMAP3UART1 || \ 1795 DEBUG_OMAP4UART1 || DEBUG_OMAP5UART1 1796 default 0xfa06c000 if DEBUG_OMAP2UART2 || DEBUG_OMAP3UART2 || \ 1797 DEBUG_OMAP4UART2 || DEBUG_OMAP5UART2 1798 default 0xfa06e000 if DEBUG_OMAP2UART3 || DEBUG_OMAP4UART4 1799 default 0xfa71e000 if DEBUG_QCOM_UARTDM 1800 default 0xfb002000 if DEBUG_CNS3XXX 1801 default 0xfb009000 if DEBUG_REALVIEW_STD_PORT 1802 default 0xfb00c000 if DEBUG_AT91_SAMA5D4_USART3 1803 default 0xfb020000 if DEBUG_OMAP3UART3 1804 default 0xfb042000 if DEBUG_OMAP3UART4 1805 default 0xfb10c000 if DEBUG_REALVIEW_PB1176_PORT 1806 default 0xfcfe8600 if DEBUG_BCM63XX_UART 1807 default 0xfd000000 if DEBUG_SPEAR3XX || DEBUG_SPEAR13XX 1808 default 0xfd531000 if DEBUG_STIH41X_SBC_ASC1 1809 default 0xfd883000 if DEBUG_ALPINE_UART0 1810 default 0xfdd32000 if DEBUG_STIH41X_ASC2 1811 default 0xfe010000 if STM32MP1_DEBUG_UART 1812 default 0xfe017000 if DEBUG_MMP_UART2 1813 default 0xfe018000 if DEBUG_MMP_UART3 1814 default 0xfe100000 if DEBUG_IMX23_UART || DEBUG_IMX28_UART 1815 default 0xfe300000 if DEBUG_BCM_KONA_UART 1816 default 0xfe800000 if ARCH_IOP32X 1817 default 0xfeb00000 if DEBUG_HI3620_UART || DEBUG_HIX5HD2_UART 1818 default 0xfeb24000 if DEBUG_RK3X_UART0 1819 default 0xfeb26000 if DEBUG_RK3X_UART1 1820 default 0xfeb30c00 if DEBUG_KEYSTONE_UART0 1821 default 0xfeb31000 if DEBUG_KEYSTONE_UART1 1822 default 0xfec02000 if DEBUG_SOCFPGA_UART0 1823 default 0xfec02100 if DEBUG_SOCFPGA_ARRIA10_UART1 1824 default 0xfec03000 if DEBUG_SOCFPGA_CYCLONE5_UART1 1825 default 0xfec12000 if DEBUG_MVEBU_UART0 || DEBUG_MVEBU_UART0_ALTERNATE 1826 default 0xfec12100 if DEBUG_MVEBU_UART1_ALTERNATE 1827 default 0xfec20000 if DEBUG_DAVINCI_DMx_UART0 1828 default 0xfec90000 if DEBUG_RK32_UART2 1829 default 0xfed0c000 if DEBUG_DAVINCI_DA8XX_UART1 1830 default 0xfed0d000 if DEBUG_DAVINCI_DA8XX_UART2 || DEBUG_SD5203_UART 1831 default 0xfed60000 if DEBUG_RK29_UART0 1832 default 0xfed64000 if DEBUG_RK29_UART1 || DEBUG_RK3X_UART2 1833 default 0xfed68000 if DEBUG_RK29_UART2 || DEBUG_RK3X_UART3 1834 default 0xfedc0000 if DEBUG_EP93XX 1835 default 0xfee003f8 if DEBUG_FOOTBRIDGE_COM1 1836 default 0xfee20000 if DEBUG_NSPIRE_CLASSIC_UART || DEBUG_NSPIRE_CX_UART 1837 default 0xfec00000 if ARCH_IXP4XX && !CPU_BIG_ENDIAN 1838 default 0xfec00003 if ARCH_IXP4XX && CPU_BIG_ENDIAN 1839 default 0xfef36000 if DEBUG_HIGHBANK_UART 1840 default 0xfefb0000 if DEBUG_OMAP1UART1 || DEBUG_OMAP7XXUART1 1841 default 0xfefb0800 if DEBUG_OMAP1UART2 || DEBUG_OMAP7XXUART2 1842 default 0xfefb9800 if DEBUG_OMAP1UART3 || DEBUG_OMAP7XXUART3 1843 default 0xffd01000 if DEBUG_HIP01_UART 1844 default DEBUG_UART_PHYS if !MMU 1845 depends on DEBUG_LL_UART_8250 || DEBUG_LL_UART_PL01X || \ 1846 DEBUG_UART_8250 || DEBUG_UART_PL01X || DEBUG_MESON_UARTAO || \ 1847 DEBUG_QCOM_UARTDM || DEBUG_S3C24XX_UART || \ 1848 DEBUG_S3C64XX_UART || \ 1849 DEBUG_BCM63XX_UART || DEBUG_ASM9260_UART || \ 1850 DEBUG_DIGICOLOR_UA0 || \ 1851 DEBUG_AT91_UART || DEBUG_STM32_UART || \ 1852 DEBUG_STIH41X_ASC2 || DEBUG_STIH41X_SBC_ASC1 || \ 1853 DEBUG_STIH418_SBC_ASC0 1854 1855config DEBUG_UART_8250_SHIFT 1856 int "Register offset shift for the 8250 debug UART" 1857 depends on DEBUG_LL_UART_8250 || DEBUG_UART_8250 1858 default 0 if DEBUG_FOOTBRIDGE_COM1 || ARCH_IOP32X || DEBUG_BCM_5301X || \ 1859 DEBUG_BCM_HR2 || DEBUG_OMAP7XXUART1 || DEBUG_OMAP7XXUART2 || \ 1860 DEBUG_OMAP7XXUART3 1861 default 3 if DEBUG_MSTARV7_PMUART 1862 default 2 1863 1864config DEBUG_UART_8250_WORD 1865 bool "Use 32-bit accesses for 8250 UART" 1866 depends on DEBUG_LL_UART_8250 || DEBUG_UART_8250 1867 depends on DEBUG_UART_8250_SHIFT >= 2 1868 default y if DEBUG_SOCFPGA_UART0 || DEBUG_SOCFPGA_ARRIA10_UART1 || \ 1869 DEBUG_SOCFPGA_CYCLONE5_UART1 || DEBUG_KEYSTONE_UART0 || \ 1870 DEBUG_KEYSTONE_UART1 || DEBUG_ALPINE_UART0 || \ 1871 DEBUG_DAVINCI_DMx_UART0 || DEBUG_DAVINCI_DA8XX_UART1 || \ 1872 DEBUG_DAVINCI_DA8XX_UART2 || DEBUG_BCM_IPROC_UART3 || \ 1873 DEBUG_BCM_KONA_UART || DEBUG_RK32_UART2 1874 1875config DEBUG_UART_8250_PALMCHIP 1876 bool "8250 UART is Palmchip BK-310x" 1877 depends on DEBUG_LL_UART_8250 || DEBUG_UART_8250 1878 help 1879 Palmchip provides a UART implementation compatible with 16550 1880 except for having a different register layout. Say Y here if 1881 the debug UART is of this type. 1882 1883config DEBUG_UNCOMPRESS 1884 bool "Enable decompressor debugging via DEBUG_LL output" 1885 depends on ARCH_MULTIPLATFORM || PLAT_SAMSUNG || ARM_SINGLE_ARMV7M 1886 depends on DEBUG_LL && !DEBUG_OMAP2PLUS_UART && \ 1887 (!DEBUG_TEGRA_UART || !ZBOOT_ROM) && \ 1888 !DEBUG_BRCMSTB_UART && !DEBUG_SEMIHOSTING 1889 help 1890 This option influences the normal decompressor output for 1891 multiplatform kernels. Normally, multiplatform kernels disable 1892 decompressor output because it is not possible to know where to 1893 send the decompressor output. 1894 1895 When this option is set, the selected DEBUG_LL output method 1896 will be re-used for normal decompressor output on multiplatform 1897 kernels. 1898 1899 1900config UNCOMPRESS_INCLUDE 1901 string 1902 default "debug/uncompress.h" if ARCH_MULTIPLATFORM || ARCH_MSM || \ 1903 PLAT_SAMSUNG || ARM_SINGLE_ARMV7M 1904 default "mach/uncompress.h" 1905 1906config EARLY_PRINTK 1907 bool "Early printk" 1908 depends on DEBUG_LL 1909 help 1910 Say Y here if you want to have an early console using the 1911 kernel low-level debugging functions. Add earlyprintk to your 1912 kernel parameters to enable this console. 1913 1914config ARM_KPROBES_TEST 1915 tristate "Kprobes test module" 1916 depends on KPROBES && MODULES 1917 help 1918 Perform tests of kprobes API and instruction set simulation. 1919 1920config PID_IN_CONTEXTIDR 1921 bool "Write the current PID to the CONTEXTIDR register" 1922 depends on CPU_COPY_V6 1923 help 1924 Enabling this option causes the kernel to write the current PID to 1925 the PROCID field of the CONTEXTIDR register, at the expense of some 1926 additional instructions during context switch. Say Y here only if you 1927 are planning to use hardware trace tools with this kernel. 1928 1929source "drivers/hwtracing/coresight/Kconfig" 1930