blob: 06e73bf665e92cba042590dbe68a50a463d50f76 [file] [log] [blame]
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -07001config AVR32
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +01002 def_bool y
David Rientjes6a108a12011-01-20 14:44:16 -08003 # With EXPERT=n, we get lots of stuff automatically selected
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -07004 # that we usually don't need on AVR32.
David Rientjes6a108a12011-01-20 14:44:16 -08005 select EXPERT
David Brownell9483a572008-07-23 21:26:48 -07006 select HAVE_CLK
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -05007 select HAVE_OPROFILE
Mathieu Desnoyers3f550092008-02-02 15:10:35 -05008 select HAVE_KPROBES
Thomas Gleixner25015332011-02-06 17:29:04 +01009 select HAVE_GENERIC_HARDIRQS
10 select GENERIC_IRQ_PROBE
Fabio Baltieri31e00172012-02-03 15:37:14 -080011 select GENERIC_ATOMIC64
Thomas Gleixner25015332011-02-06 17:29:04 +010012 select HARDIRQS_SW_RESEND
Thomas Gleixnerdb828172011-03-24 19:08:11 +010013 select GENERIC_IRQ_SHOW
Mark Brown7563bbf2012-04-15 10:52:54 +010014 select ARCH_HAVE_CUSTOM_GPIO_H
Will Deaconc1d7e012012-07-30 14:42:46 -070015 select ARCH_WANT_IPC_PARSE_VERSION
Huang Yingdf013ff2011-07-13 13:14:22 +080016 select ARCH_HAVE_NMI_SAFE_CMPXCHG
Anna-Maria Gleixner8d6af992012-05-18 16:45:45 +000017 select GENERIC_CLOCKEVENTS
David Howells786d35d2012-09-28 14:31:03 +093018 select HAVE_MOD_ARCH_SPECIFIC
19 select MODULES_USE_ELF_RELA
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070020 help
21 AVR32 is a high-performance 32-bit RISC microprocessor core,
22 designed for cost-sensitive embedded applications, with particular
23 emphasis on low power consumption and high code density.
24
25 There is an AVR32 Linux project with a web page at
26 http://avr32linux.org/.
27
David Brownell0a938b92007-03-05 00:30:18 -080028config GENERIC_GPIO
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010029 def_bool y
David Brownell0a938b92007-03-05 00:30:18 -080030
Haavard Skinnemoen2f026032007-11-23 20:01:59 +010031config STACKTRACE_SUPPORT
32 def_bool y
33
Haavard Skinnemoen320516b2007-11-26 14:34:57 +010034config LOCKDEP_SUPPORT
35 def_bool y
36
37config TRACE_IRQFLAGS_SUPPORT
38 def_bool y
39
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070040config RWSEM_GENERIC_SPINLOCK
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010041 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070042
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070043config RWSEM_XCHGADD_ALGORITHM
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010044 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070045
David Howellsf0d1b0b2006-12-08 02:37:49 -080046config ARCH_HAS_ILOG2_U32
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010047 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080048
49config ARCH_HAS_ILOG2_U64
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010050 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080051
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070052config GENERIC_HWEIGHT
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010053 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070054
55config GENERIC_CALIBRATE_DELAY
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010056 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070057
Haavard Skinnemoen623b0352007-03-13 17:59:11 +010058config GENERIC_BUG
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010059 def_bool y
Haavard Skinnemoen623b0352007-03-13 17:59:11 +010060 depends on BUG
61
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070062source "init/Kconfig"
63
Matt Helsleydc52ddc2008-10-18 20:27:21 -070064source "kernel/Kconfig.freezer"
65
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070066menu "System Type and features"
67
68config SUBARCH_AVR32B
69 bool
70config MMU
71 bool
72config PERFORMANCE_COUNTERS
73 bool
74
75config PLATFORM_AT32AP
76 bool
77 select SUBARCH_AVR32B
78 select MMU
79 select PERFORMANCE_COUNTERS
Michael Buesch7444a722008-07-25 01:46:11 -070080 select ARCH_REQUIRE_GPIOLIB
Haavard Skinnemoenb83d6ee12008-03-05 10:00:28 +010081 select GENERIC_ALLOCATOR
Nicolas Ferre0912e532009-06-23 16:30:56 +020082 select HAVE_FB_ATMEL
Jean-Christophe PLAGNIOL-VILLARDee621dd2010-08-08 06:21:33 +020083 select HAVE_NET_MACB
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070084
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +010085#
86# CPU types
87#
88
89# AP7000 derivatives
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010090config CPU_AT32AP700X
91 bool
92 select PLATFORM_AT32AP
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070093config CPU_AT32AP7000
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +010094 bool
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010095 select CPU_AT32AP700X
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010096config CPU_AT32AP7001
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +010097 bool
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010098 select CPU_AT32AP700X
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010099config CPU_AT32AP7002
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +0100100 bool
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100101 select CPU_AT32AP700X
102
Hans-Christian Egtvedt3550b932009-12-03 14:58:20 +0100103# AP700X boards
104config BOARD_ATNGW100_COMMON
105 bool
106 select CPU_AT32AP7000
107
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700108choice
109 prompt "AVR32 board type"
110 default BOARD_ATSTK1000
111
112config BOARD_ATSTK1000
113 bool "ATSTK1000 evaluation board"
Haavard Skinnemoen9ca20a82007-04-12 17:26:57 +0200114
Hans-Christian Egtvedt3550b932009-12-03 14:58:20 +0100115config BOARD_ATNGW100_MKI
Haavard Skinnemoen9ca20a82007-04-12 17:26:57 +0200116 bool "ATNGW100 Network Gateway"
Hans-Christian Egtvedt3550b932009-12-03 14:58:20 +0100117 select BOARD_ATNGW100_COMMON
118
119config BOARD_ATNGW100_MKII
120 bool "ATNGW100 mkII Network Gateway"
121 select BOARD_ATNGW100_COMMON
Hans-Christian Egtvedt45c349b2008-07-29 09:25:37 +0000122
Alex Raimondidd5e1332008-12-09 16:17:13 +0100123config BOARD_HAMMERHEAD
124 bool "Hammerhead board"
125 select CPU_AT32AP7000
126 select USB_ARCH_HAS_HCD
127 help
Matt LaPlante692105b2009-01-26 11:12:25 +0100128 The Hammerhead platform is built around an AVR32 32-bit microcontroller from Atmel.
Alex Raimondidd5e1332008-12-09 16:17:13 +0100129 It offers versatile peripherals, such as ethernet, usb device, usb host etc.
130
Matt LaPlante692105b2009-01-26 11:12:25 +0100131 The board also incorporates a power supply and is a Power over Ethernet (PoE) Powered
Alex Raimondidd5e1332008-12-09 16:17:13 +0100132 Device (PD).
133
Matt LaPlante692105b2009-01-26 11:12:25 +0100134 Additionally, a Cyclone III FPGA from Altera is integrated on the board. The FPGA is
Alex Raimondidd5e1332008-12-09 16:17:13 +0100135 mapped into the 32-bit AVR memory bus. The FPGA offers two DDR2 SDRAM interfaces, which
136 will cover even the most exceptional need of memory bandwidth. Together with the onboard
137 video decoder the board is ready for video processing.
138
Justin P. Mattock50a23e62010-10-16 10:36:23 -0700139 For more information see: http://www.miromico.ch/index.php/hammerhead.html
Alex Raimondidd5e1332008-12-09 16:17:13 +0100140
Hans-Christian Egtvedt45c349b2008-07-29 09:25:37 +0000141config BOARD_FAVR_32
142 bool "Favr-32 LCD-board"
143 select CPU_AT32AP7000
Mark Jackson5b50c162008-10-13 13:14:50 +0000144
Jonas Larssona16fffdd2009-03-27 10:18:14 +0100145config BOARD_MERISC
146 bool "Merisc board"
147 select CPU_AT32AP7000
148 help
149 Merisc is the family name for a range of AVR32-based boards.
150
151 The boards are designed to be used in a man-machine
152 interfacing environment, utilizing a touch-based graphical
153 user interface. They host a vast range of I/O peripherals as
154 well as a large SDRAM & Flash memory bank.
155
156 For more information see: http://www.martinsson.se/merisc
157
Mark Jackson5b50c162008-10-13 13:14:50 +0000158config BOARD_MIMC200
159 bool "MIMC200 CPU board"
160 select CPU_AT32AP7000
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700161endchoice
162
David Brownella8e93ed2007-06-12 14:34:47 +0200163source "arch/avr32/boards/atstk1000/Kconfig"
Hans-Christian Egtvedta3bee422008-07-01 08:29:27 +0000164source "arch/avr32/boards/atngw100/Kconfig"
Alex Raimondidd5e1332008-12-09 16:17:13 +0100165source "arch/avr32/boards/hammerhead/Kconfig"
Hans-Christian Egtvedt45c349b2008-07-29 09:25:37 +0000166source "arch/avr32/boards/favr-32/Kconfig"
Jonas Larssona16fffdd2009-03-27 10:18:14 +0100167source "arch/avr32/boards/merisc/Kconfig"
David Brownella8e93ed2007-06-12 14:34:47 +0200168
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700169choice
170 prompt "Boot loader type"
171 default LOADER_U_BOOT
172
173config LOADER_U_BOOT
174 bool "U-Boot (or similar) bootloader"
175endchoice
176
Haavard Skinnemoen228e8452007-03-07 15:24:34 +0100177source "arch/avr32/mach-at32ap/Kconfig"
178
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700179config LOAD_ADDRESS
180 hex
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100181 default 0x10000000 if LOADER_U_BOOT=y && CPU_AT32AP700X=y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700182
183config ENTRY_ADDRESS
184 hex
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100185 default 0x90000000 if LOADER_U_BOOT=y && CPU_AT32AP700X=y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700186
187config PHYS_OFFSET
188 hex
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100189 default 0x10000000 if CPU_AT32AP700X=y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700190
191source "kernel/Kconfig.preempt"
192
Haavard Skinnemoen5a4d5292008-01-14 23:33:44 +0100193config QUICKLIST
194 def_bool y
195
Tejun Heoc1329372009-02-24 11:57:20 +0900196config HAVE_ARCH_BOOTMEM
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100197 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700198
199config ARCH_HAVE_MEMORY_PRESENT
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100200 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700201
202config NEED_NODE_MEMMAP_SIZE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100203 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700204
205config ARCH_FLATMEM_ENABLE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100206 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700207
208config ARCH_DISCONTIGMEM_ENABLE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100209 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700210
211config ARCH_SPARSEMEM_ENABLE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100212 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700213
214source "mm/Kconfig"
215
216config OWNERSHIP_TRACE
217 bool "Ownership trace support"
218 default y
219 help
220 Say Y to generate an Ownership Trace message on every context switch,
221 enabling Nexus-compliant debuggers to keep track of the PID of the
222 currently executing task.
223
Haavard Skinnemoene7ba1762007-10-10 14:58:29 +0200224config NMI_DEBUGGING
225 bool "NMI Debugging"
226 default n
227 help
228 Say Y here and pass the nmi_debug command-line parameter to
229 the kernel to turn on NMI debugging. Depending on the value
230 of the nmi_debug option, various pieces of information will
231 be dumped to the console when a Non-Maskable Interrupt
232 happens.
233
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700234# FPU emulation goes here
235
236source "kernel/Kconfig.hz"
237
238config CMDLINE
239 string "Default kernel command line"
240 default ""
241 help
242 If you don't have a boot loader capable of passing a command line string
243 to the kernel, you may specify one here. As a minimum, you should specify
244 the memory size and the root device (e.g., mem=8M, root=/dev/nfs).
245
246endmenu
247
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200248menu "Power management options"
Hans-Christian Egtvedt9e58e182007-06-04 16:10:57 +0200249
Haavard Skinnemoen02a00cf2008-02-24 13:51:38 +0100250source "kernel/power/Kconfig"
251
252config ARCH_SUSPEND_POSSIBLE
253 def_bool y
254
Hans-Christian Egtvedt9e58e182007-06-04 16:10:57 +0200255menu "CPU Frequency scaling"
256
257source "drivers/cpufreq/Kconfig"
258
259config CPU_FREQ_AT32AP
260 bool "CPU frequency driver for AT32AP"
261 depends on CPU_FREQ && PLATFORM_AT32AP
262 default n
263 help
264 This enables the CPU frequency driver for AT32AP processors.
265
266 For details, take a look in <file:Documentation/cpu-freq>.
267
268 If in doubt, say N.
269
270endmenu
271
272endmenu
273
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700274menu "Bus options"
275
276config PCI
277 bool
278
279source "drivers/pci/Kconfig"
280
281source "drivers/pcmcia/Kconfig"
282
283endmenu
284
285menu "Executable file formats"
286source "fs/Kconfig.binfmt"
287endmenu
288
289source "net/Kconfig"
290
291source "drivers/Kconfig"
292
293source "fs/Kconfig"
294
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700295source "arch/avr32/Kconfig.debug"
296
297source "security/Kconfig"
298
299source "crypto/Kconfig"
300
301source "lib/Kconfig"