1menu "Kernel hacking" 2 3source "lib/Kconfig.debug" 4 5config ARM_PTDUMP 6 bool "Export kernel pagetable layout to userspace via debugfs" 7 depends on DEBUG_KERNEL 8 select DEBUG_FS 9 ---help--- 10 Say Y here if you want to show the kernel pagetable layout in a 11 debugfs file. This information is only useful for kernel developers 12 who are working in architecture specific areas of the kernel. 13 It is probably not a good idea to enable this feature in a production 14 kernel. 15 If in doubt, say "N" 16 17config STRICT_DEVMEM 18 bool "Filter access to /dev/mem" 19 depends on MMU 20 ---help--- 21 If this option is disabled, you allow userspace (root) access to all 22 of memory, including kernel and userspace memory. Accidental 23 access to this is obviously disastrous, but specific access can 24 be used by people debugging the kernel. 25 26 If this option is switched on, the /dev/mem file only allows 27 userspace access to memory mapped peripherals. 28 29 If in doubt, say Y. 30 31# RMK wants arm kernels compiled with frame pointers or stack unwinding. 32# If you know what you are doing and are willing to live without stack 33# traces, you can get a slightly smaller kernel by setting this option to 34# n, but then RMK will have to kill you ;). 35config FRAME_POINTER 36 bool 37 depends on !THUMB2_KERNEL 38 default y if !ARM_UNWIND || FUNCTION_GRAPH_TRACER 39 help 40 If you say N here, the resulting kernel will be slightly smaller and 41 faster. However, if neither FRAME_POINTER nor ARM_UNWIND are enabled, 42 when a problem occurs with the kernel, the information that is 43 reported is severely limited. 44 45config ARM_UNWIND 46 bool "Enable stack unwinding support (EXPERIMENTAL)" 47 depends on AEABI 48 default y 49 help 50 This option enables stack unwinding support in the kernel 51 using the information automatically generated by the 52 compiler. The resulting kernel image is slightly bigger but 53 the performance is not affected. Currently, this feature 54 only works with EABI compilers. If unsure say Y. 55 56config OLD_MCOUNT 57 bool 58 depends on FUNCTION_TRACER && FRAME_POINTER 59 default y 60 61config DEBUG_USER 62 bool "Verbose user fault messages" 63 help 64 When a user program crashes due to an exception, the kernel can 65 print a brief message explaining what the problem was. This is 66 sometimes helpful for debugging but serves no purpose on a 67 production system. Most people should say N here. 68 69 In addition, you need to pass user_debug=N on the kernel command 70 line to enable this feature. N consists of the sum of: 71 72 1 - undefined instruction events 73 2 - system calls 74 4 - invalid data aborts 75 8 - SIGSEGV faults 76 16 - SIGBUS faults 77 78# These options are only for real kernel hackers who want to get their hands dirty. 79config DEBUG_LL 80 bool "Kernel low-level debugging functions (read help!)" 81 depends on DEBUG_KERNEL 82 help 83 Say Y here to include definitions of printascii, printch, printhex 84 in the kernel. This is helpful if you are debugging code that 85 executes before the console is initialized. 86 87 Note that selecting this option will limit the kernel to a single 88 UART definition, as specified below. Attempting to boot the kernel 89 image on a different platform *will not work*, so this option should 90 not be enabled for kernels that are intended to be portable. 91 92choice 93 prompt "Kernel low-level debugging port" 94 depends on DEBUG_LL 95 96 config AT91_DEBUG_LL_DBGU0 97 bool "Kernel low-level debugging on rm9200, 9260/9g20, 9261/9g10 and 9rl" 98 depends on HAVE_AT91_DBGU0 99 100 config AT91_DEBUG_LL_DBGU1 101 bool "Kernel low-level debugging on 9263 and 9g45" 102 depends on HAVE_AT91_DBGU1 103 104 config AT91_DEBUG_LL_DBGU2 105 bool "Kernel low-level debugging on sama5d4" 106 depends on HAVE_AT91_DBGU2 107 108 config DEBUG_BCM2835 109 bool "Kernel low-level debugging on BCM2835 PL011 UART" 110 depends on ARCH_BCM2835 111 select DEBUG_UART_PL01X 112 113 config DEBUG_BCM_5301X 114 bool "Kernel low-level debugging on BCM5301X UART1" 115 depends on ARCH_BCM_5301X 116 select DEBUG_UART_PL01X 117 118 config DEBUG_BCM_KONA_UART 119 bool "Kernel low-level debugging messages via BCM KONA UART" 120 depends on ARCH_BCM_MOBILE 121 select DEBUG_UART_8250 122 help 123 Say Y here if you want kernel low-level debugging support 124 on Broadcom SoC platforms. 125 This low level debug works for Broadcom 126 mobile SoCs in the Kona family of chips (e.g. bcm28155, 127 bcm11351, etc...) 128 129 config DEBUG_BCM63XX 130 bool "Kernel low-level debugging on BCM63XX UART" 131 depends on ARCH_BCM_63XX 132 select DEBUG_UART_BCM63XX 133 134 config DEBUG_BERLIN_UART 135 bool "Marvell Berlin SoC Debug UART" 136 depends on ARCH_BERLIN 137 select DEBUG_UART_8250 138 help 139 Say Y here if you want kernel low-level debugging support 140 on Marvell Berlin SoC based platforms. 141 142 config DEBUG_CLPS711X_UART1 143 bool "Kernel low-level debugging messages via UART1" 144 depends on ARCH_CLPS711X 145 help 146 Say Y here if you want the debug print routines to direct 147 their output to the first serial port on these devices. 148 149 config DEBUG_CLPS711X_UART2 150 bool "Kernel low-level debugging messages via UART2" 151 depends on ARCH_CLPS711X 152 help 153 Say Y here if you want the debug print routines to direct 154 their output to the second serial port on these devices. 155 156 config DEBUG_CNS3XXX 157 bool "Kernel Kernel low-level debugging on Cavium Networks CNS3xxx" 158 depends on ARCH_CNS3XXX 159 select DEBUG_UART_8250 160 help 161 Say Y here if you want the debug print routines to direct 162 their output to the CNS3xxx UART0. 163 164 config DEBUG_DAVINCI_DA8XX_UART1 165 bool "Kernel low-level debugging on DaVinci DA8XX using UART1" 166 depends on ARCH_DAVINCI_DA8XX 167 select DEBUG_UART_8250 168 help 169 Say Y here if you want the debug print routines to direct 170 their output to UART1 serial port on DaVinci DA8XX devices. 171 172 config DEBUG_DAVINCI_DA8XX_UART2 173 bool "Kernel low-level debugging on DaVinci DA8XX using UART2" 174 depends on ARCH_DAVINCI_DA8XX 175 select DEBUG_UART_8250 176 help 177 Say Y here if you want the debug print routines to direct 178 their output to UART2 serial port on DaVinci DA8XX devices. 179 180 config DEBUG_DAVINCI_DMx_UART0 181 bool "Kernel low-level debugging on DaVinci DMx using UART0" 182 depends on ARCH_DAVINCI_DMx 183 select DEBUG_UART_8250 184 help 185 Say Y here if you want the debug print routines to direct 186 their output to UART0 serial port on DaVinci DMx devices. 187 188 config DEBUG_ZYNQ_UART0 189 bool "Kernel low-level debugging on Xilinx Zynq using UART0" 190 depends on ARCH_ZYNQ 191 help 192 Say Y here if you want the debug print routines to direct 193 their output to UART0 on the Zynq platform. 194 195 config DEBUG_ZYNQ_UART1 196 bool "Kernel low-level debugging on Xilinx Zynq using UART1" 197 depends on ARCH_ZYNQ 198 help 199 Say Y here if you want the debug print routines to direct 200 their output to UART1 on the Zynq platform. 201 202 If you have a ZC702 board and want early boot messages to 203 appear on the USB serial adaptor, select this option. 204 205 config DEBUG_DC21285_PORT 206 bool "Kernel low-level debugging messages via footbridge serial port" 207 depends on FOOTBRIDGE 208 help 209 Say Y here if you want the debug print routines to direct 210 their output to the serial port in the DC21285 (Footbridge). 211 212 config DEBUG_FOOTBRIDGE_COM1 213 bool "Kernel low-level debugging messages via footbridge 8250 at PCI COM1" 214 depends on FOOTBRIDGE 215 help 216 Say Y here if you want the debug print routines to direct 217 their output to the 8250 at PCI COM1. 218 219 config DEBUG_HI3620_UART 220 bool "Hisilicon HI3620 Debug UART" 221 depends on ARCH_HI3xxx 222 select DEBUG_UART_PL01X 223 help 224 Say Y here if you want kernel low-level debugging support 225 on HI3620 UART. 226 227 config DEBUG_HI3716_UART 228 bool "Hisilicon Hi3716 Debug UART" 229 depends on ARCH_HI3xxx 230 select DEBUG_UART_PL01X 231 help 232 Say Y here if you want kernel low-level debugging support 233 on HI3716 UART. 234 235 config DEBUG_HIGHBANK_UART 236 bool "Kernel low-level debugging messages via Highbank UART" 237 depends on ARCH_HIGHBANK 238 select DEBUG_UART_PL01X 239 help 240 Say Y here if you want the debug print routines to direct 241 their output to the UART on Highbank based devices. 242 243 config DEBUG_HIP04_UART 244 bool "Hisilicon HiP04 Debug UART" 245 depends on ARCH_HIP04 246 select DEBUG_UART_8250 247 help 248 Say Y here if you want kernel low-level debugging support 249 on HIP04 UART. 250 251 config DEBUG_HIX5HD2_UART 252 bool "Hisilicon Hix5hd2 Debug UART" 253 depends on ARCH_HIX5HD2 254 select DEBUG_UART_PL01X 255 help 256 Say Y here if you want kernel low-level debugging support 257 on Hix5hd2 UART. 258 259 config DEBUG_IMX1_UART 260 bool "i.MX1 Debug UART" 261 depends on SOC_IMX1 262 help 263 Say Y here if you want kernel low-level debugging support 264 on i.MX1. 265 266 config DEBUG_IMX23_UART 267 bool "i.MX23 Debug UART" 268 depends on SOC_IMX23 269 select DEBUG_UART_PL01X 270 help 271 Say Y here if you want kernel low-level debugging support 272 on i.MX23. 273 274 config DEBUG_IMX25_UART 275 bool "i.MX25 Debug UART" 276 depends on SOC_IMX25 277 help 278 Say Y here if you want kernel low-level debugging support 279 on i.MX25. 280 281 config DEBUG_IMX21_IMX27_UART 282 bool "i.MX21 and i.MX27 Debug UART" 283 depends on SOC_IMX21 || SOC_IMX27 284 help 285 Say Y here if you want kernel low-level debugging support 286 on i.MX21 or i.MX27. 287 288 config DEBUG_IMX28_UART 289 bool "i.MX28 Debug UART" 290 depends on SOC_IMX28 291 select DEBUG_UART_PL01X 292 help 293 Say Y here if you want kernel low-level debugging support 294 on i.MX28. 295 296 config DEBUG_IMX31_UART 297 bool "i.MX31 Debug UART" 298 depends on SOC_IMX31 299 help 300 Say Y here if you want kernel low-level debugging support 301 on i.MX31. 302 303 config DEBUG_IMX35_UART 304 bool "i.MX35 Debug UART" 305 depends on SOC_IMX35 306 help 307 Say Y here if you want kernel low-level debugging support 308 on i.MX35. 309 310 config DEBUG_IMX50_UART 311 bool "i.MX50 Debug UART" 312 depends on SOC_IMX50 313 help 314 Say Y here if you want kernel low-level debugging support 315 on i.MX50. 316 317 config DEBUG_IMX51_UART 318 bool "i.MX51 Debug UART" 319 depends on SOC_IMX51 320 help 321 Say Y here if you want kernel low-level debugging support 322 on i.MX51. 323 324 config DEBUG_IMX53_UART 325 bool "i.MX53 Debug UART" 326 depends on SOC_IMX53 327 help 328 Say Y here if you want kernel low-level debugging support 329 on i.MX53. 330 331 config DEBUG_IMX6Q_UART 332 bool "i.MX6Q/DL Debug UART" 333 depends on SOC_IMX6Q 334 help 335 Say Y here if you want kernel low-level debugging support 336 on i.MX6Q/DL. 337 338 config DEBUG_IMX6SL_UART 339 bool "i.MX6SL Debug UART" 340 depends on SOC_IMX6SL 341 help 342 Say Y here if you want kernel low-level debugging support 343 on i.MX6SL. 344 345 config DEBUG_IMX6SX_UART 346 bool "i.MX6SX Debug UART" 347 depends on SOC_IMX6SX 348 help 349 Say Y here if you want kernel low-level debugging support 350 on i.MX6SX. 351 352 config DEBUG_KEYSTONE_UART0 353 bool "Kernel low-level debugging on KEYSTONE2 using UART0" 354 depends on ARCH_KEYSTONE 355 select DEBUG_UART_8250 356 help 357 Say Y here if you want the debug print routines to direct 358 their output to UART0 serial port on KEYSTONE2 devices. 359 360 config DEBUG_KEYSTONE_UART1 361 bool "Kernel low-level debugging on KEYSTONE2 using UART1" 362 depends on ARCH_KEYSTONE 363 select DEBUG_UART_8250 364 help 365 Say Y here if you want the debug print routines to direct 366 their output to UART1 serial port on KEYSTONE2 devices. 367 368 config DEBUG_MESON_UARTAO 369 bool "Kernel low-level debugging via Meson6 UARTAO" 370 depends on ARCH_MESON 371 help 372 Say Y here if you want kernel low-lever debugging support 373 on Amlogic Meson6 based platforms on the UARTAO. 374 375 config DEBUG_MMP_UART2 376 bool "Kernel low-level debugging message via MMP UART2" 377 depends on ARCH_MMP 378 select DEBUG_UART_8250 379 help 380 Say Y here if you want kernel low-level debugging support 381 on MMP UART2. 382 383 config DEBUG_MMP_UART3 384 bool "Kernel low-level debugging message via MMP UART3" 385 depends on ARCH_MMP 386 select DEBUG_UART_8250 387 help 388 Say Y here if you want kernel low-level debugging support 389 on MMP UART3. 390 391 config DEBUG_MSM_UART 392 bool "Kernel low-level debugging messages via MSM UART" 393 depends on ARCH_MSM 394 help 395 Say Y here if you want the debug print routines to direct 396 their output to the serial port on MSM devices. 397 398 ARCH DEBUG_UART_PHYS DEBUG_UART_BASE # 399 MSM7X00A, QSD8X50 0xa9a00000 0xe1000000 UART1 400 MSM7X00A, QSD8X50 0xa9b00000 0xe1000000 UART2 401 MSM7X00A, QSD8X50 0xa9c00000 0xe1000000 UART3 402 403 MSM7X30 0xaca00000 0xe1000000 UART1 404 MSM7X30 0xacb00000 0xe1000000 UART2 405 MSM7X30 0xacc00000 0xe1000000 UART3 406 407 Please adjust DEBUG_UART_PHYS and DEBUG_UART_BASE configuration 408 options based on your needs. 409 410 config DEBUG_QCOM_UARTDM 411 bool "Kernel low-level debugging messages via QCOM UARTDM" 412 depends on ARCH_QCOM 413 help 414 Say Y here if you want the debug print routines to direct 415 their output to the serial port on Qualcomm devices. 416 417 ARCH DEBUG_UART_PHYS DEBUG_UART_BASE 418 APQ8084 0xf995e000 0xfa75e000 419 MSM8X60 0x19c40000 0xf0040000 420 MSM8960 0x16440000 0xf0040000 421 MSM8974 0xf991e000 0xfa71e000 422 423 Please adjust DEBUG_UART_PHYS and DEBUG_UART_BASE configuration 424 options based on your needs. 425 426 config DEBUG_MVEBU_UART 427 bool "Kernel low-level debugging messages via MVEBU UART (old bootloaders)" 428 depends on ARCH_MVEBU 429 select DEBUG_UART_8250 430 help 431 Say Y here if you want kernel low-level debugging support 432 on MVEBU based platforms. 433 434 This option should be used with the old bootloaders 435 that left the internal registers mapped at 436 0xd0000000. As of today, this is the case on 437 platforms such as the Globalscale Mirabox or the 438 Plathome OpenBlocks AX3, when using the original 439 bootloader. 440 441 If the wrong DEBUG_MVEBU_UART* option is selected, 442 when u-boot hands over to the kernel, the system 443 silently crashes, with no serial output at all. 444 445 config DEBUG_MVEBU_UART_ALTERNATE 446 bool "Kernel low-level debugging messages via MVEBU UART (new bootloaders)" 447 depends on ARCH_MVEBU 448 select DEBUG_UART_8250 449 help 450 Say Y here if you want kernel low-level debugging support 451 on MVEBU based platforms. 452 453 This option should be used with the new bootloaders 454 that remap the internal registers at 0xf1000000. 455 456 If the wrong DEBUG_MVEBU_UART* option is selected, 457 when u-boot hands over to the kernel, the system 458 silently crashes, with no serial output at all. 459 460 config DEBUG_VF_UART 461 bool "Vybrid UART" 462 depends on SOC_VF610 463 help 464 Say Y here if you want kernel low-level debugging support 465 on Vybrid based platforms. 466 467 config DEBUG_NOMADIK_UART 468 bool "Kernel low-level debugging messages via NOMADIK UART" 469 depends on ARCH_NOMADIK 470 select DEBUG_UART_PL01X 471 help 472 Say Y here if you want kernel low-level debugging support 473 on NOMADIK based platforms. 474 475 config DEBUG_NSPIRE_CLASSIC_UART 476 bool "Kernel low-level debugging via TI-NSPIRE 8250 UART" 477 depends on ARCH_NSPIRE 478 select DEBUG_UART_8250 479 help 480 Say Y here if you want kernel low-level debugging support 481 on TI-NSPIRE classic models. 482 483 config DEBUG_NSPIRE_CX_UART 484 bool "Kernel low-level debugging via TI-NSPIRE PL011 UART" 485 depends on ARCH_NSPIRE 486 select DEBUG_UART_PL01X 487 help 488 Say Y here if you want kernel low-level debugging support 489 on TI-NSPIRE CX models. 490 491 config DEBUG_OMAP2UART1 492 bool "OMAP2/3/4 UART1 (omap2/3 sdp boards and some omap3 boards)" 493 depends on ARCH_OMAP2PLUS 494 select DEBUG_OMAP2PLUS_UART 495 help 496 This covers at least h4, 2430sdp, 3430sdp, 3630sdp, 497 omap3 torpedo and 3530 lv som. 498 499 config DEBUG_OMAP2UART2 500 bool "Kernel low-level debugging messages via OMAP2/3/4 UART2" 501 depends on ARCH_OMAP2PLUS 502 select DEBUG_OMAP2PLUS_UART 503 504 config DEBUG_OMAP2UART3 505 bool "Kernel low-level debugging messages via OMAP2 UART3 (n8x0)" 506 depends on ARCH_OMAP2PLUS 507 select DEBUG_OMAP2PLUS_UART 508 509 config DEBUG_OMAP3UART3 510 bool "Kernel low-level debugging messages via OMAP3 UART3 (most omap3 boards)" 511 depends on ARCH_OMAP2PLUS 512 select DEBUG_OMAP2PLUS_UART 513 help 514 This covers at least cm_t3x, beagle, crane, devkit8000, 515 igep00x0, ldp, n900, n9(50), pandora, overo, touchbook, 516 and 3517evm. 517 518 config DEBUG_OMAP4UART3 519 bool "Kernel low-level debugging messages via OMAP4/5 UART3 (omap4 blaze, panda, omap5 sevm)" 520 depends on ARCH_OMAP2PLUS 521 select DEBUG_OMAP2PLUS_UART 522 523 config DEBUG_OMAP3UART4 524 bool "Kernel low-level debugging messages via OMAP36XX UART4" 525 depends on ARCH_OMAP2PLUS 526 select DEBUG_OMAP2PLUS_UART 527 528 config DEBUG_OMAP4UART4 529 bool "Kernel low-level debugging messages via OMAP4/5 UART4" 530 depends on ARCH_OMAP2PLUS 531 select DEBUG_OMAP2PLUS_UART 532 533 config DEBUG_TI81XXUART1 534 bool "Kernel low-level debugging messages via TI81XX UART1 (ti8148evm)" 535 depends on ARCH_OMAP2PLUS 536 select DEBUG_OMAP2PLUS_UART 537 538 config DEBUG_TI81XXUART2 539 bool "Kernel low-level debugging messages via TI81XX UART2" 540 depends on ARCH_OMAP2PLUS 541 select DEBUG_OMAP2PLUS_UART 542 543 config DEBUG_TI81XXUART3 544 bool "Kernel low-level debugging messages via TI81XX UART3 (ti8168evm)" 545 depends on ARCH_OMAP2PLUS 546 select DEBUG_OMAP2PLUS_UART 547 548 config DEBUG_AM33XXUART1 549 bool "Kernel low-level debugging messages via AM33XX UART1" 550 depends on ARCH_OMAP2PLUS 551 select DEBUG_OMAP2PLUS_UART 552 553 config DEBUG_ZOOM_UART 554 bool "Kernel low-level debugging messages via Zoom2/3 UART" 555 depends on ARCH_OMAP2PLUS 556 select DEBUG_OMAP2PLUS_UART 557 558 config DEBUG_PICOXCELL_UART 559 depends on ARCH_PICOXCELL 560 bool "Use PicoXcell UART for low-level debug" 561 select DEBUG_UART_8250 562 help 563 Say Y here if you want kernel low-level debugging support 564 on PicoXcell based platforms. 565 566 config DEBUG_PXA_UART1 567 depends on ARCH_PXA 568 bool "Use PXA UART1 for low-level debug" 569 select DEBUG_UART_8250 570 help 571 Say Y here if you want kernel low-level debugging support 572 on PXA UART1. 573 574 config DEBUG_REALVIEW_STD_PORT 575 bool "RealView Default UART" 576 depends on ARCH_REALVIEW 577 select DEBUG_UART_PL01X 578 help 579 Say Y here if you want the debug print routines to direct 580 their output to the serial port on RealView EB, PB11MP, PBA8 581 and PBX platforms. 582 583 config DEBUG_REALVIEW_PB1176_PORT 584 bool "RealView PB1176 UART" 585 depends on MACH_REALVIEW_PB1176 586 select DEBUG_UART_PL01X 587 help 588 Say Y here if you want the debug print routines to direct 589 their output to the standard serial port on the RealView 590 PB1176 platform. 591 592 config DEBUG_RK29_UART0 593 bool "Kernel low-level debugging messages via Rockchip RK29 UART0" 594 depends on ARCH_ROCKCHIP 595 select DEBUG_UART_8250 596 help 597 Say Y here if you want kernel low-level debugging support 598 on Rockchip based platforms. 599 600 config DEBUG_RK29_UART1 601 bool "Kernel low-level debugging messages via Rockchip RK29 UART1" 602 depends on ARCH_ROCKCHIP 603 select DEBUG_UART_8250 604 help 605 Say Y here if you want kernel low-level debugging support 606 on Rockchip based platforms. 607 608 config DEBUG_RK29_UART2 609 bool "Kernel low-level debugging messages via Rockchip RK29 UART2" 610 depends on ARCH_ROCKCHIP 611 select DEBUG_UART_8250 612 help 613 Say Y here if you want kernel low-level debugging support 614 on Rockchip based platforms. 615 616 config DEBUG_RK3X_UART0 617 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART0" 618 depends on ARCH_ROCKCHIP 619 select DEBUG_UART_8250 620 help 621 Say Y here if you want kernel low-level debugging support 622 on Rockchip based platforms. 623 624 config DEBUG_RK3X_UART1 625 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART1" 626 depends on ARCH_ROCKCHIP 627 select DEBUG_UART_8250 628 help 629 Say Y here if you want kernel low-level debugging support 630 on Rockchip based platforms. 631 632 config DEBUG_RK3X_UART2 633 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART2" 634 depends on ARCH_ROCKCHIP 635 select DEBUG_UART_8250 636 help 637 Say Y here if you want kernel low-level debugging support 638 on Rockchip based platforms. 639 640 config DEBUG_RK3X_UART3 641 bool "Kernel low-level debugging messages via Rockchip RK30/RK31 UART3" 642 depends on ARCH_ROCKCHIP 643 select DEBUG_UART_8250 644 help 645 Say Y here if you want kernel low-level debugging support 646 on Rockchip based platforms. 647 648 config DEBUG_RK32_UART2 649 bool "Kernel low-level debugging messages via Rockchip RK32 UART2" 650 depends on ARCH_ROCKCHIP 651 select DEBUG_UART_8250 652 help 653 Say Y here if you want kernel low-level debugging support 654 on Rockchip RK32xx based platforms. 655 656 config DEBUG_S3C_UART0 657 depends on PLAT_SAMSUNG 658 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 659 select DEBUG_S3C24XX_UART if ARCH_S3C24XX 660 select DEBUG_S5PV210_UART if ARCH_S5PV210 661 bool "Use Samsung S3C UART 0 for low-level debug" 662 help 663 Say Y here if you want the debug print routines to direct 664 their output to UART 0. The port must have been initialised 665 by the boot-loader before use. 666 667 config DEBUG_S3C_UART1 668 depends on PLAT_SAMSUNG 669 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 670 select DEBUG_S3C24XX_UART if ARCH_S3C24XX 671 select DEBUG_S5PV210_UART if ARCH_S5PV210 672 bool "Use Samsung S3C UART 1 for low-level debug" 673 help 674 Say Y here if you want the debug print routines to direct 675 their output to UART 1. The port must have been initialised 676 by the boot-loader before use. 677 678 config DEBUG_S3C_UART2 679 depends on PLAT_SAMSUNG 680 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 681 select DEBUG_S3C24XX_UART if ARCH_S3C24XX 682 select DEBUG_S5PV210_UART if ARCH_S5PV210 683 bool "Use Samsung S3C UART 2 for low-level debug" 684 help 685 Say Y here if you want the debug print routines to direct 686 their output to UART 2. The port must have been initialised 687 by the boot-loader before use. 688 689 config DEBUG_S3C_UART3 690 depends on PLAT_SAMSUNG && (ARCH_EXYNOS || ARCH_S5PV210) 691 select DEBUG_EXYNOS_UART if ARCH_EXYNOS 692 select DEBUG_S5PV210_UART if ARCH_S5PV210 693 bool "Use Samsung S3C UART 3 for low-level debug" 694 help 695 Say Y here if you want the debug print routines to direct 696 their output to UART 3. The port must have been initialised 697 by the boot-loader before use. 698 699 config DEBUG_S3C2410_UART0 700 depends on ARCH_S3C24XX 701 select DEBUG_S3C2410_UART 702 bool "Use S3C2410/S3C2412 UART 0 for low-level debug" 703 help 704 Say Y here if you want the debug print routines to direct 705 their output to UART 0. The port must have been initialised 706 by the boot-loader before use. 707 708 config DEBUG_S3C2410_UART1 709 depends on ARCH_S3C24XX 710 select DEBUG_S3C2410_UART 711 bool "Use S3C2410/S3C2412 UART 1 for low-level debug" 712 help 713 Say Y here if you want the debug print routines to direct 714 their output to UART 1. The port must have been initialised 715 by the boot-loader before use. 716 717 config DEBUG_S3C2410_UART2 718 depends on ARCH_S3C24XX 719 select DEBUG_S3C2410_UART 720 bool "Use S3C2410/S3C2412 UART 2 for low-level debug" 721 help 722 Say Y here if you want the debug print routines to direct 723 their output to UART 2. The port must have been initialised 724 by the boot-loader before use. 725 726 config DEBUG_SOCFPGA_UART 727 depends on ARCH_SOCFPGA 728 bool "Use SOCFPGA UART for low-level debug" 729 select DEBUG_UART_8250 730 help 731 Say Y here if you want kernel low-level debugging support 732 on SOCFPGA based platforms. 733 734 config DEBUG_SUNXI_UART0 735 bool "Kernel low-level debugging messages via sunXi UART0" 736 depends on ARCH_SUNXI 737 select DEBUG_UART_8250 738 help 739 Say Y here if you want kernel low-level debugging support 740 on Allwinner A1X based platforms on the UART0. 741 742 config DEBUG_SUNXI_UART1 743 bool "Kernel low-level debugging messages via sunXi UART1" 744 depends on ARCH_SUNXI 745 select DEBUG_UART_8250 746 help 747 Say Y here if you want kernel low-level debugging support 748 on Allwinner A1X based platforms on the UART1. 749 750 config DEBUG_SUNXI_R_UART 751 bool "Kernel low-level debugging messages via sunXi R_UART" 752 depends on MACH_SUN6I || MACH_SUN8I 753 select DEBUG_UART_8250 754 help 755 Say Y here if you want kernel low-level debugging support 756 on Allwinner A31/A23 based platforms on the R_UART. 757 758 config TEGRA_DEBUG_UART_AUTO_ODMDATA 759 bool "Kernel low-level debugging messages via Tegra UART via ODMDATA" 760 depends on ARCH_TEGRA 761 select DEBUG_TEGRA_UART 762 help 763 Automatically determines which UART to use for low-level 764 debug based on the ODMDATA value. This value is part of 765 the BCT, and is written to the boot memory device using 766 nvflash, or other flashing tool. When bits 19:18 are 3, 767 then bits 17:15 indicate which UART to use; 0/1/2/3/4 768 are UART A/B/C/D/E. 769 770 config TEGRA_DEBUG_UARTA 771 bool "Kernel low-level debugging messages via Tegra UART A" 772 depends on ARCH_TEGRA 773 select DEBUG_TEGRA_UART 774 help 775 Say Y here if you want kernel low-level debugging support 776 on Tegra based platforms. 777 778 config TEGRA_DEBUG_UARTB 779 bool "Kernel low-level debugging messages via Tegra UART B" 780 depends on ARCH_TEGRA 781 select DEBUG_TEGRA_UART 782 help 783 Say Y here if you want kernel low-level debugging support 784 on Tegra based platforms. 785 786 config TEGRA_DEBUG_UARTC 787 bool "Kernel low-level debugging messages via Tegra UART C" 788 depends on ARCH_TEGRA 789 select DEBUG_TEGRA_UART 790 help 791 Say Y here if you want kernel low-level debugging support 792 on Tegra based platforms. 793 794 config TEGRA_DEBUG_UARTD 795 bool "Kernel low-level debugging messages via Tegra UART D" 796 depends on ARCH_TEGRA 797 select DEBUG_TEGRA_UART 798 help 799 Say Y here if you want kernel low-level debugging support 800 on Tegra based platforms. 801 802 config TEGRA_DEBUG_UARTE 803 bool "Kernel low-level debugging messages via Tegra UART E" 804 depends on ARCH_TEGRA 805 select DEBUG_TEGRA_UART 806 help 807 Say Y here if you want kernel low-level debugging support 808 on Tegra based platforms. 809 810 config DEBUG_SIRFPRIMA2_UART1 811 bool "Kernel low-level debugging messages via SiRFprimaII UART1" 812 depends on ARCH_PRIMA2 813 help 814 Say Y here if you want the debug print routines to direct 815 their output to the uart1 port on SiRFprimaII devices. 816 817 config DEBUG_SIRFMARCO_UART1 818 bool "Kernel low-level debugging messages via SiRFmarco UART1" 819 depends on ARCH_MARCO 820 help 821 Say Y here if you want the debug print routines to direct 822 their output to the uart1 port on SiRFmarco devices. 823 824 config STIH41X_DEBUG_ASC2 825 bool "Use StiH415/416 ASC2 UART for low-level debug" 826 depends on ARCH_STI 827 select DEBUG_STI_UART 828 help 829 Say Y here if you want kernel low-level debugging support 830 on STiH415/416 based platforms like b2000, which has 831 default UART wired up to ASC2. 832 833 If unsure, say N. 834 835 config STIH41X_DEBUG_SBC_ASC1 836 bool "Use StiH415/416 SBC ASC1 UART for low-level debug" 837 depends on ARCH_STI 838 select DEBUG_STI_UART 839 help 840 Say Y here if you want kernel low-level debugging support 841 on STiH415/416 based platforms like b2020. which has 842 default UART wired up to SBC ASC1. 843 844 If unsure, say N. 845 846 config DEBUG_U300_UART 847 bool "Kernel low-level debugging messages via U300 UART0" 848 depends on ARCH_U300 849 select DEBUG_UART_PL01X 850 help 851 Say Y here if you want the debug print routines to direct 852 their output to the uart port on U300 devices. 853 854 config DEBUG_UX500_UART 855 depends on ARCH_U8500 856 bool "Use Ux500 UART for low-level debug" 857 help 858 Say Y here if you want kernel low-level debugging support 859 on Ux500 based platforms. 860 861 config DEBUG_MT6589_UART0 862 bool "Mediatek mt6589 UART0" 863 depends on ARCH_MEDIATEK 864 select DEBUG_UART_8250 865 help 866 Say Y here if you want kernel low-level debugging support 867 for Mediatek mt6589 based platforms on UART0. 868 869 config DEBUG_VEXPRESS_UART0_DETECT 870 bool "Autodetect UART0 on Versatile Express Cortex-A core tiles" 871 depends on ARCH_VEXPRESS && CPU_CP15_MMU 872 help 873 This option enables a simple heuristic which tries to determine 874 the motherboard's memory map variant (original or RS1) and then 875 choose the relevant UART0 base address. 876 877 Note that this will only work with standard A-class core tiles, 878 and may fail with non-standard SMM or custom software models. 879 880 config DEBUG_VEXPRESS_UART0_CA9 881 bool "Use PL011 UART0 at 0x10009000 (V2P-CA9 core tile)" 882 depends on ARCH_VEXPRESS 883 select DEBUG_UART_PL01X 884 help 885 This option selects UART0 at 0x10009000. Except for custom models, 886 this applies only to the V2P-CA9 tile. 887 888 config DEBUG_VEXPRESS_UART0_RS1 889 bool "Use PL011 UART0 at 0x1c090000 (RS1 complaint tiles)" 890 depends on ARCH_VEXPRESS 891 select DEBUG_UART_PL01X 892 help 893 This option selects UART0 at 0x1c090000. This applies to most 894 of the tiles using the RS1 memory map, including all new A-class 895 core tiles, FPGA-based SMMs and software models. 896 897 config DEBUG_VEXPRESS_UART0_CRX 898 bool "Use PL011 UART0 at 0xb0090000 (Cortex-R compliant tiles)" 899 depends on ARCH_VEXPRESS && !MMU 900 select DEBUG_UART_PL01X 901 help 902 This option selects UART0 at 0xb0090000. This is appropriate for 903 Cortex-R series tiles and SMMs, such as Cortex-R5 and Cortex-R7 904 905 config DEBUG_VT8500_UART0 906 bool "Use UART0 on VIA/Wondermedia SoCs" 907 depends on ARCH_VT8500 908 help 909 This option selects UART0 on VIA/Wondermedia System-on-a-chip 910 devices, including VT8500, WM8505, WM8650 and WM8850. 911 912 config DEBUG_LL_UART_NONE 913 bool "No low-level debugging UART" 914 depends on !ARCH_MULTIPLATFORM 915 help 916 Say Y here if your platform doesn't provide a UART option 917 above. This relies on your platform choosing the right UART 918 definition internally in order for low-level debugging to 919 work. 920 921 config DEBUG_ICEDCC 922 bool "Kernel low-level debugging via EmbeddedICE DCC channel" 923 help 924 Say Y here if you want the debug print routines to direct 925 their output to the EmbeddedICE macrocell's DCC channel using 926 co-processor 14. This is known to work on the ARM9 style ICE 927 channel and on the XScale with the PEEDI. 928 929 Note that the system will appear to hang during boot if there 930 is nothing connected to read from the DCC. 931 932 config DEBUG_SEMIHOSTING 933 bool "Kernel low-level debug output via semihosting I/O" 934 help 935 Semihosting enables code running on an ARM target to use 936 the I/O facilities on a host debugger/emulator through a 937 simple SVC call. The host debugger or emulator must have 938 semihosting enabled for the special svc call to be trapped 939 otherwise the kernel will crash. 940 941 This is known to work with OpenOCD, as well as 942 ARM's Fast Models, or any other controlling environment 943 that implements semihosting. 944 945 For more details about semihosting, please see 946 chapter 8 of DUI0203I_rvct_developer_guide.pdf from ARM Ltd. 947 948 config DEBUG_LL_UART_8250 949 bool "Kernel low-level debugging via 8250 UART" 950 help 951 Say Y here if you wish the debug print routes to direct 952 their output to an 8250 UART. You can use this option 953 to provide the parameters for the 8250 UART rather than 954 selecting one of the platform specific options above if 955 you know the parameters for the port. 956 957 This option is preferred over the platform specific 958 options; the platform specific options are deprecated 959 and will be soon removed. 960 961 config DEBUG_LL_UART_EFM32 962 bool "Kernel low-level debugging via efm32 UART" 963 depends on ARCH_EFM32 964 help 965 Say Y here if you want the debug print routines to direct 966 their output to an UART or USART port on efm32 based 967 machines. Use the following addresses for DEBUG_UART_PHYS: 968 969 0x4000c000 | USART0 970 0x4000c400 | USART1 971 0x4000c800 | USART2 972 0x4000e000 | UART0 973 0x4000e400 | UART1 974 975 config DEBUG_LL_UART_PL01X 976 bool "Kernel low-level debugging via ARM Ltd PL01x Primecell UART" 977 help 978 Say Y here if you wish the debug print routes to direct 979 their output to a PL01x Primecell UART. You can use 980 this option to provide the parameters for the UART 981 rather than selecting one of the platform specific 982 options above if you know the parameters for the port. 983 984 This option is preferred over the platform specific 985 options; the platform specific options are deprecated 986 and will be soon removed. 987 988endchoice 989 990config DEBUG_EXYNOS_UART 991 bool 992 993config DEBUG_S3C2410_UART 994 bool 995 select DEBUG_S3C24XX_UART 996 997config DEBUG_S3C24XX_UART 998 bool 999 1000config DEBUG_S5PV210_UART 1001 bool 1002 1003config DEBUG_OMAP2PLUS_UART 1004 bool 1005 depends on ARCH_OMAP2PLUS 1006 1007config DEBUG_IMX_UART_PORT 1008 int "i.MX Debug UART Port Selection" if DEBUG_IMX1_UART || \ 1009 DEBUG_IMX25_UART || \ 1010 DEBUG_IMX21_IMX27_UART || \ 1011 DEBUG_IMX31_UART || \ 1012 DEBUG_IMX35_UART || \ 1013 DEBUG_IMX50_UART || \ 1014 DEBUG_IMX51_UART || \ 1015 DEBUG_IMX53_UART || \ 1016 DEBUG_IMX6Q_UART || \ 1017 DEBUG_IMX6SL_UART || \ 1018 DEBUG_IMX6SX_UART 1019 default 1 1020 depends on ARCH_MXC 1021 help 1022 Choose UART port on which kernel low-level debug messages 1023 should be output. 1024 1025config DEBUG_VF_UART_PORT 1026 int "Vybrid Debug UART Port Selection" if DEBUG_VF_UART 1027 default 1 1028 range 0 3 1029 depends on SOC_VF610 1030 help 1031 Choose UART port on which kernel low-level debug messages 1032 should be output. 1033 1034config DEBUG_TEGRA_UART 1035 bool 1036 depends on ARCH_TEGRA 1037 1038config DEBUG_STI_UART 1039 bool 1040 depends on ARCH_STI 1041 1042config DEBUG_LL_INCLUDE 1043 string 1044 default "debug/8250.S" if DEBUG_LL_UART_8250 || DEBUG_UART_8250 1045 default "debug/clps711x.S" if DEBUG_CLPS711X_UART1 || DEBUG_CLPS711X_UART2 1046 default "debug/meson.S" if DEBUG_MESON_UARTAO 1047 default "debug/pl01x.S" if DEBUG_LL_UART_PL01X || DEBUG_UART_PL01X 1048 default "debug/exynos.S" if DEBUG_EXYNOS_UART 1049 default "debug/efm32.S" if DEBUG_LL_UART_EFM32 1050 default "debug/icedcc.S" if DEBUG_ICEDCC 1051 default "debug/imx.S" if DEBUG_IMX1_UART || \ 1052 DEBUG_IMX25_UART || \ 1053 DEBUG_IMX21_IMX27_UART || \ 1054 DEBUG_IMX31_UART || \ 1055 DEBUG_IMX35_UART || \ 1056 DEBUG_IMX50_UART || \ 1057 DEBUG_IMX51_UART || \ 1058 DEBUG_IMX53_UART ||\ 1059 DEBUG_IMX6Q_UART || \ 1060 DEBUG_IMX6SL_UART || \ 1061 DEBUG_IMX6SX_UART 1062 default "debug/msm.S" if DEBUG_MSM_UART || DEBUG_QCOM_UARTDM 1063 default "debug/omap2plus.S" if DEBUG_OMAP2PLUS_UART 1064 default "debug/s3c24xx.S" if DEBUG_S3C24XX_UART 1065 default "debug/s5pv210.S" if DEBUG_S5PV210_UART 1066 default "debug/sirf.S" if DEBUG_SIRFPRIMA2_UART1 || DEBUG_SIRFMARCO_UART1 1067 default "debug/sti.S" if DEBUG_STI_UART 1068 default "debug/tegra.S" if DEBUG_TEGRA_UART 1069 default "debug/ux500.S" if DEBUG_UX500_UART 1070 default "debug/vexpress.S" if DEBUG_VEXPRESS_UART0_DETECT 1071 default "debug/vf.S" if DEBUG_VF_UART 1072 default "debug/vt8500.S" if DEBUG_VT8500_UART0 1073 default "debug/zynq.S" if DEBUG_ZYNQ_UART0 || DEBUG_ZYNQ_UART1 1074 default "debug/bcm63xx.S" if DEBUG_UART_BCM63XX 1075 default "mach/debug-macro.S" 1076 1077# Compatibility options for PL01x 1078config DEBUG_UART_PL01X 1079 def_bool ARCH_EP93XX || \ 1080 ARCH_INTEGRATOR || \ 1081 ARCH_SPEAR3XX || \ 1082 ARCH_SPEAR6XX || \ 1083 ARCH_SPEAR13XX || \ 1084 ARCH_VERSATILE 1085 1086# Compatibility options for 8250 1087config DEBUG_UART_8250 1088 def_bool ARCH_DOVE || ARCH_EBSA110 || \ 1089 (FOOTBRIDGE && !DEBUG_DC21285_PORT) || \ 1090 ARCH_GEMINI || ARCH_IOP13XX || ARCH_IOP32X || \ 1091 ARCH_IOP33X || ARCH_IXP4XX || \ 1092 ARCH_LPC32XX || ARCH_MV78XX0 || ARCH_ORION5X || ARCH_RPC 1093 1094# Compatibility options for BCM63xx 1095config DEBUG_UART_BCM63XX 1096 def_bool ARCH_BCM_63XX 1097 1098config DEBUG_UART_PHYS 1099 hex "Physical base address of debug UART" 1100 default 0x01c20000 if DEBUG_DAVINCI_DMx_UART0 1101 default 0x01c28000 if DEBUG_SUNXI_UART0 1102 default 0x01c28400 if DEBUG_SUNXI_UART1 1103 default 0x01d0c000 if DEBUG_DAVINCI_DA8XX_UART1 1104 default 0x01d0d000 if DEBUG_DAVINCI_DA8XX_UART2 1105 default 0x01f02800 if DEBUG_SUNXI_R_UART 1106 default 0x02530c00 if DEBUG_KEYSTONE_UART0 1107 default 0x02531000 if DEBUG_KEYSTONE_UART1 1108 default 0x03010fe0 if ARCH_RPC 1109 default 0x10009000 if DEBUG_REALVIEW_STD_PORT || \ 1110 DEBUG_VEXPRESS_UART0_CA9 1111 default 0x1010c000 if DEBUG_REALVIEW_PB1176_PORT 1112 default 0x10124000 if DEBUG_RK3X_UART0 1113 default 0x10126000 if DEBUG_RK3X_UART1 1114 default 0x101f1000 if ARCH_VERSATILE 1115 default 0x101fb000 if DEBUG_NOMADIK_UART 1116 default 0x11006000 if DEBUG_MT6589_UART0 1117 default 0x16000000 if ARCH_INTEGRATOR 1118 default 0x18000300 if DEBUG_BCM_5301X 1119 default 0x1c090000 if DEBUG_VEXPRESS_UART0_RS1 1120 default 0x20060000 if DEBUG_RK29_UART0 1121 default 0x20064000 if DEBUG_RK29_UART1 || DEBUG_RK3X_UART2 1122 default 0x20068000 if DEBUG_RK29_UART2 || DEBUG_RK3X_UART3 1123 default 0x20201000 if DEBUG_BCM2835 1124 default 0x3e000000 if DEBUG_BCM_KONA_UART 1125 default 0x4000e400 if DEBUG_LL_UART_EFM32 1126 default 0x40090000 if ARCH_LPC32XX 1127 default 0x40100000 if DEBUG_PXA_UART1 1128 default 0x42000000 if ARCH_GEMINI 1129 default 0x50000000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART0 || \ 1130 DEBUG_S3C2410_UART0) 1131 default 0x50004000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART1 || \ 1132 DEBUG_S3C2410_UART1) 1133 default 0x50008000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART2 || \ 1134 DEBUG_S3C2410_UART2) 1135 default 0x78000000 if DEBUG_CNS3XXX 1136 default 0x7c0003f8 if FOOTBRIDGE 1137 default 0x78000000 if DEBUG_CNS3XXX 1138 default 0x80070000 if DEBUG_IMX23_UART 1139 default 0x80074000 if DEBUG_IMX28_UART 1140 default 0x80230000 if DEBUG_PICOXCELL_UART 1141 default 0x808c0000 if ARCH_EP93XX 1142 default 0x90020000 if DEBUG_NSPIRE_CLASSIC_UART || DEBUG_NSPIRE_CX_UART 1143 default 0xa9a00000 if DEBUG_MSM_UART 1144 default 0xb0090000 if DEBUG_VEXPRESS_UART0_CRX 1145 default 0xc0013000 if DEBUG_U300_UART 1146 default 0xc8000000 if ARCH_IXP4XX && !CPU_BIG_ENDIAN 1147 default 0xc8000003 if ARCH_IXP4XX && CPU_BIG_ENDIAN 1148 default 0xd0000000 if ARCH_SPEAR3XX || ARCH_SPEAR6XX 1149 default 0xd0012000 if DEBUG_MVEBU_UART 1150 default 0xc81004c0 if DEBUG_MESON_UARTAO 1151 default 0xd4017000 if DEBUG_MMP_UART2 1152 default 0xd4018000 if DEBUG_MMP_UART3 1153 default 0xe0000000 if ARCH_SPEAR13XX 1154 default 0xe4007000 if DEBUG_HIP04_UART 1155 default 0xf0000be0 if ARCH_EBSA110 1156 default 0xf1012000 if DEBUG_MVEBU_UART_ALTERNATE 1157 default 0xf1012000 if ARCH_DOVE || ARCH_MV78XX0 || \ 1158 ARCH_ORION5X 1159 default 0xf7fc9000 if DEBUG_BERLIN_UART 1160 default 0xf8b00000 if DEBUG_HIX5HD2_UART 1161 default 0xf991e000 if DEBUG_QCOM_UARTDM 1162 default 0xfcb00000 if DEBUG_HI3620_UART 1163 default 0xfe800000 if ARCH_IOP32X 1164 default 0xff690000 if DEBUG_RK32_UART2 1165 default 0xffc02000 if DEBUG_SOCFPGA_UART 1166 default 0xffd82340 if ARCH_IOP13XX 1167 default 0xfff36000 if DEBUG_HIGHBANK_UART 1168 default 0xfffe8600 if DEBUG_UART_BCM63XX 1169 default 0xfffff700 if ARCH_IOP33X 1170 depends on DEBUG_LL_UART_8250 || DEBUG_LL_UART_PL01X || \ 1171 DEBUG_LL_UART_EFM32 || \ 1172 DEBUG_UART_8250 || DEBUG_UART_PL01X || DEBUG_MESON_UARTAO || \ 1173 DEBUG_MSM_UART || DEBUG_QCOM_UARTDM || DEBUG_S3C24XX_UART || \ 1174 DEBUG_UART_BCM63XX 1175 1176config DEBUG_UART_VIRT 1177 hex "Virtual base address of debug UART" 1178 default 0xe0010fe0 if ARCH_RPC 1179 default 0xe1000000 if DEBUG_MSM_UART 1180 default 0xf0000be0 if ARCH_EBSA110 1181 default 0xf01fb000 if DEBUG_NOMADIK_UART 1182 default 0xf0201000 if DEBUG_BCM2835 1183 default 0xf1000300 if DEBUG_BCM_5301X 1184 default 0xf1006000 if DEBUG_MT6589_UART0 1185 default 0xf11f1000 if ARCH_VERSATILE 1186 default 0xf1600000 if ARCH_INTEGRATOR 1187 default 0xf1c28000 if DEBUG_SUNXI_UART0 1188 default 0xf1c28400 if DEBUG_SUNXI_UART1 1189 default 0xf1f02800 if DEBUG_SUNXI_R_UART 1190 default 0xf6200000 if DEBUG_PXA_UART1 1191 default 0xf4090000 if ARCH_LPC32XX 1192 default 0xf4200000 if ARCH_GEMINI 1193 default 0xf7000000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART0 || \ 1194 DEBUG_S3C2410_UART0) 1195 default 0xf7004000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART1 || \ 1196 DEBUG_S3C2410_UART1) 1197 default 0xf7008000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART2 || \ 1198 DEBUG_S3C2410_UART2) 1199 default 0xf7fc9000 if DEBUG_BERLIN_UART 1200 default 0xf8007000 if DEBUG_HIP04_UART 1201 default 0xf8009000 if DEBUG_VEXPRESS_UART0_CA9 1202 default 0xf8090000 if DEBUG_VEXPRESS_UART0_RS1 1203 default 0xfa71e000 if DEBUG_QCOM_UARTDM 1204 default 0xfb002000 if DEBUG_CNS3XXX 1205 default 0xfb009000 if DEBUG_REALVIEW_STD_PORT 1206 default 0xfb10c000 if DEBUG_REALVIEW_PB1176_PORT 1207 default 0xfcfe8600 if DEBUG_UART_BCM63XX 1208 default 0xfd000000 if ARCH_SPEAR3XX || ARCH_SPEAR6XX 1209 default 0xfd000000 if ARCH_SPEAR13XX 1210 default 0xfd012000 if ARCH_MV78XX0 1211 default 0xfde12000 if ARCH_DOVE 1212 default 0xfe012000 if ARCH_ORION5X 1213 default 0xf31004c0 if DEBUG_MESON_UARTAO 1214 default 0xfe017000 if DEBUG_MMP_UART2 1215 default 0xfe018000 if DEBUG_MMP_UART3 1216 default 0xfe100000 if DEBUG_IMX23_UART || DEBUG_IMX28_UART 1217 default 0xfe230000 if DEBUG_PICOXCELL_UART 1218 default 0xfe300000 if DEBUG_BCM_KONA_UART 1219 default 0xfe800000 if ARCH_IOP32X 1220 default 0xfeb00000 if DEBUG_HI3620_UART || DEBUG_HIX5HD2_UART 1221 default 0xfeb24000 if DEBUG_RK3X_UART0 1222 default 0xfeb26000 if DEBUG_RK3X_UART1 1223 default 0xfeb30c00 if DEBUG_KEYSTONE_UART0 1224 default 0xfeb31000 if DEBUG_KEYSTONE_UART1 1225 default 0xfec02000 if DEBUG_SOCFPGA_UART 1226 default 0xfec12000 if DEBUG_MVEBU_UART || DEBUG_MVEBU_UART_ALTERNATE 1227 default 0xfec20000 if DEBUG_DAVINCI_DMx_UART0 1228 default 0xfec90000 if DEBUG_RK32_UART2 1229 default 0xfed0c000 if DEBUG_DAVINCI_DA8XX_UART1 1230 default 0xfed0d000 if DEBUG_DAVINCI_DA8XX_UART2 1231 default 0xfed60000 if DEBUG_RK29_UART0 1232 default 0xfed64000 if DEBUG_RK29_UART1 || DEBUG_RK3X_UART2 1233 default 0xfed68000 if DEBUG_RK29_UART2 || DEBUG_RK3X_UART3 1234 default 0xfedc0000 if ARCH_EP93XX 1235 default 0xfee003f8 if FOOTBRIDGE 1236 default 0xfee20000 if DEBUG_NSPIRE_CLASSIC_UART || DEBUG_NSPIRE_CX_UART 1237 default 0xfee82340 if ARCH_IOP13XX 1238 default 0xfef00000 if ARCH_IXP4XX && !CPU_BIG_ENDIAN 1239 default 0xfef00003 if ARCH_IXP4XX && CPU_BIG_ENDIAN 1240 default 0xfef36000 if DEBUG_HIGHBANK_UART 1241 default 0xfefff700 if ARCH_IOP33X 1242 default 0xff003000 if DEBUG_U300_UART 1243 default DEBUG_UART_PHYS if !MMU 1244 depends on DEBUG_LL_UART_8250 || DEBUG_LL_UART_PL01X || \ 1245 DEBUG_UART_8250 || DEBUG_UART_PL01X || DEBUG_MESON_UARTAO || \ 1246 DEBUG_MSM_UART || DEBUG_QCOM_UARTDM || DEBUG_S3C24XX_UART || \ 1247 DEBUG_UART_BCM63XX 1248 1249config DEBUG_UART_8250_SHIFT 1250 int "Register offset shift for the 8250 debug UART" 1251 depends on DEBUG_LL_UART_8250 || DEBUG_UART_8250 1252 default 0 if FOOTBRIDGE || ARCH_IOP32X 1253 default 2 1254 1255config DEBUG_UART_8250_WORD 1256 bool "Use 32-bit accesses for 8250 UART" 1257 depends on DEBUG_LL_UART_8250 || DEBUG_UART_8250 1258 depends on DEBUG_UART_8250_SHIFT >= 2 1259 default y if DEBUG_PICOXCELL_UART || DEBUG_SOCFPGA_UART || \ 1260 ARCH_KEYSTONE || \ 1261 DEBUG_DAVINCI_DMx_UART0 || DEBUG_DAVINCI_DA8XX_UART1 || \ 1262 DEBUG_DAVINCI_DA8XX_UART2 || \ 1263 DEBUG_BCM_KONA_UART || DEBUG_RK32_UART2 1264 1265config DEBUG_UART_8250_FLOW_CONTROL 1266 bool "Enable flow control for 8250 UART" 1267 depends on DEBUG_LL_UART_8250 || DEBUG_UART_8250 1268 default y if ARCH_EBSA110 || FOOTBRIDGE || ARCH_GEMINI || ARCH_RPC 1269 1270config DEBUG_UNCOMPRESS 1271 bool 1272 depends on ARCH_MULTIPLATFORM || ARCH_MSM || PLAT_SAMSUNG 1273 default y if DEBUG_LL && !DEBUG_OMAP2PLUS_UART && \ 1274 (!DEBUG_TEGRA_UART || !ZBOOT_ROM) 1275 help 1276 This option influences the normal decompressor output for 1277 multiplatform kernels. Normally, multiplatform kernels disable 1278 decompressor output because it is not possible to know where to 1279 send the decompressor output. 1280 1281 When this option is set, the selected DEBUG_LL output method 1282 will be re-used for normal decompressor output on multiplatform 1283 kernels. 1284 1285 1286config UNCOMPRESS_INCLUDE 1287 string 1288 default "debug/uncompress.h" if ARCH_MULTIPLATFORM || ARCH_MSM || \ 1289 PLAT_SAMSUNG || ARCH_EFM32 1290 default "mach/uncompress.h" 1291 1292config EARLY_PRINTK 1293 bool "Early printk" 1294 depends on DEBUG_LL 1295 help 1296 Say Y here if you want to have an early console using the 1297 kernel low-level debugging functions. Add earlyprintk to your 1298 kernel parameters to enable this console. 1299 1300config OC_ETM 1301 bool "On-chip ETM and ETB" 1302 depends on ARM_AMBA 1303 help 1304 Enables the on-chip embedded trace macrocell and embedded trace 1305 buffer driver that will allow you to collect traces of the 1306 kernel code. 1307 1308config ARM_KPROBES_TEST 1309 tristate "Kprobes test module" 1310 depends on KPROBES && MODULES 1311 help 1312 Perform tests of kprobes API and instruction set simulation. 1313 1314config PID_IN_CONTEXTIDR 1315 bool "Write the current PID to the CONTEXTIDR register" 1316 depends on CPU_COPY_V6 1317 help 1318 Enabling this option causes the kernel to write the current PID to 1319 the PROCID field of the CONTEXTIDR register, at the expense of some 1320 additional instructions during context switch. Say Y here only if you 1321 are planning to use hardware trace tools with this kernel. 1322 1323config DEBUG_SET_MODULE_RONX 1324 bool "Set loadable kernel module data as NX and text as RO" 1325 depends on MODULES 1326 ---help--- 1327 This option helps catch unintended modifications to loadable 1328 kernel module's text and read-only data. It also prevents execution 1329 of module data. Such protection may interfere with run-time code 1330 patching and dynamic kernel tracing - and they might also protect 1331 against certain classes of kernel exploits. 1332 If in doubt, say "N". 1333 1334endmenu 1335