1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0 2f8c4a270SJonas Bonn# 3f8c4a270SJonas Bonn# For a description of the syntax of this configuration file, 4395cf969SPaul Bolle# see Documentation/kbuild/kconfig-language.txt. 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 39*6137fed0SPeter 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 RWSEM_GENERIC_SPINLOCK 48f8c4a270SJonas Bonn def_bool y 49f8c4a270SJonas Bonn 50f8c4a270SJonas Bonnconfig RWSEM_XCHGADD_ALGORITHM 51f8c4a270SJonas Bonn def_bool n 52f8c4a270SJonas Bonn 53f8c4a270SJonas Bonnconfig GENERIC_HWEIGHT 54f8c4a270SJonas Bonn def_bool y 55f8c4a270SJonas Bonn 56ce816fa8SUwe Kleine-Königconfig NO_IOPORT_MAP 57f8c4a270SJonas Bonn def_bool y 58f8c4a270SJonas Bonn 59f8c4a270SJonas Bonnconfig TRACE_IRQFLAGS_SUPPORT 60f8c4a270SJonas Bonn def_bool y 61f8c4a270SJonas Bonn 62f8c4a270SJonas Bonn# For now, use generic checksum functions 63f8c4a270SJonas Bonn#These can be reimplemented in assembly later if so inclined 64f8c4a270SJonas Bonnconfig GENERIC_CSUM 65f8c4a270SJonas Bonn def_bool y 66f8c4a270SJonas Bonn 67eecac38bSStafford Horneconfig STACKTRACE_SUPPORT 68eecac38bSStafford Horne def_bool y 69eecac38bSStafford Horne 7078cdfb5cSStafford Horneconfig LOCKDEP_SUPPORT 7178cdfb5cSStafford Horne def_bool y 7278cdfb5cSStafford Horne 73f8c4a270SJonas Bonnmenu "Processor type and features" 74f8c4a270SJonas Bonn 75f8c4a270SJonas Bonnchoice 76f8c4a270SJonas Bonn prompt "Subarchitecture" 77f8c4a270SJonas Bonn default OR1K_1200 78f8c4a270SJonas Bonn 79f8c4a270SJonas Bonnconfig OR1K_1200 80f8c4a270SJonas Bonn bool "OR1200" 81f8c4a270SJonas Bonn help 82f8c4a270SJonas Bonn Generic OpenRISC 1200 architecture 83f8c4a270SJonas Bonn 84f8c4a270SJonas Bonnendchoice 85f8c4a270SJonas Bonn 864ee93d80SJan Henrik Weinstockconfig DCACHE_WRITETHROUGH 874ee93d80SJan Henrik Weinstock bool "Have write through data caches" 884ee93d80SJan Henrik Weinstock default n 894ee93d80SJan Henrik Weinstock help 904ee93d80SJan Henrik Weinstock Select this if your implementation features write through data caches. 914ee93d80SJan Henrik Weinstock Selecting 'N' here will allow the kernel to force flushing of data 924ee93d80SJan Henrik Weinstock caches at relevant times. Most OpenRISC implementations support write- 934ee93d80SJan Henrik Weinstock through data caches. 944ee93d80SJan Henrik Weinstock 954ee93d80SJan Henrik Weinstock If unsure say N here 964ee93d80SJan Henrik Weinstock 97f8c4a270SJonas Bonnconfig OPENRISC_BUILTIN_DTB 98f8c4a270SJonas Bonn string "Builtin DTB" 99f8c4a270SJonas Bonn default "" 100f8c4a270SJonas Bonn 101f8c4a270SJonas Bonnmenu "Class II Instructions" 102f8c4a270SJonas Bonn 103f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_FF1 104f8c4a270SJonas Bonn bool "Have instruction l.ff1" 105f8c4a270SJonas Bonn default y 106f8c4a270SJonas Bonn help 107f8c4a270SJonas Bonn Select this if your implementation has the Class II instruction l.ff1 108f8c4a270SJonas Bonn 109f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_FL1 110f8c4a270SJonas Bonn bool "Have instruction l.fl1" 111f8c4a270SJonas Bonn default y 112f8c4a270SJonas Bonn help 113f8c4a270SJonas Bonn Select this if your implementation has the Class II instruction l.fl1 114f8c4a270SJonas Bonn 115f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_MUL 116f8c4a270SJonas Bonn bool "Have instruction l.mul for hardware multiply" 117f8c4a270SJonas Bonn default y 118f8c4a270SJonas Bonn help 119f8c4a270SJonas Bonn Select this if your implementation has a hardware multiply instruction 120f8c4a270SJonas Bonn 121f8c4a270SJonas Bonnconfig OPENRISC_HAVE_INST_DIV 122f8c4a270SJonas Bonn bool "Have instruction l.div for hardware divide" 123f8c4a270SJonas Bonn default y 124f8c4a270SJonas Bonn help 125f8c4a270SJonas Bonn Select this if your implementation has a hardware divide instruction 126f8c4a270SJonas Bonnendmenu 127f8c4a270SJonas Bonn 12834bbdcdcSStafford Horneconfig NR_CPUS 1298e6d08e0SStefan Kristiansson int "Maximum number of CPUs (2-32)" 1308e6d08e0SStefan Kristiansson range 2 32 1318e6d08e0SStefan Kristiansson depends on SMP 1328e6d08e0SStefan Kristiansson default "2" 1338e6d08e0SStefan Kristiansson 1348e6d08e0SStefan Kristianssonconfig SMP 1358e6d08e0SStefan Kristiansson bool "Symmetric Multi-Processing support" 1368e6d08e0SStefan Kristiansson help 1378e6d08e0SStefan Kristiansson This enables support for systems with more than one CPU. If you have 1388e6d08e0SStefan Kristiansson a system with only one CPU, say N. If you have a system with more 1398e6d08e0SStefan Kristiansson than one CPU, say Y. 1408e6d08e0SStefan Kristiansson 1418e6d08e0SStefan Kristiansson If you don't know what to do here, say N. 142f8c4a270SJonas Bonn 1438636a1f9SMasahiro Yamadasource "kernel/Kconfig.hz" 144f8c4a270SJonas Bonn 145f8c4a270SJonas Bonnconfig OPENRISC_NO_SPR_SR_DSX 146f8c4a270SJonas Bonn bool "use SPR_SR_DSX software emulation" if OR1K_1200 147f8c4a270SJonas Bonn default y 148f8c4a270SJonas Bonn help 149f8c4a270SJonas Bonn SPR_SR_DSX bit is status register bit indicating whether 150f8c4a270SJonas Bonn the last exception has happened in delay slot. 151f8c4a270SJonas Bonn 152f8c4a270SJonas Bonn OpenRISC architecture makes it optional to have it implemented 153f8c4a270SJonas Bonn in hardware and the OR1200 does not have it. 154f8c4a270SJonas Bonn 155f8c4a270SJonas Bonn Say N here if you know that your OpenRISC processor has 156f8c4a270SJonas Bonn SPR_SR_DSX bit implemented. Say Y if you are unsure. 157f8c4a270SJonas Bonn 15891993c8cSStefan Kristianssonconfig OPENRISC_HAVE_SHADOW_GPRS 15991993c8cSStefan Kristiansson bool "Support for shadow gpr files" if !SMP 16091993c8cSStefan Kristiansson default y if SMP 16191993c8cSStefan Kristiansson help 16291993c8cSStefan Kristiansson Say Y here if your OpenRISC processor features shadowed 16391993c8cSStefan Kristiansson register files. They will in such case be used as a 16491993c8cSStefan Kristiansson scratch reg storage on exception entry. 16591993c8cSStefan Kristiansson 16691993c8cSStefan Kristiansson On SMP systems, this feature is mandatory. 16791993c8cSStefan Kristiansson On a unicore system it's safe to say N here if you are unsure. 16891993c8cSStefan Kristiansson 169f8c4a270SJonas Bonnconfig CMDLINE 170f8c4a270SJonas Bonn string "Default kernel command string" 171f8c4a270SJonas Bonn default "" 172f8c4a270SJonas Bonn help 173f8c4a270SJonas Bonn On some architectures there is currently no way for the boot loader 174f8c4a270SJonas Bonn to pass arguments to the kernel. For these architectures, you should 175f8c4a270SJonas Bonn supply some command-line options at build time by entering them 176f8c4a270SJonas Bonn here. 177f8c4a270SJonas Bonn 178f8c4a270SJonas Bonnmenu "Debugging options" 179f8c4a270SJonas Bonn 180f8c4a270SJonas Bonnconfig JUMP_UPON_UNHANDLED_EXCEPTION 181f8c4a270SJonas Bonn bool "Try to die gracefully" 182f8c4a270SJonas Bonn default y 183f8c4a270SJonas Bonn help 184f8c4a270SJonas Bonn Now this puts kernel into infinite loop after first oops. Till 185f8c4a270SJonas Bonn your kernel crashes this doesn't have any influence. 186f8c4a270SJonas Bonn 187f8c4a270SJonas Bonn Say Y if you are unsure. 188f8c4a270SJonas Bonn 189f8c4a270SJonas Bonnconfig OPENRISC_ESR_EXCEPTION_BUG_CHECK 190f8c4a270SJonas Bonn bool "Check for possible ESR exception bug" 191f8c4a270SJonas Bonn default n 192f8c4a270SJonas Bonn help 193f8c4a270SJonas Bonn This option enables some checks that might expose some problems 194f8c4a270SJonas Bonn in kernel. 195f8c4a270SJonas Bonn 196f8c4a270SJonas Bonn Say N if you are unsure. 197f8c4a270SJonas Bonn 198f8c4a270SJonas Bonnendmenu 199f8c4a270SJonas Bonn 200f8c4a270SJonas Bonnendmenu 201