blob: 4bcf89148f3cec3767373776f309d47f687b8bb3 [file] [log] [blame]
Michal Simek575ca282009-03-27 14:25:50 +01001config MICROBLAZE
2 def_bool y
Yinghai Lu95f72d12010-07-12 14:36:09 +10003 select HAVE_MEMBLOCK
Michal Simekbaab8a82011-12-15 15:47:16 +01004 select HAVE_MEMBLOCK_NODE_MAP
Michal Simek2fd7c762009-11-16 09:40:14 +01005 select HAVE_FUNCTION_TRACER
Michal Simek6d9e60c2009-11-16 09:55:08 +01006 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Michal Simeka0d3e662009-11-16 10:32:10 +01007 select HAVE_FUNCTION_GRAPH_TRACER
Michal Simek7d241ff2009-12-10 14:15:44 +01008 select HAVE_DYNAMIC_FTRACE
9 select HAVE_FTRACE_MCOUNT_RECORD
Michal Simek6fa612b2009-05-11 15:49:12 +020010 select ARCH_WANT_OPTIONAL_GPIOLIB
John Williams3540ce82009-11-24 20:27:54 +100011 select HAVE_OPROFILE
Michal Simek2d5973c2010-08-03 11:45:08 +020012 select HAVE_ARCH_KGDB
Michal Simekccfe27d2010-01-14 11:21:02 +010013 select HAVE_DMA_ATTRS
14 select HAVE_DMA_API_DEBUG
John Williams3540ce82009-11-24 20:27:54 +100015 select TRACING_SUPPORT
Stephen Rothwellae5bf632010-06-29 12:42:00 +100016 select OF
Stephen Neuendorffere6ce1322010-11-18 15:54:56 -080017 select OF_EARLY_FLATTREE
Will Deaconc1d7e012012-07-30 14:42:46 -070018 select ARCH_WANT_IPC_PARSE_VERSION
Catalin Marinasb69ec422012-10-08 16:28:11 -070019 select HAVE_DEBUG_KMEMLEAK
Grant Likely2462bac2012-01-26 14:10:13 -070020 select IRQ_DOMAIN
Thomas Gleixnerb6e31622011-01-19 20:35:05 +010021 select HAVE_GENERIC_HARDIRQS
22 select GENERIC_IRQ_PROBE
Thomas Gleixner9d61c182011-03-24 14:55:52 +010023 select GENERIC_IRQ_SHOW
Michael S. Tsirkin1b34d162011-11-24 21:06:41 +020024 select GENERIC_PCI_IOMAP
Ben Hutchings9f13a1f2012-01-10 03:04:32 +000025 select GENERIC_CPU_DEVICES
Daniel Borkmanneacb6ec2012-01-19 12:37:13 +010026 select GENERIC_ATOMIC64
Anna-Maria Gleixnerd6412e22012-05-18 16:45:49 +000027 select GENERIC_CLOCKEVENTS
David Howells786d35d2012-09-28 14:31:03 +093028 select MODULES_USE_ELF_RELA
Al Viro23192952012-10-06 13:52:37 -040029 select GENERIC_KERNEL_THREAD
Al Viro99c59f62012-10-10 11:52:44 -040030 select GENERIC_KERNEL_EXECVE
Al Virof3268ed2012-10-27 00:03:41 -040031 select CLONE_BACKWARDS
Michal Simek575ca282009-03-27 14:25:50 +010032
33config SWAP
34 def_bool n
35
36config RWSEM_GENERIC_SPINLOCK
37 def_bool y
38
Michal Simek4e2e4122011-12-15 09:24:06 +010039config ZONE_DMA
40 def_bool y
41
Michal Simekbaab8a82011-12-15 15:47:16 +010042config ARCH_POPULATES_NODE_MAP
43 def_bool y
44
Michal Simek575ca282009-03-27 14:25:50 +010045config RWSEM_XCHGADD_ALGORITHM
46 bool
47
48config ARCH_HAS_ILOG2_U32
49 def_bool n
50
51config ARCH_HAS_ILOG2_U64
52 def_bool n
53
Michal Simek575ca282009-03-27 14:25:50 +010054config GENERIC_HWEIGHT
55 def_bool y
56
Michal Simek575ca282009-03-27 14:25:50 +010057config GENERIC_CALIBRATE_DELAY
58 def_bool y
59
Michal Simek6fa612b2009-05-11 15:49:12 +020060config GENERIC_GPIO
Lars-Peter Clausen59516b02012-04-09 15:05:44 +020061 bool
Michal Simek6fa612b2009-05-11 15:49:12 +020062
Remis Lima Baima14f87382009-06-18 19:55:32 +020063config GENERIC_CSUM
64 def_bool y
65
Michal Simek24b45a12009-11-10 15:57:01 +010066config STACKTRACE_SUPPORT
67 def_bool y
68
Michal Simekbf2d8092009-12-10 12:07:02 +010069config LOCKDEP_SUPPORT
70 def_bool y
71
Michal Simekfb5a32d2009-11-16 09:09:47 +010072config HAVE_LATENCYTOP_SUPPORT
73 def_bool y
74
Michal Simek575ca282009-03-27 14:25:50 +010075source "init/Kconfig"
76
77source "kernel/Kconfig.freezer"
78
79source "arch/microblaze/platform/Kconfig.platform"
80
81menu "Processor type and features"
82
Michal Simek575ca282009-03-27 14:25:50 +010083source "kernel/Kconfig.preempt"
84
85source "kernel/Kconfig.hz"
86
87config MMU
Michal Simeka116f6d2009-05-26 16:30:31 +020088 bool "MMU support"
89 default n
Michal Simek575ca282009-03-27 14:25:50 +010090
91config NO_MMU
92 bool
93 depends on !MMU
94 default y
95
96comment "Boot options"
97
98config CMDLINE_BOOL
99 bool "Default bootloader kernel arguments"
100
101config CMDLINE
102 string "Default kernel command string"
103 depends on CMDLINE_BOOL
104 default "console=ttyUL0,115200"
105 help
106 On some architectures there is currently no way for the boot loader
107 to pass arguments to the kernel. For these architectures, you should
108 supply some command-line options at build time by entering them
109 here.
110
111config CMDLINE_FORCE
112 bool "Force default kernel command string"
113 depends on CMDLINE_BOOL
114 default n
115 help
116 Set this to have arguments from the default kernel command string
117 override those passed by the boot loader.
118
Michal Simek68c6ac32010-08-06 08:50:35 +0200119config SECCOMP
120 bool "Enable seccomp to safely compute untrusted bytecode"
121 depends on PROC_FS
122 default y
123 help
124 This kernel feature is useful for number crunching applications
125 that may need to compute untrusted bytecode during their
126 execution. By using pipes or other transports made available to
127 the process as file descriptors supporting the read/write
128 syscalls, it's possible to isolate those applications in
129 their own address space using seccomp. Once seccomp is
130 enabled via /proc/<pid>/seccomp, it cannot be disabled
131 and the task is only allowed to execute a few safe syscalls
132 defined by each seccomp mode.
133
134 If unsure, say Y. Only embedded should say N here.
135
Michal Simek575ca282009-03-27 14:25:50 +0100136endmenu
137
Michal Simeka116f6d2009-05-26 16:30:31 +0200138menu "Advanced setup"
139
140config ADVANCED_OPTIONS
141 bool "Prompt for advanced kernel configuration options"
Michal Simeka116f6d2009-05-26 16:30:31 +0200142 help
143 This option will enable prompting for a variety of advanced kernel
144 configuration options. These options can cause the kernel to not
145 work if they are set incorrectly, but can be used to optimize certain
146 aspects of kernel memory management.
147
148 Unless you know what you are doing, say N here.
149
150comment "Default settings for advanced configuration options are used"
151 depends on !ADVANCED_OPTIONS
152
Michal Simek3a0d7a42010-02-22 12:16:08 +0100153config XILINX_UNCACHED_SHADOW
154 bool "Are you using uncached shadow for RAM ?"
155 depends on ADVANCED_OPTIONS && !MMU
156 default n
157 help
158 This is needed to be able to allocate uncachable memory regions.
159 The feature requires the design to define the RAM memory controller
160 window to be twice as large as the actual physical memory.
161
Michal Simek2f2f3712011-12-15 15:02:37 +0100162config HIGHMEM
163 bool "High memory support"
Michal Simeka116f6d2009-05-26 16:30:31 +0200164 depends on MMU
Michal Simek2f2f3712011-12-15 15:02:37 +0100165 help
166 The address space of Microblaze processors is only 4 Gigabytes large
167 and it has to accommodate user address space, kernel address
168 space as well as some memory mapped IO. That means that, if you
169 have a large amount of physical memory and/or IO, not all of the
170 memory can be "permanently mapped" by the kernel. The physical
171 memory that is not permanently mapped is called "high memory".
172
173 If unsure, say n.
Michal Simeka116f6d2009-05-26 16:30:31 +0200174
175config LOWMEM_SIZE_BOOL
176 bool "Set maximum low memory"
Michal Simekb8a84052010-02-22 11:33:07 +0100177 depends on ADVANCED_OPTIONS && MMU
Michal Simeka116f6d2009-05-26 16:30:31 +0200178 help
179 This option allows you to set the maximum amount of memory which
180 will be used as "low memory", that is, memory which the kernel can
181 access directly, without having to set up a kernel virtual mapping.
182 This can be useful in optimizing the layout of kernel virtual
183 memory.
184
185 Say N here unless you know what you are doing.
186
187config LOWMEM_SIZE
188 hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
Michal Simeka116f6d2009-05-26 16:30:31 +0200189 default "0x30000000"
190
Michal Simek0b9b0202010-11-08 12:37:40 +0100191config MANUAL_RESET_VECTOR
192 hex "Microblaze reset vector address setup"
193 default "0x0"
194 help
195 Set this option to have the kernel override the CPU Reset vector.
196 If zero, no change will be made to the MicroBlaze reset vector at
197 address 0x0.
198 If non-zero, a jump instruction to this address, will be written
199 to the reset vector at address 0x0.
200 If you are unsure, set it to default value 0x0.
201
Michal Simeka116f6d2009-05-26 16:30:31 +0200202config KERNEL_START_BOOL
203 bool "Set custom kernel base address"
204 depends on ADVANCED_OPTIONS
205 help
206 This option allows you to set the kernel virtual address at which
207 the kernel will map low memory (the kernel image will be linked at
208 this address). This can be useful in optimizing the virtual memory
209 layout of the system.
210
211 Say N here unless you know what you are doing.
212
213config KERNEL_START
214 hex "Virtual address of kernel base" if KERNEL_START_BOOL
215 default "0xc0000000" if MMU
216 default KERNEL_BASE_ADDR if !MMU
217
218config TASK_SIZE_BOOL
219 bool "Set custom user task size"
Michal Simekb8a84052010-02-22 11:33:07 +0100220 depends on ADVANCED_OPTIONS && MMU
Michal Simeka116f6d2009-05-26 16:30:31 +0200221 help
222 This option allows you to set the amount of virtual address space
223 allocated to user tasks. This can be useful in optimizing the
224 virtual memory layout of the system.
225
226 Say N here unless you know what you are doing.
227
228config TASK_SIZE
229 hex "Size of user task space" if TASK_SIZE_BOOL
Michal Simeka116f6d2009-05-26 16:30:31 +0200230 default "0x80000000"
231
Steven J. Magnaniba9c4f82010-05-13 10:48:27 -0500232choice
233 prompt "Page size"
234 default MICROBLAZE_4K_PAGES
235 depends on ADVANCED_OPTIONS && !MMU
236 help
237 Select the kernel logical page size. Increasing the page size
238 will reduce software overhead at each page boundary, allow
239 hardware prefetch mechanisms to be more effective, and allow
240 larger dma transfers increasing IO efficiency and reducing
241 overhead. However the utilization of memory will increase.
242 For example, each cached file will using a multiple of the
243 page size to hold its contents and the difference between the
244 end of file and the end of page is wasted.
245
246 If unsure, choose 4K_PAGES.
247
248config MICROBLAZE_4K_PAGES
249 bool "4k page size"
250
Steven J. Magnaniba9c4f82010-05-13 10:48:27 -0500251config MICROBLAZE_16K_PAGES
252 bool "16k page size"
253
Michal Simek6e80cff2012-08-01 10:29:28 +0200254config MICROBLAZE_64K_PAGES
255 bool "64k page size"
Steven J. Magnaniba9c4f82010-05-13 10:48:27 -0500256
257endchoice
258
Michal Simek95b0f9e2010-02-08 16:41:38 +0100259config KERNEL_PAD
260 hex "Kernel PAD for unpacking" if ADVANCED_OPTIONS
261 default "0x80000" if MMU
262
Michal Simeka116f6d2009-05-26 16:30:31 +0200263endmenu
264
Michal Simek575ca282009-03-27 14:25:50 +0100265source "mm/Kconfig"
266
Tobias Klauser910672d2011-03-02 18:38:35 +0100267menu "Executable file formats"
Michal Simek575ca282009-03-27 14:25:50 +0100268
269source "fs/Kconfig.binfmt"
270
271endmenu
272
Michal Simeka6475c12010-01-18 15:27:10 +0100273menu "Bus Options"
274
275config PCI
276 bool "PCI support"
277
278config PCI_DOMAINS
279 def_bool PCI
280
281config PCI_SYSCALL
282 def_bool PCI
283
Michal Simek733cc212010-01-18 15:27:11 +0100284config PCI_XILINX
285 bool "Xilinx PCI host bridge support"
286 depends on PCI
287
Michal Simeka6475c12010-01-18 15:27:10 +0100288source "drivers/pci/Kconfig"
289
290endmenu
291
Michal Simek575ca282009-03-27 14:25:50 +0100292source "net/Kconfig"
293
294source "drivers/Kconfig"
295
296source "fs/Kconfig"
297
298source "arch/microblaze/Kconfig.debug"
299
300source "security/Kconfig"
301
302source "crypto/Kconfig"
303
304source "lib/Kconfig"