blob: 859b2de4a624a665e13f16fe36908e7453b20146 [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
Huang Yingdf013ff2011-07-13 13:14:22 +080015 select ARCH_HAVE_NMI_SAFE_CMPXCHG
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070016 help
17 AVR32 is a high-performance 32-bit RISC microprocessor core,
18 designed for cost-sensitive embedded applications, with particular
19 emphasis on low power consumption and high code density.
20
21 There is an AVR32 Linux project with a web page at
22 http://avr32linux.org/.
23
David Brownell0a938b92007-03-05 00:30:18 -080024config GENERIC_GPIO
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010025 def_bool y
David Brownell0a938b92007-03-05 00:30:18 -080026
Haavard Skinnemoen2f026032007-11-23 20:01:59 +010027config STACKTRACE_SUPPORT
28 def_bool y
29
Haavard Skinnemoen320516b2007-11-26 14:34:57 +010030config LOCKDEP_SUPPORT
31 def_bool y
32
33config TRACE_IRQFLAGS_SUPPORT
34 def_bool y
35
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070036config RWSEM_GENERIC_SPINLOCK
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010037 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070038
David Brownelle723ff62008-02-14 11:24:02 -080039config GENERIC_CLOCKEVENTS
40 def_bool y
41
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070042config RWSEM_XCHGADD_ALGORITHM
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010043 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070044
David Howellsf0d1b0b2006-12-08 02:37:49 -080045config ARCH_HAS_ILOG2_U32
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010046 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080047
48config ARCH_HAS_ILOG2_U64
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010049 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -080050
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070051config GENERIC_HWEIGHT
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010052 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070053
54config GENERIC_CALIBRATE_DELAY
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010055 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070056
Haavard Skinnemoen623b0352007-03-13 17:59:11 +010057config GENERIC_BUG
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +010058 def_bool y
Haavard Skinnemoen623b0352007-03-13 17:59:11 +010059 depends on BUG
60
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070061source "init/Kconfig"
62
Matt Helsleydc52ddc2008-10-18 20:27:21 -070063source "kernel/Kconfig.freezer"
64
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070065menu "System Type and features"
66
David Brownelle723ff62008-02-14 11:24:02 -080067source "kernel/time/Kconfig"
68
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070069config SUBARCH_AVR32B
70 bool
71config MMU
72 bool
73config PERFORMANCE_COUNTERS
74 bool
75
76config PLATFORM_AT32AP
77 bool
78 select SUBARCH_AVR32B
79 select MMU
80 select PERFORMANCE_COUNTERS
Michael Buesch7444a722008-07-25 01:46:11 -070081 select ARCH_REQUIRE_GPIOLIB
Haavard Skinnemoenb83d6ee12008-03-05 10:00:28 +010082 select GENERIC_ALLOCATOR
Nicolas Ferre0912e532009-06-23 16:30:56 +020083 select HAVE_FB_ATMEL
Jean-Christophe PLAGNIOL-VILLARDee621dd2010-08-08 06:21:33 +020084 select HAVE_NET_MACB
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070085
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +010086#
87# CPU types
88#
89
90# AP7000 derivatives
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010091config CPU_AT32AP700X
92 bool
93 select PLATFORM_AT32AP
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -070094config CPU_AT32AP7000
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +010095 bool
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010096 select CPU_AT32AP700X
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010097config CPU_AT32AP7001
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +010098 bool
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +010099 select CPU_AT32AP700X
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100100config CPU_AT32AP7002
Haavard Skinnemoene8897bf2007-11-29 11:15:15 +0100101 bool
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100102 select CPU_AT32AP700X
103
Hans-Christian Egtvedt3550b932009-12-03 14:58:20 +0100104# AP700X boards
105config BOARD_ATNGW100_COMMON
106 bool
107 select CPU_AT32AP7000
108
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700109choice
110 prompt "AVR32 board type"
111 default BOARD_ATSTK1000
112
113config BOARD_ATSTK1000
114 bool "ATSTK1000 evaluation board"
Haavard Skinnemoen9ca20a82007-04-12 17:26:57 +0200115
Hans-Christian Egtvedt3550b932009-12-03 14:58:20 +0100116config BOARD_ATNGW100_MKI
Haavard Skinnemoen9ca20a82007-04-12 17:26:57 +0200117 bool "ATNGW100 Network Gateway"
Hans-Christian Egtvedt3550b932009-12-03 14:58:20 +0100118 select BOARD_ATNGW100_COMMON
119
120config BOARD_ATNGW100_MKII
121 bool "ATNGW100 mkII Network Gateway"
122 select BOARD_ATNGW100_COMMON
Hans-Christian Egtvedt45c349b2008-07-29 09:25:37 +0000123
Alex Raimondidd5e1332008-12-09 16:17:13 +0100124config BOARD_HAMMERHEAD
125 bool "Hammerhead board"
126 select CPU_AT32AP7000
127 select USB_ARCH_HAS_HCD
128 help
Matt LaPlante692105b2009-01-26 11:12:25 +0100129 The Hammerhead platform is built around an AVR32 32-bit microcontroller from Atmel.
Alex Raimondidd5e1332008-12-09 16:17:13 +0100130 It offers versatile peripherals, such as ethernet, usb device, usb host etc.
131
Matt LaPlante692105b2009-01-26 11:12:25 +0100132 The board also incorporates a power supply and is a Power over Ethernet (PoE) Powered
Alex Raimondidd5e1332008-12-09 16:17:13 +0100133 Device (PD).
134
Matt LaPlante692105b2009-01-26 11:12:25 +0100135 Additionally, a Cyclone III FPGA from Altera is integrated on the board. The FPGA is
Alex Raimondidd5e1332008-12-09 16:17:13 +0100136 mapped into the 32-bit AVR memory bus. The FPGA offers two DDR2 SDRAM interfaces, which
137 will cover even the most exceptional need of memory bandwidth. Together with the onboard
138 video decoder the board is ready for video processing.
139
Justin P. Mattock50a23e62010-10-16 10:36:23 -0700140 For more information see: http://www.miromico.ch/index.php/hammerhead.html
Alex Raimondidd5e1332008-12-09 16:17:13 +0100141
Hans-Christian Egtvedt45c349b2008-07-29 09:25:37 +0000142config BOARD_FAVR_32
143 bool "Favr-32 LCD-board"
144 select CPU_AT32AP7000
Mark Jackson5b50c162008-10-13 13:14:50 +0000145
Jonas Larssona16fffdd2009-03-27 10:18:14 +0100146config BOARD_MERISC
147 bool "Merisc board"
148 select CPU_AT32AP7000
149 help
150 Merisc is the family name for a range of AVR32-based boards.
151
152 The boards are designed to be used in a man-machine
153 interfacing environment, utilizing a touch-based graphical
154 user interface. They host a vast range of I/O peripherals as
155 well as a large SDRAM & Flash memory bank.
156
157 For more information see: http://www.martinsson.se/merisc
158
Mark Jackson5b50c162008-10-13 13:14:50 +0000159config BOARD_MIMC200
160 bool "MIMC200 CPU board"
161 select CPU_AT32AP7000
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700162endchoice
163
David Brownella8e93ed2007-06-12 14:34:47 +0200164source "arch/avr32/boards/atstk1000/Kconfig"
Hans-Christian Egtvedta3bee422008-07-01 08:29:27 +0000165source "arch/avr32/boards/atngw100/Kconfig"
Alex Raimondidd5e1332008-12-09 16:17:13 +0100166source "arch/avr32/boards/hammerhead/Kconfig"
Hans-Christian Egtvedt45c349b2008-07-29 09:25:37 +0000167source "arch/avr32/boards/favr-32/Kconfig"
Jonas Larssona16fffdd2009-03-27 10:18:14 +0100168source "arch/avr32/boards/merisc/Kconfig"
David Brownella8e93ed2007-06-12 14:34:47 +0200169
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700170choice
171 prompt "Boot loader type"
172 default LOADER_U_BOOT
173
174config LOADER_U_BOOT
175 bool "U-Boot (or similar) bootloader"
176endchoice
177
Haavard Skinnemoen228e8452007-03-07 15:24:34 +0100178source "arch/avr32/mach-at32ap/Kconfig"
179
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700180config LOAD_ADDRESS
181 hex
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100182 default 0x10000000 if LOADER_U_BOOT=y && CPU_AT32AP700X=y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700183
184config ENTRY_ADDRESS
185 hex
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100186 default 0x90000000 if LOADER_U_BOOT=y && CPU_AT32AP700X=y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700187
188config PHYS_OFFSET
189 hex
Haavard Skinnemoen438ff3f2007-10-29 15:28:07 +0100190 default 0x10000000 if CPU_AT32AP700X=y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700191
192source "kernel/Kconfig.preempt"
193
Haavard Skinnemoen5a4d5292008-01-14 23:33:44 +0100194config QUICKLIST
195 def_bool y
196
Tejun Heoc1329372009-02-24 11:57:20 +0900197config HAVE_ARCH_BOOTMEM
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100198 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700199
200config ARCH_HAVE_MEMORY_PRESENT
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100201 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700202
203config NEED_NODE_MEMMAP_SIZE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100204 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700205
206config ARCH_FLATMEM_ENABLE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100207 def_bool y
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700208
209config ARCH_DISCONTIGMEM_ENABLE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100210 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700211
212config ARCH_SPARSEMEM_ENABLE
Haavard Skinnemoen58bd2bf2007-11-23 19:25:00 +0100213 def_bool n
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700214
215source "mm/Kconfig"
216
217config OWNERSHIP_TRACE
218 bool "Ownership trace support"
219 default y
220 help
221 Say Y to generate an Ownership Trace message on every context switch,
222 enabling Nexus-compliant debuggers to keep track of the PID of the
223 currently executing task.
224
Haavard Skinnemoene7ba1762007-10-10 14:58:29 +0200225config NMI_DEBUGGING
226 bool "NMI Debugging"
227 default n
228 help
229 Say Y here and pass the nmi_debug command-line parameter to
230 the kernel to turn on NMI debugging. Depending on the value
231 of the nmi_debug option, various pieces of information will
232 be dumped to the console when a Non-Maskable Interrupt
233 happens.
234
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700235# FPU emulation goes here
236
237source "kernel/Kconfig.hz"
238
239config CMDLINE
240 string "Default kernel command line"
241 default ""
242 help
243 If you don't have a boot loader capable of passing a command line string
244 to the kernel, you may specify one here. As a minimum, you should specify
245 the memory size and the root device (e.g., mem=8M, root=/dev/nfs).
246
247endmenu
248
Matt LaPlante01dd2fb2007-10-20 01:34:40 +0200249menu "Power management options"
Hans-Christian Egtvedt9e58e182007-06-04 16:10:57 +0200250
Haavard Skinnemoen02a00cf2008-02-24 13:51:38 +0100251source "kernel/power/Kconfig"
252
253config ARCH_SUSPEND_POSSIBLE
254 def_bool y
255
Hans-Christian Egtvedt9e58e182007-06-04 16:10:57 +0200256menu "CPU Frequency scaling"
257
258source "drivers/cpufreq/Kconfig"
259
260config CPU_FREQ_AT32AP
261 bool "CPU frequency driver for AT32AP"
262 depends on CPU_FREQ && PLATFORM_AT32AP
263 default n
264 help
265 This enables the CPU frequency driver for AT32AP processors.
266
267 For details, take a look in <file:Documentation/cpu-freq>.
268
269 If in doubt, say N.
270
271endmenu
272
273endmenu
274
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700275menu "Bus options"
276
277config PCI
278 bool
279
280source "drivers/pci/Kconfig"
281
282source "drivers/pcmcia/Kconfig"
283
284endmenu
285
286menu "Executable file formats"
287source "fs/Kconfig.binfmt"
288endmenu
289
290source "net/Kconfig"
291
292source "drivers/Kconfig"
293
294source "fs/Kconfig"
295
Haavard Skinnemoen5f97f7f2006-09-25 23:32:13 -0700296source "arch/avr32/Kconfig.debug"
297
298source "security/Kconfig"
299
300source "crypto/Kconfig"
301
302source "lib/Kconfig"