Kconfig 15.3 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11
# arch/arm/mach-s3c24xx/Kconfig
#
# Copyright (c) 2012 Samsung Electronics Co., Ltd.
#		http://www.samsung.com/
#
# Copyright 2007 Simtec Electronics
#
# Licensed under GPLv2

if ARCH_S3C24XX

12 13 14
config PLAT_S3C24XX
	def_bool y
	select ARCH_REQUIRE_GPIOLIB
15
	select NO_IOPORT_MAP
16 17 18 19 20
	select S3C_DEV_NAND
	select IRQ_DOMAIN
	help
	  Base platform code for any Samsung S3C24XX device

21 22 23 24 25 26 27 28 29
menu "SAMSUNG S3C24XX SoCs Support"

comment "S3C24XX SoCs"

config CPU_S3C2410
	bool "SAMSUNG S3C2410"
	default y
	select CPU_ARM920T
	select CPU_LLSERIAL_S3C2410
30
	select S3C2410_CLOCK
31
	select S3C2410_DMA if S3C24XX_DMA
32
	select ARM_S3C2410_CPUFREQ if ARM_S3C24XX_CPUFREQ
33
	select S3C2410_PM if PM
34
	select SAMSUNG_WDT_RESET
35 36 37 38
	help
	  Support for S3C2410 and S3C2410A family from the S3C24XX line
	  of Samsung Mobile CPUs.

39 40 41 42 43
config CPU_S3C2412
	bool "SAMSUNG S3C2412"
	select CPU_ARM926T
	select CPU_LLSERIAL_S3C2440
	select S3C2412_DMA if S3C24XX_DMA
44
	select S3C2412_PM if PM
45 46 47
	help
	  Support for the S3C2412 and S3C2413 SoCs from the S3C24XX line

48 49 50 51
config CPU_S3C2416
	bool "SAMSUNG S3C2416/S3C2450"
	select CPU_ARM926T
	select CPU_LLSERIAL_S3C2440
52
	select S3C2416_PM if PM
53
	select S3C2443_COMMON
54
	select S3C2443_DMA if S3C24XX_DMA
55
	select SAMSUNG_CLKSRC
56 57 58
	help
	  Support for the S3C2416 SoC from the S3C24XX line

59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
config CPU_S3C2440
	bool "SAMSUNG S3C2440"
	select CPU_ARM920T
	select CPU_LLSERIAL_S3C2440
	select S3C2410_CLOCK
	select S3C2410_PM if PM
	select S3C2440_DMA if S3C24XX_DMA
	help
	  Support for S3C2440 Samsung Mobile CPU based systems.

config CPU_S3C2442
	bool "SAMSUNG S3C2442"
	select CPU_ARM920T
	select CPU_LLSERIAL_S3C2440
	select S3C2410_CLOCK
74
	select S3C2410_DMA if S3C24XX_DMA
75 76 77 78 79 80 81
	select S3C2410_PM if PM
	help
	  Support for S3C2442 Samsung Mobile CPU based systems.

config CPU_S3C244X
	def_bool y
	depends on CPU_S3C2440 || CPU_S3C2442
82
	select SAMSUNG_WDT_RESET
83

84 85 86 87
config CPU_S3C2443
	bool "SAMSUNG S3C2443"
	select CPU_ARM920T
	select CPU_LLSERIAL_S3C2440
88
	select S3C2443_COMMON
89
	select S3C2443_DMA if S3C24XX_DMA
90
	select SAMSUNG_CLKSRC
91 92 93
	help
	  Support for the S3C2443 SoC from the S3C24XX line

94 95
# common code

96 97 98 99 100 101 102 103 104 105 106
config S3C2410_CLOCK
	bool
	help
	  Clock code for the S3C2410, and similar processors which
	  is currently includes the S3C2410, S3C2440, S3C2442.

config S3C24XX_DCLK
	bool
	help
	  Clock code for supporting DCLK/CLKOUT on S3C24XX architectures

107 108 109 110 111
config S3C24XX_SMDK
	bool
	help
	  Common machine code for SMDK2410 and SMDK2440

112 113 114 115 116 117 118 119 120 121 122 123 124
config S3C24XX_SIMTEC_AUDIO
	bool
	depends on (ARCH_BAST || MACH_VR1000 || MACH_OSIRIS || MACH_ANUBIS)
	default y
	help
	  Add audio devices for common Simtec S3C24XX boards

config S3C24XX_SIMTEC_PM
	bool
	help
	  Common power management code for systems that are
	  compatible with the Simtec style of power management

125 126 127 128 129
config S3C24XX_SIMTEC_USB
	bool
	help
	  USB management code for common Simtec S3C24XX boards

130 131 132 133 134
config S3C24XX_SETUP_TS
	bool
	help
	  Compile in platform device definition for Samsung TouchScreen.

135 136 137 138 139 140 141 142 143 144
config S3C24XX_DMA
	bool "S3C2410 DMA support"
	select S3C_DMA
	help
	  S3C2410 DMA support. This is needed for drivers like sound which
	  use the S3C2410's DMA system to move data to and from the
	  peripheral blocks.

config S3C2410_DMA_DEBUG
	bool "S3C2410 DMA support debug"
145
	depends on S3C2410_DMA
146 147 148 149
	help
	  Enable debugging output for the DMA code. This option sends info
	  to the kernel log, at priority KERN_DEBUG.

150 151
config S3C2410_DMA
	bool
152
	depends on S3C24XX_DMA && (CPU_S3C2410 || CPU_S3C2442)
153 154 155 156 157 158 159 160
	help
	  DMA device selection for S3C2410 and compatible CPUs

config S3C2410_PM
	bool
	help
	  Power Management code common to S3C2410 and better

161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182
# low-level serial option nodes

config CPU_LLSERIAL_S3C2410_ONLY
	bool
	default y if CPU_LLSERIAL_S3C2410 && !CPU_LLSERIAL_S3C2440

config CPU_LLSERIAL_S3C2440_ONLY
	bool
	default y if CPU_LLSERIAL_S3C2440 && !CPU_LLSERIAL_S3C2410

config CPU_LLSERIAL_S3C2410
	bool
	help
	  Selected if there is an S3C2410 (or register compatible) serial
	  low-level implementation needed

config CPU_LLSERIAL_S3C2440
	bool
	help
	  Selected if there is an S3C2440 (or register compatible) serial
	  low-level implementation needed

183 184
config S3C24XX_PLL
	bool "Support CPUfreq changing of PLL frequency (EXPERIMENTAL)"
185
	depends on ARM_S3C24XX_CPUFREQ
186 187 188 189 190 191 192 193
	help
	  Compile in support for changing the PLL frequency from the
	  S3C24XX series CPUfreq driver. The PLL takes time to settle
	  after a frequency change, so by default it is not enabled.

	  This also means that the PLL tables for the selected CPU(s) will
	  be built which may increase the size of the kernel image.

194 195 196 197
# cpu frequency items common between s3c2410 and s3c2440/s3c2442

config S3C2410_IOTIMING
	bool
198
	depends on ARM_S3C24XX_CPUFREQ
199 200 201 202 203
	help
	  Internal node to select io timing code that is common to the s3c2410
	  and s3c2440/s3c2442 cpu frequency support.

config S3C2410_CPUFREQ_UTILS
204 205 206 207 208
       bool
       depends on ARM_S3C24XX_CPUFREQ
       help
         Internal node to select timing code that is common to the s3c2410
         and s3c2440/s3c244 cpu frequency support.
209 210 211 212 213

# cpu frequency support common to s3c2412, s3c2413 and s3c2442

config S3C2412_IOTIMING
	bool
214
	depends on ARM_S3C24XX_CPUFREQ && (CPU_S3C2412 || CPU_S3C2443)
215 216 217 218
	help
	  Intel node to select io timing code that is common to the s3c2412
	  and the s3c2443.

219 220 221 222
# cpu-specific sections

if CPU_S3C2410

223 224
config S3C2410_PLL
	bool
225
	depends on ARM_S3C2410_CPUFREQ && S3C24XX_PLL
226 227 228 229
	default y
	help
	  Select the PLL table for the S3C2410

230
config S3C24XX_SIMTEC_NOR
231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250
	bool
	help
	  Internal node to specify machine has simtec NOR mapping

config MACH_BAST_IDE
	bool
	select HAVE_PATA_PLATFORM
	help
	  Internal node for machines with an BAST style IDE
	  interface

comment "S3C2410 Boards"

#
# The "S3C2410 Boards" list is ordered alphabetically by option text.
# (without ARCH_ or MACH_)
#

config MACH_AML_M5900
	bool "AML M5900 Series"
251
	select S3C24XX_SIMTEC_PM if PM
252 253 254 255 256 257 258
	select S3C_DEV_USB_HOST
	help
	  Say Y here if you are using the American Microsystems M5900 Series
	  <http://www.amltd.com>

config ARCH_BAST
	bool "Simtec Electronics BAST (EB2410ITX)"
259 260
	select ISA
	select MACH_BAST_IDE
261
	select S3C2410_IOTIMING if ARM_S3C2410_CPUFREQ
262
	select S3C24XX_DCLK
263
	select S3C24XX_SIMTEC_NOR
264
	select S3C24XX_SIMTEC_PM if PM
265
	select S3C24XX_SIMTEC_USB
266 267
	select S3C_DEV_HWMON
	select S3C_DEV_NAND
268
	select S3C_DEV_USB_HOST
269 270 271 272 273 274 275 276 277 278 279 280 281 282 283
	help
	  Say Y here if you are using the Simtec Electronics EB2410ITX
	  development board (also known as BAST)

config BAST_PC104_IRQ
	bool "BAST PC104 IRQ support"
	depends on ARCH_BAST
	default y
	help
	  Say Y	here to enable the PC104 IRQ routing on the
	  Simtec BAST (EB2410ITX)

config ARCH_H1940
	bool "IPAQ H1940"
	select PM_H1940 if PM
284
	select S3C24XX_SETUP_TS
285 286
	select S3C_DEV_NAND
	select S3C_DEV_USB_HOST
287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305
	help
	  Say Y here if you are using the HP IPAQ H1940

config H1940BT
	tristate "Control the state of H1940 bluetooth chip"
	depends on ARCH_H1940
	select RFKILL
	help
	  This is a simple driver that is able to control
	  the state of built in bluetooth chip on h1940.

config PM_H1940
	bool
	help
	  Internal node for H1940 and related PM

config MACH_N30
	bool "Acer N30 family"
	select S3C_DEV_NAND
306
	select S3C_DEV_USB_HOST
307 308 309 310 311 312 313
	help
	  Say Y here if you want suppt for the Acer N30, Acer N35,
	  Navman PiN570, Yakumo AlphaX or Airis NC05 PDAs.

config MACH_OTOM
	bool "NexVision OTOM Board"
	select S3C_DEV_NAND
314
	select S3C_DEV_USB_HOST
315 316 317 318 319 320
	help
	  Say Y here if you are using the Nex Vision OTOM board

config MACH_QT2410
	bool "QT2410"
	select S3C_DEV_NAND
321
	select S3C_DEV_USB_HOST
322 323 324 325 326
	help
	  Say Y here if you are using the Armzone QT2410

config ARCH_SMDK2410
	bool "SMDK2410/A9M2410"
327
	select S3C24XX_SMDK
328
	select S3C_DEV_USB_HOST
329 330 331 332 333 334 335 336 337 338 339 340 341
	help
	  Say Y here if you are using the SMDK2410 or the derived module A9M2410
	  <http://www.fsforth.de>

config MACH_TCT_HAMMER
	bool "TCT Hammer Board"
	select S3C_DEV_USB_HOST
	help
	  Say Y here if you are using the TinCanTools Hammer Board
	  <http://www.tincantools.com>

config MACH_VR1000
	bool "Thorcom VR1000"
342
	select MACH_BAST_IDE
343
	select S3C24XX_DCLK
344
	select S3C24XX_SIMTEC_NOR
345
	select S3C24XX_SIMTEC_PM if PM
346
	select S3C24XX_SIMTEC_USB
347
	select S3C_DEV_USB_HOST
348 349 350 351 352
	help
	  Say Y here if you are using the Thorcom VR1000 board.

endif	# CPU_S3C2410

353 354 355 356 357 358 359 360 361 362 363
config S3C2412_PM_SLEEP
	bool
	help
	  Internal config node to apply sleep for S3C2412 power management.
	  Can be selected by another SoCs such as S3C2416 with similar
	  sleep procedure.

if CPU_S3C2412

config CPU_S3C2412_ONLY
	bool
364
	depends on !CPU_S3C2410 && !CPU_S3C2416 && !CPU_S3C2440 && \
365
		   !CPU_S3C2442 && !CPU_S3C2443
366 367 368 369 370 371 372 373 374
	default y

config S3C2412_DMA
	bool
	help
	  Internal config node for S3C2412 DMA support

config S3C2412_PM
	bool
375
	select S3C2412_PM_SLEEP
376
	select SAMSUNG_WAKEMASK
377 378 379 380 381 382 383 384 385 386 387 388 389
	help
	  Internal config node to apply S3C2412 power management

comment "S3C2412 Boards"

#
# The "S3C2412 Boards" list is ordered alphabetically by option text.
# (without ARCH_ or MACH_)
#

config MACH_JIVE
	bool "Logitech Jive"
	select S3C_DEV_NAND
390
	select S3C_DEV_USB_HOST
391 392 393 394
	help
	  Say Y here if you are using the Logitech Jive.

config MACH_JIVE_SHOW_BOOTLOADER
395 396
	bool "Allow access to bootloader partitions in MTD"
	depends on MACH_JIVE
397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416

config MACH_S3C2413
	bool
	help
	  Internal node for S3C2413 version of SMDK2413, so that
	  machine_is_s3c2413() will work when MACH_SMDK2413 is
	  selected

config MACH_SMDK2412
	bool "SMDK2412"
	select MACH_SMDK2413
	help
	  Say Y here if you are using an SMDK2412

	  Note, this shares support with SMDK2413, so will automatically
	  select MACH_SMDK2413.

config MACH_SMDK2413
	bool "SMDK2413"
	select MACH_S3C2413
417
	select S3C24XX_SMDK
418
	select S3C_DEV_NAND
419
	select S3C_DEV_USB_HOST
420 421 422 423 424 425
	help
	  Say Y here if you are using an SMDK2413

config MACH_VSTMS
	bool "VMSTMS"
	select S3C_DEV_NAND
426
	select S3C_DEV_USB_HOST
427 428 429 430 431
	help
	  Say Y here if you are using an VSTMS board

endif	# CPU_S3C2412

432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454
if CPU_S3C2416

config S3C2416_PM
	bool
	select S3C2412_PM_SLEEP
	help
	  Internal config node to apply S3C2416 power management

config S3C2416_SETUP_SDHCI
	bool
	select S3C2416_SETUP_SDHCI_GPIO
	help
	  Internal helper functions for S3C2416 based SDHCI systems

config S3C2416_SETUP_SDHCI_GPIO
	bool
	help
	  Common setup code for SDHCI gpio.

comment "S3C2416 Boards"

config MACH_SMDK2416
	bool "SMDK2416"
455
	select S3C2416_SETUP_SDHCI
456
	select S3C24XX_SMDK
457 458 459 460 461 462 463 464
	select S3C_DEV_FB
	select S3C_DEV_HSMMC
	select S3C_DEV_HSMMC1
	select S3C_DEV_NAND
	select S3C_DEV_USB_HOST
	help
	  Say Y here if you are using an SMDK2416

465 466 467 468 469 470 471 472 473 474 475 476
config MACH_S3C2416_DT
	bool "Samsung S3C2416 machine using devicetree"
	select CLKSRC_OF
	select USE_OF
	select PINCTRL
	select PINCTRL_S3C24XX
	help
	  Machine support for Samsung S3C2416 machines with device tree enabled.
	  Select this if a fdt blob is available for the S3C2416 SoC based board.
	  Note: This is under development and not all peripherals can be supported
	  with this machine file.

477 478
endif	# CPU_S3C2416

479 480 481 482 483 484 485
if CPU_S3C2440

config S3C2440_DMA
	bool
	help
	  Support for S3C2440 specific DMA code5A

486 487 488 489 490 491 492 493 494 495 496 497 498 499
config S3C2440_XTAL_12000000
	bool
	help
	  Indicate that the build needs to support 12MHz system
	  crystal.

config S3C2440_XTAL_16934400
	bool
	help
	  Indicate that the build needs to support 16.9344MHz system
	  crystal.

config S3C2440_PLL_12000000
	bool
500 501
	depends on ARM_S3C2440_CPUFREQ && S3C2440_XTAL_12000000
	default y if S3C24XX_PLL
502 503 504 505 506
	help
	  PLL tables for S3C2440 or S3C2442 CPUs with 12MHz crystals.

config S3C2440_PLL_16934400
	bool
507 508
	depends on ARM_S3C2440_CPUFREQ && S3C2440_XTAL_16934400
	default y if S3C24XX_PLL
509 510 511
	help
	  PLL tables for S3C2440 or S3C2442 CPUs with 16.934MHz crystals.

512 513 514 515 516 517 518 519 520 521 522
comment "S3C2440 Boards"

#
# The "S3C2440 Boards" list is ordered alphabetically by option text.
# (without ARCH_ or MACH_)
#

config MACH_ANUBIS
	bool "Simtec Electronics ANUBIS"
	select HAVE_PATA_PLATFORM
	select S3C2440_XTAL_12000000
523 524
	select S3C24XX_DCLK
	select S3C24XX_SIMTEC_PM if PM
525 526 527 528 529 530 531 532
	select S3C_DEV_USB_HOST
	help
	  Say Y here if you are using the Simtec Electronics ANUBIS
	  development system

config MACH_AT2440EVB
	bool "Avantech AT2440EVB development board"
	select S3C_DEV_NAND
533
	select S3C_DEV_USB_HOST
534 535 536 537 538
	help
	  Say Y here if you are using the AT2440EVB development board

config MACH_MINI2440
	bool "MINI2440 development board"
539
	select EEPROM_AT24 if I2C
540
	select LEDS_CLASS
541
	select LEDS_TRIGGERS
542
	select LEDS_TRIGGER_BACKLIGHT
543
	select NEW_LEDS
544 545
	select S3C_DEV_NAND
	select S3C_DEV_USB_HOST
546
	select S3C_SETUP_CAMIF
547 548 549 550 551 552 553 554
	help
	  Say Y here to select support for the MINI2440. Is a 10cm x 10cm board
	  available via various sources. It can come with a 3.5" or 7" touch LCD.

config MACH_NEXCODER_2440
	bool "NexVision NEXCODER 2440 Light Board"
	select S3C2440_XTAL_12000000
	select S3C_DEV_NAND
555
	select S3C_DEV_USB_HOST
556 557 558 559 560
	help
	  Say Y here if you are using the Nex Vision NEXCODER 2440 Light Board

config MACH_OSIRIS
	bool "Simtec IM2440D20 (OSIRIS) module"
561
	select S3C2410_IOTIMING if ARM_S3C2440_CPUFREQ
562
	select S3C2440_XTAL_12000000
563
	select S3C24XX_DCLK
564
	select S3C24XX_SIMTEC_PM if PM
565
	select S3C_DEV_NAND
566
	select S3C_DEV_USB_HOST
567 568 569 570 571 572 573
	help
	  Say Y here if you are using the Simtec IM2440D20 module, also
	  known as the Osiris.

config MACH_OSIRIS_DVS
	tristate "Simtec IM2440D20 (OSIRIS) Dynamic Voltage Scaling driver"
	depends on MACH_OSIRIS
574
	depends on TPS65010
575 576 577 578 579 580 581 582 583 584 585 586
	help
	  Say Y/M here if you want to have dynamic voltage scaling support
	  on the Simtec IM2440D20 (OSIRIS) module via the TPS65011.

	  The DVS driver alters the voltage supplied to the ARM core
	  depending on the frequency it is running at. The driver itself
	  does not do any of the frequency alteration, which is left up
	  to the cpufreq driver.

config MACH_RX3715
	bool "HP iPAQ rx3715"
	select PM_H1940 if PM
587
	select S3C2440_XTAL_16934400
588 589 590 591 592 593 594
	select S3C_DEV_NAND
	help
	  Say Y here if you are using the HP iPAQ rx3715.

config ARCH_S3C2440
	bool "SMDK2440"
	select S3C2440_XTAL_16934400
595
	select S3C24XX_SMDK
596
	select S3C_DEV_NAND
597
	select S3C_DEV_USB_HOST
598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618
	help
	  Say Y here if you are using the SMDK2440.

config SMDK2440_CPU2440
	bool "SMDK2440 with S3C2440 CPU module"
	default y if ARCH_S3C2440
	select S3C2440_XTAL_16934400

endif	# CPU_S3C2440

if CPU_S3C2442

comment "S3C2442 Boards"

#
# The "S3C2442 Boards" list is ordered alphabetically by option text.
# (without ARCH_ or MACH_)
#

config MACH_NEO1973_GTA02
	bool "Openmoko GTA02 / Freerunner phone"
619
	select I2C
620 621 622
	select MFD_PCF50633
	select PCF50633_GPIO
	select POWER_SUPPLY
A
Arnd Bergmann 已提交
623
	select S3C24XX_PWM
624 625 626 627 628 629 630
	select S3C_DEV_USB_HOST
	help
	   Say Y here if you are using the Openmoko GTA02 / Freerunner GSM Phone

config MACH_RX1950
	bool "HP iPAQ rx1950"
	select I2C
631
	select PM_H1940 if PM
632
	select S3C2410_IOTIMING if ARM_S3C2440_CPUFREQ
633
	select S3C2440_XTAL_16934400
634 635 636
	select S3C24XX_DCLK
	select S3C24XX_PWM
	select S3C_DEV_NAND
637 638 639
	help
	   Say Y here if you're using HP iPAQ rx1950

640
endif	# CPU_S3C2442
641

642 643 644 645 646 647 648 649
if CPU_S3C2443 || CPU_S3C2416

config S3C2443_COMMON
	bool
	help
	  Common code for the S3C2443 and similar processors, which includes
	  the S3C2416 and S3C2450.

650 651 652 653 654 655
config S3C2443_COMMON_CLK
	bool
	help
	  Temporary symbol to build the clock driver based on the common clock
	  framework.

656 657 658 659 660
config S3C2443_DMA
	bool
	help
	  Internal config node for S3C2443 DMA support

661 662 663 664 665
config S3C2443_SETUP_SPI
	bool
	help
	  Common setup code for SPI GPIO configurations

666 667 668 669
endif	# CPU_S3C2443 || CPU_S3C2416

if CPU_S3C2443

670 671 672 673
comment "S3C2443 Boards"

config MACH_SMDK2443
	bool "SMDK2443"
674
	select S3C24XX_SMDK
675 676 677 678 679 680
	select S3C_DEV_HSMMC1
	help
	  Say Y here if you are using an SMDK2443

endif	# CPU_S3C2443

681 682 683
endmenu	# SAMSUNG S3C24XX SoCs Support

endif	# ARCH_S3C24XX