blob: 2fe8812f78de50bbd841d07587cd549bff84294a [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001config SUPERH
Paul Mundtea0e1a92007-11-21 15:58:01 +09002 def_bool y
Paul Mundt7a440c92006-09-27 18:18:31 +09003 select EMBEDDED
David Brownell9483a572008-07-23 21:26:48 -07004 select HAVE_CLK
Paul Mundt86e4dd52010-05-25 20:06:13 +09005 select HAVE_IDE if HAS_IOPORT
Yinghai Lu95f72d12010-07-12 14:36:09 +10006 select HAVE_MEMBLOCK
Mathieu Desnoyers42d4b832008-02-02 15:10:34 -05007 select HAVE_OPROFILE
Dmitry Baryshkov9de90ac2008-07-18 13:30:31 +04008 select HAVE_GENERIC_DMA_COHERENT
Paul Mundtd7b01f72008-12-10 20:17:15 +09009 select HAVE_ARCH_TRACEHOOK
Paul Mundtf802d962009-04-09 10:36:54 -070010 select HAVE_DMA_API_DEBUG
Paul Mundt73c926b2009-10-20 12:55:56 +090011 select HAVE_DMA_ATTRS
Peter Zijlstrae360adb2010-10-14 14:01:34 +080012 select HAVE_IRQ_WORK
Ingo Molnarcdd6c482009-09-21 12:02:48 +020013 select HAVE_PERF_EVENTS
Paul Mundt72f0c132009-10-27 17:08:55 +090014 select PERF_USE_VMALLOC
Paul Mundtdf8ce252009-07-12 01:37:30 +090015 select HAVE_KERNEL_GZIP
Paul Mundt07e88e12009-07-11 13:21:19 -040016 select HAVE_KERNEL_BZIP2
17 select HAVE_KERNEL_LZMA
Paul Mundtc7b16ef2010-01-13 13:29:19 +090018 select HAVE_KERNEL_LZO
Paul Mundta74f7e02009-09-16 14:30:34 +090019 select HAVE_SYSCALL_TRACEPOINTS
Paul Mundteaaaeef2010-06-14 15:16:53 +090020 select HAVE_REGS_AND_STACK_ACCESS_API
Paul Mundt57b81332010-10-26 15:20:51 +090021 select HAVE_GENERIC_HARDIRQS
22 select HAVE_SPARSE_IRQ
Paul Mundt6eac1af2009-05-08 19:48:47 +090023 select RTC_LIB
Paul Mundtf01789c2009-06-17 10:43:13 +090024 select GENERIC_ATOMIC64
Paul Mundt1e5cefd2010-10-27 15:44:19 +090025 select GENERIC_HARDIRQS_NO_DEPRECATED
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 help
27 The SuperH is a RISC processor targeted for use in embedded systems
28 and consumer electronics; it was also used in the Sega Dreamcast
29 gaming console. The SuperH port has a home page at
30 <http://www.linux-sh.org/>.
31
Paul Mundt39d28a22007-11-08 18:39:33 +090032config SUPERH32
Paul Mundt3cc000b2009-04-11 08:39:27 +090033 def_bool ARCH = "sh"
Chris Smithd39f5452008-09-05 17:15:39 +090034 select HAVE_KPROBES
35 select HAVE_KRETPROBES
Paul Mundt6d63e732010-01-19 14:00:14 +090036 select HAVE_IOREMAP_PROT if MMU && !X2TLB
Paul Mundt694f94f2008-10-31 16:20:36 +090037 select HAVE_FUNCTION_TRACER
Matt Flemingfad57fe2008-11-12 20:11:47 +090038 select HAVE_FTRACE_MCOUNT_RECORD
39 select HAVE_DYNAMIC_FTRACE
Matt Flemingc1340c02009-06-28 14:05:44 +010040 select HAVE_FUNCTION_TRACE_MCOUNT_TEST
Paul Mundte4b053d2009-10-13 16:52:50 +090041 select HAVE_FTRACE_NMI_ENTER if DYNAMIC_FTRACE
Matt Fleming327933f2009-07-11 00:29:03 +000042 select HAVE_FUNCTION_GRAPH_TRACER
Paul Mundtab6e5702008-12-11 18:46:46 +090043 select HAVE_ARCH_KGDB
Paul Mundt6fbfe8d2010-01-06 15:46:53 +090044 select HAVE_HW_BREAKPOINT
Frederic Weisbecker01027522010-04-11 18:55:56 +020045 select HAVE_MIXED_BREAKPOINTS_REGS
Sam Ravnborge583d6b2010-08-14 12:23:39 +000046 select PERF_EVENTS
Paul Mundt8dafc342009-04-02 11:56:38 +090047 select ARCH_HIBERNATION_POSSIBLE if MMU
Paul Mundt57b81332010-10-26 15:20:51 +090048 select SPARSE_IRQ
Paul Mundtea0e1a92007-11-21 15:58:01 +090049
50config SUPERH64
Paul Mundt3cc000b2009-04-11 08:39:27 +090051 def_bool ARCH = "sh64"
Paul Mundt39d28a22007-11-08 18:39:33 +090052
Paul Mundtf42b7e32008-07-29 20:12:51 +090053config ARCH_DEFCONFIG
54 string
55 default "arch/sh/configs/shx3_defconfig" if SUPERH32
56 default "arch/sh/configs/cayman_defconfig" if SUPERH64
57
Linus Torvalds1da177e2005-04-16 15:20:36 -070058config RWSEM_GENERIC_SPINLOCK
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090059 def_bool y
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
61config RWSEM_XCHGADD_ALGORITHM
62 bool
63
Paul Mundtfa691512007-03-08 19:41:21 +090064config GENERIC_BUG
65 def_bool y
Paul Mundta82d53e2007-11-21 18:22:05 +090066 depends on BUG && SUPERH32
Paul Mundtfa691512007-03-08 19:41:21 +090067
Paul Mundt3767f3f2009-06-15 00:00:42 +090068config GENERIC_CSUM
69 def_bool y
70 depends on SUPERH64
71
Akinobu Mitae2268c72006-03-26 01:39:35 -080072config GENERIC_FIND_NEXT_BIT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090073 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080074
75config GENERIC_HWEIGHT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +090076 def_bool y
Akinobu Mitae2268c72006-03-26 01:39:35 -080077
Paul Mundt2eb2a432009-06-19 16:00:00 +090078config IRQ_PER_CPU
79 def_bool y
80
Magnus Damm2967dab2008-10-08 20:41:43 +090081config GENERIC_GPIO
82 def_bool n
83
Linus Torvalds1da177e2005-04-16 15:20:36 -070084config GENERIC_CALIBRATE_DELAY
Paul Mundtcf204fa2008-09-08 20:47:42 +090085 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -070086
Paul Mundtcad82442006-01-16 22:14:19 -080087config GENERIC_IOMAP
88 bool
89
Paul Mundt57be2b42007-05-09 17:33:24 +090090config GENERIC_CLOCKEVENTS
Paul Mundt938edae2009-05-03 18:12:26 +090091 def_bool y
Paul Mundt57be2b42007-05-09 17:33:24 +090092
Paul Mundt8c245942008-08-06 18:37:07 +090093config GENERIC_CLOCKEVENTS_BROADCAST
94 bool
95
Paul Mundt6d134b92009-05-08 16:36:13 +090096config GENERIC_CMOS_UPDATE
97 def_bool y
98 depends on SH_SH03 || SH_DREAMCAST
99
Paul Mundtbdcab872008-08-04 14:09:15 +0900100config GENERIC_LOCKBREAK
101 def_bool y
102 depends on SMP && PREEMPT
103
Paul Mundt357d5942007-06-11 15:32:07 +0900104config SYS_SUPPORTS_PM
105 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900106 depends on !SMP
107
108config ARCH_SUSPEND_POSSIBLE
109 def_bool n
110
111config ARCH_HIBERNATION_POSSIBLE
112 def_bool n
Paul Mundt357d5942007-06-11 15:32:07 +0900113
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900114config SYS_SUPPORTS_APM_EMULATION
115 bool
Magnus Dammaf998a92008-12-04 22:45:12 +0900116 select ARCH_SUSPEND_POSSIBLE
Paul Mundt357d5942007-06-11 15:32:07 +0900117
Paul Mundtffb4a732009-10-27 07:22:37 +0900118config SYS_SUPPORTS_HUGETLBFS
119 bool
120
Paul Mundt357d5942007-06-11 15:32:07 +0900121config SYS_SUPPORTS_SMP
122 bool
123
124config SYS_SUPPORTS_NUMA
125 bool
126
127config SYS_SUPPORTS_PCI
128 bool
Paul Mundt0a9b0db2007-01-24 21:56:20 +0900129
Paul Mundtf5ad8812009-01-29 18:08:58 +0900130config SYS_SUPPORTS_CMT
131 bool
132
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000133config SYS_SUPPORTS_MTU2
134 bool
135
Magnus Damm9570ef22009-05-01 06:51:00 +0000136config SYS_SUPPORTS_TMU
137 bool
138
Paul Mundtafbfb522006-12-04 18:17:28 +0900139config STACKTRACE_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900140 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900141
142config LOCKDEP_SUPPORT
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900143 def_bool y
Paul Mundtafbfb522006-12-04 18:17:28 +0900144
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900145config HAVE_LATENCYTOP_SUPPORT
146 def_bool y
Paul Mundt5a89f1a2008-09-13 01:44:03 +0900147
David Howellsf0d1b0b2006-12-08 02:37:49 -0800148config ARCH_HAS_ILOG2_U32
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900149 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800150
151config ARCH_HAS_ILOG2_U64
Harvey Harrisond7ef4fb2007-12-11 13:49:35 +0900152 def_bool n
David Howellsf0d1b0b2006-12-08 02:37:49 -0800153
Paul Mundte257ad02007-07-25 11:18:00 +0900154config ARCH_NO_VIRT_TO_BUS
155 def_bool y
156
Paul Mundte869a902009-04-02 13:08:31 +0900157config ARCH_HAS_DEFAULT_IDLE
158 def_bool y
159
Paul Mundt2e046b92009-06-19 14:40:51 +0900160config ARCH_HAS_CPU_IDLE_WAIT
161 def_bool y
162
Paul Mundt86e4dd52010-05-25 20:06:13 +0900163config NO_IOPORT
164 bool
165
Magnus Damme7cc9a72008-02-07 20:18:21 +0900166config IO_TRAPPED
167 bool
168
Paul Mundt01be5d62009-10-27 10:35:02 +0900169config DMA_COHERENT
170 bool
171
172config DMA_NONCOHERENT
173 def_bool !DMA_COHERENT
174
FUJITA Tomonori5cabbb62010-03-10 15:23:27 -0800175config NEED_DMA_MAP_STATE
176 def_bool DMA_NONCOHERENT
177
FUJITA Tomonori18e98302010-05-26 14:44:32 -0700178config NEED_SG_DMA_LENGTH
179 def_bool y
180
Linus Torvalds1da177e2005-04-16 15:20:36 -0700181source "init/Kconfig"
182
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700183source "kernel/Kconfig.freezer"
184
Linus Torvalds1da177e2005-04-16 15:20:36 -0700185menu "System type"
186
Paul Mundtb5f42db2007-11-08 18:38:14 +0900187#
188# Processor families
189#
190config CPU_SH2
191 bool
192
193config CPU_SH2A
194 bool
195 select CPU_SH2
Paul Mundte2fcf742010-11-04 12:32:24 +0900196 select UNCACHED_MAPPING
Paul Mundtb5f42db2007-11-08 18:38:14 +0900197
198config CPU_SH3
199 bool
200 select CPU_HAS_INTEVT
201 select CPU_HAS_SR_RB
Paul Mundt4fa48e12009-05-08 15:28:15 +0900202 select SYS_SUPPORTS_TMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900203
204config CPU_SH4
205 bool
206 select CPU_HAS_INTEVT
207 select CPU_HAS_SR_RB
Paul Mundtb5f42db2007-11-08 18:38:14 +0900208 select CPU_HAS_FPU if !CPU_SH4AL_DSP
Paul Mundt4fa48e12009-05-08 15:28:15 +0900209 select SYS_SUPPORTS_TMU
Paul Mundtffb4a732009-10-27 07:22:37 +0900210 select SYS_SUPPORTS_HUGETLBFS if MMU
Paul Mundtb5f42db2007-11-08 18:38:14 +0900211
212config CPU_SH4A
213 bool
214 select CPU_SH4
215
216config CPU_SH4AL_DSP
217 bool
218 select CPU_SH4A
219 select CPU_HAS_DSP
220
Paul Mundtea0e1a92007-11-21 15:58:01 +0900221config CPU_SH5
222 bool
223 select CPU_HAS_FPU
Paul Mundtadd47062009-05-08 16:12:17 +0900224 select SYS_SUPPORTS_TMU
Paul Mundtffb4a732009-10-27 07:22:37 +0900225 select SYS_SUPPORTS_HUGETLBFS if MMU
Paul Mundtea0e1a92007-11-21 15:58:01 +0900226
Paul Mundtb5f42db2007-11-08 18:38:14 +0900227config CPU_SHX2
228 bool
229
230config CPU_SHX3
231 bool
Paul Mundt01be5d62009-10-27 10:35:02 +0900232 select DMA_COHERENT
Paul Mundt4b478ee2010-05-11 15:24:04 +0900233 select SYS_SUPPORTS_SMP
234 select SYS_SUPPORTS_NUMA
Paul Mundtb5f42db2007-11-08 18:38:14 +0900235
Paul Mundtdc65a972009-03-10 16:26:29 +0900236config ARCH_SHMOBILE
237 bool
Magnus Damm77594912009-03-13 15:23:04 +0000238 select ARCH_SUSPEND_POSSIBLE
Magnus Dammac2c5962009-08-19 10:31:53 +0000239 select PM
240 select PM_RUNTIME
Paul Mundtdc65a972009-03-10 16:26:29 +0900241
Matt Fleming86c8c042010-09-10 20:36:23 +0100242config CPU_HAS_PMU
243 depends on CPU_SH4 || CPU_SH4A
244 default y
245 bool
246
Paul Mundt3cc000b2009-04-11 08:39:27 +0900247if SUPERH32
248
Paul Mundtb5f42db2007-11-08 18:38:14 +0900249choice
250 prompt "Processor sub-type selection"
251
252#
253# Processor subtypes
254#
255
256# SH-2 Processor Support
257
258config CPU_SUBTYPE_SH7619
259 bool "Support SH7619 processor"
260 select CPU_SH2
Paul Mundtf5ad8812009-01-29 18:08:58 +0900261 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900262
263# SH-2A Processor Support
264
Peter Griffin28259992008-11-28 22:48:20 +0900265config CPU_SUBTYPE_SH7201
266 bool "Support SH7201 processor"
267 select CPU_SH2A
268 select CPU_HAS_FPU
Magnus Dammda107c62009-04-30 07:06:26 +0000269 select SYS_SUPPORTS_MTU2
Peter Griffin28259992008-11-28 22:48:20 +0900270
Paul Mundt6d01f512007-11-26 18:17:21 +0900271config CPU_SUBTYPE_SH7203
272 bool "Support SH7203 processor"
273 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900274 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900275 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000276 select SYS_SUPPORTS_MTU2
Paul Mundt6d01f512007-11-26 18:17:21 +0900277
Paul Mundtb5f42db2007-11-08 18:38:14 +0900278config CPU_SUBTYPE_SH7206
279 bool "Support SH7206 processor"
280 select CPU_SH2A
Paul Mundtf5ad8812009-01-29 18:08:58 +0900281 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000282 select SYS_SUPPORTS_MTU2
Paul Mundtb5f42db2007-11-08 18:38:14 +0900283
Paul Mundta8f67f42007-11-26 19:54:02 +0900284config CPU_SUBTYPE_SH7263
285 bool "Support SH7263 processor"
286 select CPU_SH2A
Paul Mundt74d99a52007-11-26 20:38:36 +0900287 select CPU_HAS_FPU
Paul Mundtf5ad8812009-01-29 18:08:58 +0900288 select SYS_SUPPORTS_CMT
Magnus Dammda107c62009-04-30 07:06:26 +0000289 select SYS_SUPPORTS_MTU2
Paul Mundta8f67f42007-11-26 19:54:02 +0900290
Paul Mundt2ad69902008-03-13 12:52:44 +0900291config CPU_SUBTYPE_MXG
292 bool "Support MX-G processor"
293 select CPU_SH2A
Magnus Dammda107c62009-04-30 07:06:26 +0000294 select SYS_SUPPORTS_MTU2
Paul Mundt2ad69902008-03-13 12:52:44 +0900295 help
296 Select MX-G if running on an R8A03022BG part.
297
Paul Mundtb5f42db2007-11-08 18:38:14 +0900298# SH-3 Processor Support
299
300config CPU_SUBTYPE_SH7705
301 bool "Support SH7705 processor"
302 select CPU_SH3
303
304config CPU_SUBTYPE_SH7706
305 bool "Support SH7706 processor"
306 select CPU_SH3
307 help
308 Select SH7706 if you have a 133 Mhz SH-3 HD6417706 CPU.
309
310config CPU_SUBTYPE_SH7707
311 bool "Support SH7707 processor"
312 select CPU_SH3
313 help
314 Select SH7707 if you have a 60 Mhz SH-3 HD6417707 CPU.
315
316config CPU_SUBTYPE_SH7708
317 bool "Support SH7708 processor"
318 select CPU_SH3
319 help
320 Select SH7708 if you have a 60 Mhz SH-3 HD6417708S or
321 if you have a 100 Mhz SH-3 HD6417708R CPU.
322
323config CPU_SUBTYPE_SH7709
324 bool "Support SH7709 processor"
325 select CPU_SH3
326 help
327 Select SH7709 if you have a 80 Mhz SH-3 HD6417709 CPU.
328
329config CPU_SUBTYPE_SH7710
330 bool "Support SH7710 processor"
331 select CPU_SH3
332 select CPU_HAS_DSP
333 help
334 Select SH7710 if you have a SH3-DSP SH7710 CPU.
335
336config CPU_SUBTYPE_SH7712
337 bool "Support SH7712 processor"
338 select CPU_SH3
339 select CPU_HAS_DSP
340 help
341 Select SH7712 if you have a SH3-DSP SH7712 CPU.
342
343config CPU_SUBTYPE_SH7720
344 bool "Support SH7720 processor"
345 select CPU_SH3
346 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000347 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900348 help
349 Select SH7720 if you have a SH3-DSP SH7720 CPU.
350
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900351config CPU_SUBTYPE_SH7721
352 bool "Support SH7721 processor"
353 select CPU_SH3
354 select CPU_HAS_DSP
Magnus Damm2b23a882009-05-12 10:21:11 +0000355 select SYS_SUPPORTS_CMT
Yoshihiro Shimoda31a49c42007-12-26 11:45:06 +0900356 help
357 Select SH7721 if you have a SH3-DSP SH7721 CPU.
358
Paul Mundtb5f42db2007-11-08 18:38:14 +0900359# SH-4 Processor Support
360
361config CPU_SUBTYPE_SH7750
362 bool "Support SH7750 processor"
363 select CPU_SH4
364 help
365 Select SH7750 if you have a 200 Mhz SH-4 HD6417750 CPU.
366
367config CPU_SUBTYPE_SH7091
368 bool "Support SH7091 processor"
369 select CPU_SH4
370 help
371 Select SH7091 if you have an SH-4 based Sega device (such as
372 the Dreamcast, Naomi, and Naomi 2).
373
374config CPU_SUBTYPE_SH7750R
375 bool "Support SH7750R processor"
376 select CPU_SH4
377
378config CPU_SUBTYPE_SH7750S
379 bool "Support SH7750S processor"
380 select CPU_SH4
381
382config CPU_SUBTYPE_SH7751
383 bool "Support SH7751 processor"
384 select CPU_SH4
385 help
386 Select SH7751 if you have a 166 Mhz SH-4 HD6417751 CPU,
387 or if you have a HD6417751R CPU.
388
389config CPU_SUBTYPE_SH7751R
390 bool "Support SH7751R processor"
391 select CPU_SH4
392
393config CPU_SUBTYPE_SH7760
394 bool "Support SH7760 processor"
395 select CPU_SH4
396
397config CPU_SUBTYPE_SH4_202
398 bool "Support SH4-202 processor"
399 select CPU_SH4
400
401# SH-4A Processor Support
402
Paul Mundt178dd0c2008-04-09 17:56:18 +0900403config CPU_SUBTYPE_SH7723
404 bool "Support SH7723 processor"
405 select CPU_SH4A
406 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900407 select ARCH_SHMOBILE
Paul Mundt178dd0c2008-04-09 17:56:18 +0900408 select ARCH_SPARSEMEM_ENABLE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900409 select SYS_SUPPORTS_CMT
Paul Mundt178dd0c2008-04-09 17:56:18 +0900410 help
411 Select SH7723 if you have an SH-MobileR2 CPU.
412
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900413config CPU_SUBTYPE_SH7724
414 bool "Support SH7724 processor"
415 select CPU_SH4A
416 select CPU_SHX2
Paul Mundt59fe7002009-04-16 15:43:42 +0900417 select ARCH_SHMOBILE
Kuninori Morimoto0207a2e2009-04-16 14:40:56 +0900418 select ARCH_SPARSEMEM_ENABLE
419 select SYS_SUPPORTS_CMT
420 help
421 Select SH7724 if you have an SH-MobileR2R CPU.
422
Yoshihiro Shimodac01f0f12009-08-21 16:30:28 +0900423config CPU_SUBTYPE_SH7757
424 bool "Support SH7757 processor"
425 select CPU_SH4A
426 select CPU_SHX2
427 help
428 Select SH7757 if you have a SH4A SH7757 CPU.
429
Yoshihiro Shimoda7d740a02008-01-07 14:40:07 +0900430config CPU_SUBTYPE_SH7763
431 bool "Support SH7763 processor"
432 select CPU_SH4A
433 help
434 Select SH7763 if you have a SH4A SH7763(R5S77631) CPU.
435
Paul Mundtb5f42db2007-11-08 18:38:14 +0900436config CPU_SUBTYPE_SH7770
437 bool "Support SH7770 processor"
438 select CPU_SH4A
439
440config CPU_SUBTYPE_SH7780
441 bool "Support SH7780 processor"
442 select CPU_SH4A
443
444config CPU_SUBTYPE_SH7785
445 bool "Support SH7785 processor"
446 select CPU_SH4A
447 select CPU_SHX2
448 select ARCH_SPARSEMEM_ENABLE
449 select SYS_SUPPORTS_NUMA
450
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900451config CPU_SUBTYPE_SH7786
452 bool "Support SH7786 processor"
453 select CPU_SH4A
Paul Mundt37042fb2009-03-03 15:57:02 +0900454 select CPU_SHX3
Paul Mundt8263a672009-03-17 17:49:49 +0900455 select CPU_HAS_PTEAEX
Paul Mundt2eb2a432009-06-19 16:00:00 +0900456 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Kuninori Morimoto55ba99e2009-03-03 15:40:25 +0900457
Paul Mundtb5f42db2007-11-08 18:38:14 +0900458config CPU_SUBTYPE_SHX3
459 bool "Support SH-X3 processor"
460 select CPU_SH4A
461 select CPU_SHX3
Paul Mundt58402632008-09-05 15:36:39 +0900462 select GENERIC_CLOCKEVENTS_BROADCAST if SMP
Paul Mundt742759e2010-10-02 19:43:40 +0900463 select ARCH_REQUIRE_GPIOLIB
Paul Mundtb5f42db2007-11-08 18:38:14 +0900464
465# SH4AL-DSP Processor Support
466
467config CPU_SUBTYPE_SH7343
468 bool "Support SH7343 processor"
469 select CPU_SH4AL_DSP
Paul Mundtdc65a972009-03-10 16:26:29 +0900470 select ARCH_SHMOBILE
Paul Mundtf5ad8812009-01-29 18:08:58 +0900471 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900472
473config CPU_SUBTYPE_SH7722
474 bool "Support SH7722 processor"
475 select CPU_SH4AL_DSP
476 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900477 select ARCH_SHMOBILE
Paul Mundtb5f42db2007-11-08 18:38:14 +0900478 select ARCH_SPARSEMEM_ENABLE
479 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900480 select SYS_SUPPORTS_CMT
Paul Mundtb5f42db2007-11-08 18:38:14 +0900481
Magnus Damm9109a302008-02-08 17:31:24 +0900482config CPU_SUBTYPE_SH7366
483 bool "Support SH7366 processor"
484 select CPU_SH4AL_DSP
485 select CPU_SHX2
Paul Mundtdc65a972009-03-10 16:26:29 +0900486 select ARCH_SHMOBILE
Magnus Damm9109a302008-02-08 17:31:24 +0900487 select ARCH_SPARSEMEM_ENABLE
488 select SYS_SUPPORTS_NUMA
Paul Mundtf5ad8812009-01-29 18:08:58 +0900489 select SYS_SUPPORTS_CMT
Magnus Damm9109a302008-02-08 17:31:24 +0900490
Paul Mundt3cc000b2009-04-11 08:39:27 +0900491endchoice
492
493endif
494
495if SUPERH64
496
497choice
498 prompt "Processor sub-type selection"
499
Paul Mundtea0e1a92007-11-21 15:58:01 +0900500# SH-5 Processor Support
501
502config CPU_SUBTYPE_SH5_101
503 bool "Support SH5-101 processor"
504 select CPU_SH5
505
506config CPU_SUBTYPE_SH5_103
507 bool "Support SH5-103 processor"
Paul Mundt8ef97dd2008-02-14 15:30:54 +0900508 select CPU_SH5
Paul Mundtea0e1a92007-11-21 15:58:01 +0900509
Paul Mundtb5f42db2007-11-08 18:38:14 +0900510endchoice
511
Paul Mundt3cc000b2009-04-11 08:39:27 +0900512endif
513
Paul Mundtcad82442006-01-16 22:14:19 -0800514source "arch/sh/mm/Kconfig"
Paul Mundt939a24a2008-07-29 21:41:37 +0900515
Paul Mundt4690bdc2007-11-09 13:45:42 +0900516source "arch/sh/Kconfig.cpu"
Paul Mundtcad82442006-01-16 22:14:19 -0800517
Paul Mundt939a24a2008-07-29 21:41:37 +0900518source "arch/sh/boards/Kconfig"
Paul Mundtf3d22292007-05-14 17:29:12 +0900519
Paul Mundt32351a22007-03-12 14:38:59 +0900520menu "Timer and clock configuration"
521
Magnus Damm9570ef22009-05-01 06:51:00 +0000522config SH_TIMER_TMU
523 bool "TMU timer driver"
Magnus Dammf19900b2009-05-12 10:25:54 +0000524 depends on SYS_SUPPORTS_TMU
Magnus Damm9570ef22009-05-01 06:51:00 +0000525 default y
Magnus Damm9570ef22009-05-01 06:51:00 +0000526 help
527 This enables the build of the TMU timer driver.
528
Paul Mundtf5ad8812009-01-29 18:08:58 +0900529config SH_TIMER_CMT
Magnus Dammf4257522009-04-30 04:09:26 +0000530 bool "CMT timer driver"
531 depends on SYS_SUPPORTS_CMT
532 default y
Magnus Dammf4257522009-04-30 04:09:26 +0000533 help
534 This enables build of the CMT timer driver.
Paul Mundtf5ad8812009-01-29 18:08:58 +0900535
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000536config SH_TIMER_MTU2
537 bool "MTU2 timer driver"
Magnus Damm3280c882009-04-30 07:12:09 +0000538 depends on SYS_SUPPORTS_MTU2
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000539 default y
Magnus Dammd5ed4c22009-04-30 07:02:49 +0000540 help
541 This enables build of the MTU2 timer driver.
542
Paul Mundtcad82442006-01-16 22:14:19 -0800543config SH_PCLK_FREQ
544 int "Peripheral clock frequency (in Hz)"
Paul Mundt8152a742009-12-29 11:09:30 +0900545 depends on SH_CLK_CPG_LEGACY
Yoshinori Sato9d4436a2006-11-05 15:40:13 +0900546 default "31250000" if CPU_SUBTYPE_SH7619
Paul Mundt8152a742009-12-29 11:09:30 +0900547 default "33333333" if CPU_SUBTYPE_SH7770 || \
548 CPU_SUBTYPE_SH7760 || \
549 CPU_SUBTYPE_SH7705 || \
550 CPU_SUBTYPE_SH7203 || \
551 CPU_SUBTYPE_SH7206 || \
552 CPU_SUBTYPE_SH7263 || \
Paul Mundt43a18392010-01-19 19:37:14 +0900553 CPU_SUBTYPE_MXG
Paul Mundt05627482007-05-15 16:25:47 +0900554 default "60000000" if CPU_SUBTYPE_SH7751 || CPU_SUBTYPE_SH7751R
Paul Mundtcad82442006-01-16 22:14:19 -0800555 default "66000000" if CPU_SUBTYPE_SH4_202
Paul Mundt05627482007-05-15 16:25:47 +0900556 default "50000000"
Paul Mundtcad82442006-01-16 22:14:19 -0800557 help
558 This option is used to specify the peripheral clock frequency.
559 This is necessary for determining the reference clock value on
560 platforms lacking an RTC.
561
Paul Mundt36aa1e32009-05-22 14:00:34 +0900562config SH_CLK_CPG
563 def_bool y
564
Paul Mundt253b0882009-05-13 17:38:11 +0900565config SH_CLK_CPG_LEGACY
Paul Mundt36aa1e32009-05-22 14:00:34 +0900566 depends on SH_CLK_CPG
Paul Mundt43a18392010-01-19 19:37:14 +0900567 def_bool y if !CPU_SUBTYPE_SH7785 && !ARCH_SHMOBILE && \
Paul Mundt5924ad02010-10-01 23:49:56 +0900568 !CPU_SHX3 && !CPU_SUBTYPE_SH7757
Paul Mundt253b0882009-05-13 17:38:11 +0900569
Paul Mundt57be2b42007-05-09 17:33:24 +0900570source "kernel/time/Kconfig"
571
Paul Mundt32351a22007-03-12 14:38:59 +0900572endmenu
573
Paul Mundtcad82442006-01-16 22:14:19 -0800574menu "CPU Frequency scaling"
575
576source "drivers/cpufreq/Kconfig"
577
578config SH_CPU_FREQ
579 tristate "SuperH CPU Frequency driver"
Paul Mundtcb5ec752007-07-20 13:38:19 +0900580 depends on CPU_FREQ
Paul Mundtcad82442006-01-16 22:14:19 -0800581 select CPU_FREQ_TABLE
582 help
Paul Mundt8a655052008-12-17 15:06:54 +0900583 This adds the cpufreq driver for SuperH. Any CPU that supports
584 clock rate rounding through the clock framework can use this
585 driver. While it will make the kernel slightly larger, this is
586 harmless for CPUs that don't support rate rounding. The driver
587 will also generate a notice in the boot log before disabling
588 itself if the CPU in question is not capable of rate rounding.
Paul Mundtcad82442006-01-16 22:14:19 -0800589
590 For details, take a look at <file:Documentation/cpu-freq>.
591
592 If unsure, say N.
593
594endmenu
595
Paul Mundt9f5e8ee2006-11-24 11:22:57 +0900596source "arch/sh/drivers/Kconfig"
597
Paul Mundtcad82442006-01-16 22:14:19 -0800598endmenu
599
Paul Mundtcad82442006-01-16 22:14:19 -0800600menu "Kernel features"
601
Paul Mundt91b91d02006-09-27 18:08:33 +0900602source kernel/Kconfig.hz
603
Paul Mundtcad82442006-01-16 22:14:19 -0800604config KEXEC
605 bool "kexec system call (EXPERIMENTAL)"
Nobuhiro Iwamatsuf36b59d2009-03-26 08:32:37 +0000606 depends on SUPERH32 && EXPERIMENTAL && MMU
Paul Mundtcad82442006-01-16 22:14:19 -0800607 help
608 kexec is a system call that implements the ability to shutdown your
609 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400610 but it is independent of the system firmware. And like a reboot
Paul Mundtcad82442006-01-16 22:14:19 -0800611 you can start any kernel with it, not just Linux.
612
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400613 The name comes from the similarity to the exec system call.
Paul Mundtcad82442006-01-16 22:14:19 -0800614
615 It is an ongoing process to be certain the hardware in a machine
616 is properly shutdown, so do not be surprised if this code does not
617 initially work for you. It may help to enable device hotplugging
618 support. As of this writing the exact hardware interface is
619 strongly in flux, so no good recommendation can be made.
620
Paul Mundt4d5ade52007-04-27 11:25:57 +0900621config CRASH_DUMP
622 bool "kernel crash dumps (EXPERIMENTAL)"
Paul Mundtd523e1a2010-05-07 16:39:09 +0900623 depends on SUPERH32 && EXPERIMENTAL && BROKEN_ON_SMP
Paul Mundt4d5ade52007-04-27 11:25:57 +0900624 help
625 Generate crash dump after being started by kexec.
626 This should be normally only set in special crash dump kernels
627 which are loaded in the main kernel with kexec-tools into
628 a specially reserved region and then later executed after
629 a crash by kdump/kexec. The crash dump kernel must be compiled
630 to a memory address not used by the main kernel using
631 MEMORY_START.
632
633 For more details see Documentation/kdump/kdump.txt
634
Magnus Dammb7cf6dd2009-03-18 08:51:29 +0000635config KEXEC_JUMP
636 bool "kexec jump (EXPERIMENTAL)"
637 depends on SUPERH32 && KEXEC && HIBERNATION && EXPERIMENTAL
638 help
639 Jump between original kernel and kexeced kernel and invoke
640 code via KEXEC
641
Paul Mundtc4637d42008-07-30 15:30:52 +0900642config SECCOMP
643 bool "Enable seccomp to safely compute untrusted bytecode"
644 depends on PROC_FS
Paul Mundtc4637d42008-07-30 15:30:52 +0900645 help
646 This kernel feature is useful for number crunching applications
647 that may need to compute untrusted bytecode during their
648 execution. By using pipes or other transports made available to
649 the process as file descriptors supporting the read/write
650 syscalls, it's possible to isolate those applications in
651 their own address space using seccomp. Once seccomp is
652 enabled via prctl, it cannot be disabled and the task is only
653 allowed to execute a few safe syscalls defined by each seccomp
654 mode.
655
656 If unsure, say N.
657
Linus Torvalds1da177e2005-04-16 15:20:36 -0700658config SMP
659 bool "Symmetric multi-processing support"
Paul Mundt357d5942007-06-11 15:32:07 +0900660 depends on SYS_SUPPORTS_SMP
Jens Axboe490f5de2008-06-10 20:52:59 +0200661 select USE_GENERIC_SMP_HELPERS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700662 ---help---
663 This enables support for systems with more than one CPU. If you have
664 a system with only one CPU, like most personal computers, say N. If
665 you have a system with more than one CPU, say Y.
666
667 If you say N here, the kernel will run on single and multiprocessor
668 machines, but will use only one CPU of a multiprocessor machine. If
669 you say Y here, the kernel will run on many, but not all,
670 singleprocessor machines. On a singleprocessor machine, the kernel
671 will run faster if you say N here.
672
673 People using multiprocessor machines who say Y here should also say
674 Y to "Enhanced Real Time Clock Support", below.
675
Adrian Bunk03502fa2008-02-03 15:50:21 +0200676 See also <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO
677 available at <http://www.tldp.org/docs.html#howto>.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700678
679 If you don't know what to do here, say N.
680
681config NR_CPUS
682 int "Maximum number of CPUs (2-32)"
683 range 2 32
684 depends on SMP
Paul Mundt2eb2a432009-06-19 16:00:00 +0900685 default "4" if CPU_SUBTYPE_SHX3
Linus Torvalds1da177e2005-04-16 15:20:36 -0700686 default "2"
687 help
688 This allows you to specify the maximum number of CPUs which this
689 kernel will support. The maximum supported value is 32 and the
690 minimum value which makes sense is 2.
691
692 This is purely to save memory - each supported CPU adds
693 approximately eight kilobytes to the kernel image.
694
Paul Mundt763142d2010-04-26 19:08:55 +0900695config HOTPLUG_CPU
696 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
697 depends on SMP && HOTPLUG && EXPERIMENTAL
698 help
699 Say Y here to experiment with turning CPUs off and on. CPUs
700 can be controlled through /sys/devices/system/cpu.
701
Paul Mundt91b91d02006-09-27 18:08:33 +0900702source "kernel/Kconfig.preempt"
703
Paul Mundt83662462007-09-28 16:04:49 +0900704config GUSA
705 def_bool y
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900706 depends on !SMP && SUPERH32
Paul Mundt83662462007-09-28 16:04:49 +0900707 help
708 This enables support for gUSA (general UserSpace Atomicity).
709 This is the default implementation for both UP and non-ll/sc
710 CPUs, and is used by the libc, amongst others.
711
712 For additional information, design information can be found
713 in <http://lc.linux.or.jp/lc2002/papers/niibe0919p.pdf>.
714
715 This should only be disabled for special cases where alternate
716 atomicity implementations exist.
717
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900718config GUSA_RB
719 bool "Implement atomic operations by roll-back (gRB) (EXPERIMENTAL)"
720 depends on GUSA && CPU_SH3 || (CPU_SH4 && !CPU_SH4A)
721 help
722 Enabling this option will allow the kernel to implement some
Matt LaPlante692105b2009-01-26 11:12:25 +0100723 atomic operations using a software implementation of load-locked/
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900724 store-conditional (LLSC). On machines which do not have hardware
725 LLSC, this should be more efficient than the other alternative of
Matt LaPlante692105b2009-01-26 11:12:25 +0100726 disabling interrupts around the atomic sequence.
Stuart Menefy1efe4ce2007-11-30 16:12:36 +0900727
Matt Fleming86c8c042010-09-10 20:36:23 +0100728config HW_PERF_EVENTS
729 bool "Enable hardware performance counter support for perf events"
730 depends on PERF_EVENTS && CPU_HAS_PMU
731 default y
732 help
733 Enable hardware performance counter support for perf events. If
734 disabled, perf events will use software events only.
735
Paul Mundt43b87742010-04-13 14:43:03 +0900736source "drivers/sh/Kconfig"
737
Paul Mundtcad82442006-01-16 22:14:19 -0800738endmenu
739
740menu "Boot options"
741
742config ZERO_PAGE_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900743 hex
744 default "0x00010000" if PAGE_SIZE_64KB || SH_RTS7751R2D || \
745 SH_7751_SOLUTION_ENGINE
746 default "0x00004000" if PAGE_SIZE_16KB || SH_SH03
Paul Mundt7a847f82006-12-26 15:29:19 +0900747 default "0x00002000" if PAGE_SIZE_8KB
Paul Mundtcad82442006-01-16 22:14:19 -0800748 default "0x00001000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700749 help
Paul Mundtcad82442006-01-16 22:14:19 -0800750 This sets the default offset of zero page.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700751
Paul Mundtcad82442006-01-16 22:14:19 -0800752config BOOT_LINK_OFFSET
Paul Mundtb412a49a2009-05-10 01:23:25 +0900753 hex
754 default "0x00210000" if SH_SHMIN
Paul Mundta2e76c82009-05-10 00:54:39 +0900755 default "0x00400000" if SH_CAYMAN
Paul Mundtb412a49a2009-05-10 01:23:25 +0900756 default "0x00810000" if SH_7780_SOLUTION_ENGINE
757 default "0x009e0000" if SH_TITAN
758 default "0x01800000" if SH_SDK7780
759 default "0x02000000" if SH_EDOSK7760
Paul Mundtcad82442006-01-16 22:14:19 -0800760 default "0x00800000"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700761 help
Paul Mundtcad82442006-01-16 22:14:19 -0800762 This option allows you to set the link address offset of the zImage.
763 This can be useful if you are on a board which has a small amount of
764 memory.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700765
Paul Mundtb412a49a2009-05-10 01:23:25 +0900766config ENTRY_OFFSET
767 hex
768 default "0x00001000" if PAGE_SIZE_4KB
769 default "0x00002000" if PAGE_SIZE_8KB
770 default "0x00004000" if PAGE_SIZE_16KB
771 default "0x00010000" if PAGE_SIZE_64KB
772 default "0x00000000"
773
Magnus Damm4705b2e82010-05-18 14:43:15 +0000774config ROMIMAGE_MMCIF
775 bool "Include MMCIF loader in romImage (EXPERIMENTAL)"
776 depends on CPU_SUBTYPE_SH7724 && EXPERIMENTAL
777 help
778 Say Y here to include experimental MMCIF loading code in
779 romImage. With this enabled it is possible to write the romImage
780 kernel image to an MMC card and boot the kernel straight from
781 the reset vector. At reset the processor Mask ROM will load the
782 first part of the romImage which in turn loads the rest the kernel
783 image to RAM using the MMCIF hardware block.
784
Pawel Molld724a9c2009-08-24 16:25:38 +0900785choice
786 prompt "Kernel command line"
787 optional
788 default CMDLINE_OVERWRITE
789 help
790 Setting this option allows the kernel command line arguments
791 to be set.
792
793config CMDLINE_OVERWRITE
794 bool "Overwrite bootloader kernel arguments"
795 help
796 Given string will overwrite any arguments passed in by
797 a bootloader.
798
799config CMDLINE_EXTEND
800 bool "Extend bootloader kernel arguments"
801 help
802 Given string will be concatenated with arguments passed in
803 by a bootloader.
804
805endchoice
Linus Torvalds1da177e2005-04-16 15:20:36 -0700806
Paul Mundtcad82442006-01-16 22:14:19 -0800807config CMDLINE
Pawel Molld724a9c2009-08-24 16:25:38 +0900808 string "Kernel command line arguments string"
809 depends on CMDLINE_OVERWRITE || CMDLINE_EXTEND
Paul Mundtcad82442006-01-16 22:14:19 -0800810 default "console=ttySC1,115200"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700811
812endmenu
813
Paul Mundtcad82442006-01-16 22:14:19 -0800814menu "Bus options"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700815
Paul Mundtcad82442006-01-16 22:14:19 -0800816config SUPERHYWAY
817 tristate "SuperHyway Bus support"
818 depends on CPU_SUBTYPE_SH4_202
Linus Torvalds1da177e2005-04-16 15:20:36 -0700819
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900820config MAPLE
Paul Mundte16038a2009-01-09 15:12:30 +0900821 bool "Maple Bus support"
822 depends on SH_DREAMCAST
823 help
824 The Maple Bus is SEGA's serial communication bus for peripherals
825 on the Dreamcast. Without this bus support you won't be able to
826 get your Dreamcast keyboard etc to work, so most users
827 probably want to say 'Y' here, unless you are only using the
828 Dreamcast with a serial line terminal or a remote network
829 connection.
Adrian McMenamin17be2d22007-09-21 15:55:55 +0900830
Paul Mundt76934652009-10-27 10:36:55 +0900831config PCI
832 bool "PCI support"
833 depends on SYS_SUPPORTS_PCI
Paul Mundt320e68d2010-01-29 22:38:13 +0900834 select PCI_DOMAINS
Paul Mundt76934652009-10-27 10:36:55 +0900835 help
836 Find out whether you have a PCI motherboard. PCI is the name of a
837 bus system, i.e. the way the CPU talks to the other stuff inside
838 your box. If you have PCI, say Y, otherwise N.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700839
Paul Mundt320e68d2010-01-29 22:38:13 +0900840config PCI_DOMAINS
841 bool
842
Paul Mundte16038a2009-01-09 15:12:30 +0900843source "drivers/pci/pcie/Kconfig"
844
Linus Torvalds1da177e2005-04-16 15:20:36 -0700845source "drivers/pci/Kconfig"
846
847source "drivers/pcmcia/Kconfig"
848
849source "drivers/pci/hotplug/Kconfig"
850
851endmenu
852
853menu "Executable file formats"
854
855source "fs/Kconfig.binfmt"
856
857endmenu
858
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900859menu "Power management options (EXPERIMENTAL)"
Magnus Dammaf998a92008-12-04 22:45:12 +0900860depends on EXPERIMENTAL
Johannes Bergf4cb5702007-12-08 02:14:00 +0100861
Magnus Dammc6f17cb2008-12-04 22:45:20 +0900862source "kernel/power/Kconfig"
863
864source "drivers/cpuidle/Kconfig"
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900865
Andriy Skulysh3aa770e2006-09-27 16:20:22 +0900866endmenu
867
Sam Ravnborgd5950b42005-07-11 21:03:49 -0700868source "net/Kconfig"
869
Linus Torvalds1da177e2005-04-16 15:20:36 -0700870source "drivers/Kconfig"
871
872source "fs/Kconfig"
873
Linus Torvalds1da177e2005-04-16 15:20:36 -0700874source "arch/sh/Kconfig.debug"
875
876source "security/Kconfig"
877
878source "crypto/Kconfig"
879
Magnus Damm5f737b32010-04-28 05:46:11 +0000880menuconfig VIRTUALIZATION
881 bool "Virtualization"
882 default n
883 ---help---
884 Say Y here to get to see options for using your Linux host to run other
885 operating systems inside virtual machines (guests).
886 This option alone does not add any kernel code.
887
888 If you say N, all options in this submenu will be skipped and disabled.
889
890if VIRTUALIZATION
891
892source drivers/virtio/Kconfig
893
894endif # VIRTUALIZATION
895
Linus Torvalds1da177e2005-04-16 15:20:36 -0700896source "lib/Kconfig"