xref: /linux/arch/openrisc/Kconfig (revision cd238effefa28fac177e51dcf5e9d1a8b59c3c6b)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
2f8c4a270SJonas Bonn#
3f8c4a270SJonas Bonn# For a description of the syntax of this configuration file,
4*cd238effSMauro Carvalho Chehab# see Documentation/kbuild/kconfig-language.rst.
5f8c4a270SJonas Bonn#
6f8c4a270SJonas Bonn
7f8c4a270SJonas Bonnconfig OPENRISC
8f8c4a270SJonas Bonn	def_bool y
9942fa985SYury Norov	select ARCH_32BIT_OFF_T
105600779eSChristoph Hellwig	select ARCH_HAS_SYNC_DMA_FOR_DEVICE
11f8c4a270SJonas Bonn	select OF
12f8c4a270SJonas Bonn	select OF_EARLY_FLATTREE
13b4c4c6eeSJonas Bonn	select IRQ_DOMAIN
14d1f6f28fSMarc Zyngier	select HANDLE_DOMAIN_IRQ
158636f344SLinus Walleij	select GPIOLIB
16f8c4a270SJonas Bonn        select HAVE_ARCH_TRACEHOOK
17c0fcaf55SJonas Bonn	select SPARSE_IRQ
18f8c4a270SJonas Bonn	select GENERIC_IRQ_CHIP
19f8c4a270SJonas Bonn	select GENERIC_IRQ_PROBE
20f8c4a270SJonas Bonn	select GENERIC_IRQ_SHOW
21f8c4a270SJonas Bonn	select GENERIC_IOMAP
229f13a1fdSBen Hutchings	select GENERIC_CPU_DEVICES
2304ea1e91SAndrew Morton	select HAVE_UID16
240662d33aSRichard Weinberger	select GENERIC_ATOMIC64
255bf8f6bfSAnna-Maria Gleixner	select GENERIC_CLOCKEVENTS
268e6d08e0SStefan Kristiansson	select GENERIC_CLOCKEVENTS_BROADCAST
27603d6637SJonas Bonn	select GENERIC_STRNCPY_FROM_USER
28b48b2c3eSJonas Bonn	select GENERIC_STRNLEN_USER
298e6d08e0SStefan Kristiansson	select GENERIC_SMP_IDLE_THREAD
30786d35d4SDavid Howells	select MODULES_USE_ELF_RELA
31d1a1dc0bSDave Hansen	select HAVE_DEBUG_STACKOVERFLOW
324db8e6d2SStefan Kristiansson	select OR1K_PIC
33fff7fb0bSZhaoxiu Zeng	select CPU_NO_EFFICIENT_FFS if !OPENRISC_HAVE_INST_FF1
34b5f82176SStafford Horne	select ARCH_USE_QUEUED_SPINLOCKS
35b5f82176SStafford Horne	select ARCH_USE_QUEUED_RWLOCKS
369b54470aSStafford Horne	select OMPIC if SMP
37eecac38bSStafford Horne	select ARCH_WANT_FRAME_POINTERS
38c5ca4560SPalmer Dabbelt	select GENERIC_IRQ_MULTI_HANDLER
396137fed0SPeter Zijlstra	select MMU_GATHER_NO_RANGE if MMU
40f8c4a270SJonas Bonn
414c97a0c8SBabu Mogerconfig CPU_BIG_ENDIAN
424c97a0c8SBabu Moger	def_bool y
434c97a0c8SBabu Moger
44f8c4a270SJonas Bonnconfig MMU
45f8c4a270SJonas Bonn	def_bool y
46f8c4a270SJonas Bonn
47f8c4a270SJonas Bonnconfig GENERIC_HWEIGHT
48f8c4a270SJonas Bonn	def_bool y
49f8c4a270SJonas Bonn
50ce816fa8SUwe Kleine-Königconfig NO_IOPORT_MAP
51f8c4a270SJonas Bonn	def_bool y
52f8c4a270SJonas Bonn
53f8c4a270SJonas Bonnconfig TRACE_IRQFLAGS_SUPPORT
54f8c4a270SJonas Bonn        def_bool y
55f8c4a270SJonas Bonn
56f8c4a270SJonas Bonn# For now, use generic checksum functions
57f8c4a270SJonas Bonn#These can be reimplemented in assembly later if so inclined
58f8c4a270SJonas Bonnconfig GENERIC_CSUM
59f8c4a270SJonas Bonn        def_bool y
60f8c4a270SJonas Bonn
61eecac38bSStafford Horneconfig STACKTRACE_SUPPORT
62eecac38bSStafford Horne	def_bool y
63eecac38bSStafford Horne
6478cdfb5cSStafford Horneconfig LOCKDEP_SUPPORT
6578cdfb5cSStafford Horne	def_bool  y
6678cdfb5cSStafford Horne
67f8c4a270SJonas Bonnmenu "Processor type and features"
68f8c4a270SJonas Bonn
69f8c4a270SJonas Bonnchoice
70f8c4a270SJonas Bonn	prompt "Subarchitecture"
71f8c4a270SJonas Bonn	default OR1K_1200
72f8c4a270SJonas Bonn
73f8c4a270SJonas Bonnconfig OR1K_1200
74f8c4a270SJonas Bonn	bool "OR1200"
75f8c4a270SJonas Bonn	help
76f8c4a270SJonas Bonn	  Generic OpenRISC 1200 architecture
77f8c4a270SJonas Bonn
78f8c4a270SJonas Bonnendchoice
79f8c4a270SJonas Bonn
804ee93d80SJan Henrik Weinstockconfig DCACHE_WRITETHROUGH
814ee93d80SJan Henrik Weinstock	bool "Have write through data caches"
824ee93d80SJan Henrik Weinstock	default n
834ee93d80SJan Henrik Weinstock	help
844ee93d80SJan Henrik Weinstock	  Select this if your implementation features write through data caches.
854ee93d80SJan Henrik Weinstock	  Selecting 'N' here will allow the kernel to force flushing of data
864ee93d80SJan Henrik Weinstock	  caches at relevant times. Most OpenRISC implementations support write-
874ee93d80SJan Henrik Weinstock	  through data caches.
884ee93d80SJan Henrik Weinstock
894ee93d80SJan Henrik Weinstock	  If unsure say N here
904ee93d80SJan Henrik Weinstock
91f8c4a270SJonas Bonnconfig OPENRISC_BUILTIN_DTB
92f8c4a270SJonas Bonn        string "Builtin DTB"
93f8c4a270SJonas Bonn        default ""
94f8c4a270SJonas Bonn
95f8c4a270SJonas Bonnmenu "Class II Instructions"
96f8c4a270SJonas Bonn
97f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_FF1
98f8c4a270SJonas Bonn	bool "Have instruction l.ff1"
99f8c4a270SJonas Bonn	default y
100f8c4a270SJonas Bonn	help
101f8c4a270SJonas Bonn	  Select this if your implementation has the Class II instruction l.ff1
102f8c4a270SJonas Bonn
103f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_FL1
104f8c4a270SJonas Bonn	bool "Have instruction l.fl1"
105f8c4a270SJonas Bonn	default y
106f8c4a270SJonas Bonn	help
107f8c4a270SJonas Bonn	  Select this if your implementation has the Class II instruction l.fl1
108f8c4a270SJonas Bonn
109f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_MUL
110f8c4a270SJonas Bonn	bool "Have instruction l.mul for hardware multiply"
111f8c4a270SJonas Bonn	default y
112f8c4a270SJonas Bonn	help
113f8c4a270SJonas Bonn	  Select this if your implementation has a hardware multiply instruction
114f8c4a270SJonas Bonn
115f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_DIV
116f8c4a270SJonas Bonn	bool "Have instruction l.div for hardware divide"
117f8c4a270SJonas Bonn	default y
118f8c4a270SJonas Bonn	help
119f8c4a270SJonas Bonn	  Select this if your implementation has a hardware divide instruction
120f8c4a270SJonas Bonnendmenu
121f8c4a270SJonas Bonn
12234bbdcdcSStafford Horneconfig NR_CPUS
1238e6d08e0SStefan Kristiansson	int "Maximum number of CPUs (2-32)"
1248e6d08e0SStefan Kristiansson	range 2 32
1258e6d08e0SStefan Kristiansson	depends on SMP
1268e6d08e0SStefan Kristiansson	default "2"
1278e6d08e0SStefan Kristiansson
1288e6d08e0SStefan Kristianssonconfig SMP
1298e6d08e0SStefan Kristiansson	bool "Symmetric Multi-Processing support"
1308e6d08e0SStefan Kristiansson	help
1318e6d08e0SStefan Kristiansson	  This enables support for systems with more than one CPU. If you have
1328e6d08e0SStefan Kristiansson	  a system with only one CPU, say N. If you have a system with more
1338e6d08e0SStefan Kristiansson	  than one CPU, say Y.
1348e6d08e0SStefan Kristiansson
1358e6d08e0SStefan Kristiansson	  If you don't know what to do here, say N.
136f8c4a270SJonas Bonn
1378636a1f9SMasahiro Yamadasource "kernel/Kconfig.hz"
138f8c4a270SJonas Bonn
139f8c4a270SJonas Bonnconfig OPENRISC_NO_SPR_SR_DSX
140f8c4a270SJonas Bonn	bool "use SPR_SR_DSX software emulation" if OR1K_1200
141f8c4a270SJonas Bonn	default y
142f8c4a270SJonas Bonn	help
143f8c4a270SJonas Bonn	  SPR_SR_DSX bit is status register bit indicating whether
144f8c4a270SJonas Bonn	  the last exception has happened in delay slot.
145f8c4a270SJonas Bonn
146f8c4a270SJonas Bonn	  OpenRISC architecture makes it optional to have it implemented
147f8c4a270SJonas Bonn	  in hardware and the OR1200 does not have it.
148f8c4a270SJonas Bonn
149f8c4a270SJonas Bonn	  Say N here if you know that your OpenRISC processor has
150f8c4a270SJonas Bonn	  SPR_SR_DSX bit implemented. Say Y if you are unsure.
151f8c4a270SJonas Bonn
15291993c8cSStefan Kristianssonconfig OPENRISC_HAVE_SHADOW_GPRS
15391993c8cSStefan Kristiansson	bool "Support for shadow gpr files" if !SMP
15491993c8cSStefan Kristiansson	default y if SMP
15591993c8cSStefan Kristiansson	help
15691993c8cSStefan Kristiansson	  Say Y here if your OpenRISC processor features shadowed
15791993c8cSStefan Kristiansson	  register files. They will in such case be used as a
15891993c8cSStefan Kristiansson	  scratch reg storage on exception entry.
15991993c8cSStefan Kristiansson
16091993c8cSStefan Kristiansson	  On SMP systems, this feature is mandatory.
16191993c8cSStefan Kristiansson	  On a unicore system it's safe to say N here if you are unsure.
16291993c8cSStefan Kristiansson
163f8c4a270SJonas Bonnconfig CMDLINE
164f8c4a270SJonas Bonn        string "Default kernel command string"
165f8c4a270SJonas Bonn        default ""
166f8c4a270SJonas Bonn        help
167f8c4a270SJonas Bonn          On some architectures there is currently no way for the boot loader
168f8c4a270SJonas Bonn          to pass arguments to the kernel. For these architectures, you should
169f8c4a270SJonas Bonn          supply some command-line options at build time by entering them
170f8c4a270SJonas Bonn          here.
171f8c4a270SJonas Bonn
172f8c4a270SJonas Bonnmenu "Debugging options"
173f8c4a270SJonas Bonn
174f8c4a270SJonas Bonnconfig JUMP_UPON_UNHANDLED_EXCEPTION
175f8c4a270SJonas Bonn	bool "Try to die gracefully"
176f8c4a270SJonas Bonn	default y
177f8c4a270SJonas Bonn	help
178f8c4a270SJonas Bonn	  Now this puts kernel into infinite loop after first oops. Till
179f8c4a270SJonas Bonn	  your kernel crashes this doesn't have any influence.
180f8c4a270SJonas Bonn
181f8c4a270SJonas Bonn	  Say Y if you are unsure.
182f8c4a270SJonas Bonn
183f8c4a270SJonas Bonnconfig OPENRISC_ESR_EXCEPTION_BUG_CHECK
184f8c4a270SJonas Bonn	bool "Check for possible ESR exception bug"
185f8c4a270SJonas Bonn	default n
186f8c4a270SJonas Bonn	help
187f8c4a270SJonas Bonn	  This option enables some checks that might expose some problems
188f8c4a270SJonas Bonn          in kernel.
189f8c4a270SJonas Bonn
190f8c4a270SJonas Bonn	  Say N if you are unsure.
191f8c4a270SJonas Bonn
192f8c4a270SJonas Bonnendmenu
193f8c4a270SJonas Bonn
194f8c4a270SJonas Bonnendmenu
195