Kconfig 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. config MICROBLAZE
  2. def_bool y
  3. select HAVE_MEMBLOCK
  4. select HAVE_MEMBLOCK_NODE_MAP
  5. select HAVE_FUNCTION_TRACER
  6. select HAVE_FUNCTION_TRACE_MCOUNT_TEST
  7. select HAVE_FUNCTION_GRAPH_TRACER
  8. select HAVE_DYNAMIC_FTRACE
  9. select HAVE_FTRACE_MCOUNT_RECORD
  10. select ARCH_WANT_OPTIONAL_GPIOLIB
  11. select HAVE_OPROFILE
  12. select HAVE_ARCH_KGDB
  13. select HAVE_DMA_ATTRS
  14. select HAVE_DMA_API_DEBUG
  15. select TRACING_SUPPORT
  16. select OF
  17. select OF_EARLY_FLATTREE
  18. select IRQ_DOMAIN
  19. select HAVE_GENERIC_HARDIRQS
  20. select GENERIC_IRQ_PROBE
  21. select GENERIC_IRQ_SHOW
  22. select GENERIC_PCI_IOMAP
  23. select GENERIC_CPU_DEVICES
  24. select GENERIC_ATOMIC64
  25. select GENERIC_CLOCKEVENTS
  26. config SWAP
  27. def_bool n
  28. config RWSEM_GENERIC_SPINLOCK
  29. def_bool y
  30. config ZONE_DMA
  31. def_bool y
  32. config ARCH_POPULATES_NODE_MAP
  33. def_bool y
  34. config RWSEM_XCHGADD_ALGORITHM
  35. bool
  36. config ARCH_HAS_ILOG2_U32
  37. def_bool n
  38. config ARCH_HAS_ILOG2_U64
  39. def_bool n
  40. config GENERIC_HWEIGHT
  41. def_bool y
  42. config GENERIC_CALIBRATE_DELAY
  43. def_bool y
  44. config GENERIC_GPIO
  45. bool
  46. config GENERIC_CSUM
  47. def_bool y
  48. config STACKTRACE_SUPPORT
  49. def_bool y
  50. config LOCKDEP_SUPPORT
  51. def_bool y
  52. config HAVE_LATENCYTOP_SUPPORT
  53. def_bool y
  54. source "init/Kconfig"
  55. source "kernel/Kconfig.freezer"
  56. source "arch/microblaze/platform/Kconfig.platform"
  57. menu "Processor type and features"
  58. source "kernel/Kconfig.preempt"
  59. source "kernel/Kconfig.hz"
  60. config MMU
  61. bool "MMU support"
  62. default n
  63. config NO_MMU
  64. bool
  65. depends on !MMU
  66. default y
  67. comment "Boot options"
  68. config CMDLINE_BOOL
  69. bool "Default bootloader kernel arguments"
  70. config CMDLINE
  71. string "Default kernel command string"
  72. depends on CMDLINE_BOOL
  73. default "console=ttyUL0,115200"
  74. help
  75. On some architectures there is currently no way for the boot loader
  76. to pass arguments to the kernel. For these architectures, you should
  77. supply some command-line options at build time by entering them
  78. here.
  79. config CMDLINE_FORCE
  80. bool "Force default kernel command string"
  81. depends on CMDLINE_BOOL
  82. default n
  83. help
  84. Set this to have arguments from the default kernel command string
  85. override those passed by the boot loader.
  86. config SECCOMP
  87. bool "Enable seccomp to safely compute untrusted bytecode"
  88. depends on PROC_FS
  89. default y
  90. help
  91. This kernel feature is useful for number crunching applications
  92. that may need to compute untrusted bytecode during their
  93. execution. By using pipes or other transports made available to
  94. the process as file descriptors supporting the read/write
  95. syscalls, it's possible to isolate those applications in
  96. their own address space using seccomp. Once seccomp is
  97. enabled via /proc/<pid>/seccomp, it cannot be disabled
  98. and the task is only allowed to execute a few safe syscalls
  99. defined by each seccomp mode.
  100. If unsure, say Y. Only embedded should say N here.
  101. endmenu
  102. menu "Advanced setup"
  103. config ADVANCED_OPTIONS
  104. bool "Prompt for advanced kernel configuration options"
  105. help
  106. This option will enable prompting for a variety of advanced kernel
  107. configuration options. These options can cause the kernel to not
  108. work if they are set incorrectly, but can be used to optimize certain
  109. aspects of kernel memory management.
  110. Unless you know what you are doing, say N here.
  111. comment "Default settings for advanced configuration options are used"
  112. depends on !ADVANCED_OPTIONS
  113. config XILINX_UNCACHED_SHADOW
  114. bool "Are you using uncached shadow for RAM ?"
  115. depends on ADVANCED_OPTIONS && !MMU
  116. default n
  117. help
  118. This is needed to be able to allocate uncachable memory regions.
  119. The feature requires the design to define the RAM memory controller
  120. window to be twice as large as the actual physical memory.
  121. config HIGHMEM
  122. bool "High memory support"
  123. depends on MMU
  124. help
  125. The address space of Microblaze processors is only 4 Gigabytes large
  126. and it has to accommodate user address space, kernel address
  127. space as well as some memory mapped IO. That means that, if you
  128. have a large amount of physical memory and/or IO, not all of the
  129. memory can be "permanently mapped" by the kernel. The physical
  130. memory that is not permanently mapped is called "high memory".
  131. If unsure, say n.
  132. config LOWMEM_SIZE_BOOL
  133. bool "Set maximum low memory"
  134. depends on ADVANCED_OPTIONS && MMU
  135. help
  136. This option allows you to set the maximum amount of memory which
  137. will be used as "low memory", that is, memory which the kernel can
  138. access directly, without having to set up a kernel virtual mapping.
  139. This can be useful in optimizing the layout of kernel virtual
  140. memory.
  141. Say N here unless you know what you are doing.
  142. config LOWMEM_SIZE
  143. hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
  144. default "0x30000000"
  145. config MANUAL_RESET_VECTOR
  146. hex "Microblaze reset vector address setup"
  147. default "0x0"
  148. help
  149. Set this option to have the kernel override the CPU Reset vector.
  150. If zero, no change will be made to the MicroBlaze reset vector at
  151. address 0x0.
  152. If non-zero, a jump instruction to this address, will be written
  153. to the reset vector at address 0x0.
  154. If you are unsure, set it to default value 0x0.
  155. config KERNEL_START_BOOL
  156. bool "Set custom kernel base address"
  157. depends on ADVANCED_OPTIONS
  158. help
  159. This option allows you to set the kernel virtual address at which
  160. the kernel will map low memory (the kernel image will be linked at
  161. this address). This can be useful in optimizing the virtual memory
  162. layout of the system.
  163. Say N here unless you know what you are doing.
  164. config KERNEL_START
  165. hex "Virtual address of kernel base" if KERNEL_START_BOOL
  166. default "0xc0000000" if MMU
  167. default KERNEL_BASE_ADDR if !MMU
  168. config TASK_SIZE_BOOL
  169. bool "Set custom user task size"
  170. depends on ADVANCED_OPTIONS && MMU
  171. help
  172. This option allows you to set the amount of virtual address space
  173. allocated to user tasks. This can be useful in optimizing the
  174. virtual memory layout of the system.
  175. Say N here unless you know what you are doing.
  176. config TASK_SIZE
  177. hex "Size of user task space" if TASK_SIZE_BOOL
  178. default "0x80000000"
  179. choice
  180. prompt "Page size"
  181. default MICROBLAZE_4K_PAGES
  182. depends on ADVANCED_OPTIONS && !MMU
  183. help
  184. Select the kernel logical page size. Increasing the page size
  185. will reduce software overhead at each page boundary, allow
  186. hardware prefetch mechanisms to be more effective, and allow
  187. larger dma transfers increasing IO efficiency and reducing
  188. overhead. However the utilization of memory will increase.
  189. For example, each cached file will using a multiple of the
  190. page size to hold its contents and the difference between the
  191. end of file and the end of page is wasted.
  192. If unsure, choose 4K_PAGES.
  193. config MICROBLAZE_4K_PAGES
  194. bool "4k page size"
  195. config MICROBLAZE_8K_PAGES
  196. bool "8k page size"
  197. config MICROBLAZE_16K_PAGES
  198. bool "16k page size"
  199. config MICROBLAZE_32K_PAGES
  200. bool "32k page size"
  201. endchoice
  202. config KERNEL_PAD
  203. hex "Kernel PAD for unpacking" if ADVANCED_OPTIONS
  204. default "0x80000" if MMU
  205. endmenu
  206. source "mm/Kconfig"
  207. menu "Executable file formats"
  208. source "fs/Kconfig.binfmt"
  209. endmenu
  210. menu "Bus Options"
  211. config PCI
  212. bool "PCI support"
  213. config PCI_DOMAINS
  214. def_bool PCI
  215. config PCI_SYSCALL
  216. def_bool PCI
  217. config PCI_XILINX
  218. bool "Xilinx PCI host bridge support"
  219. depends on PCI
  220. source "drivers/pci/Kconfig"
  221. endmenu
  222. source "net/Kconfig"
  223. source "drivers/Kconfig"
  224. source "fs/Kconfig"
  225. source "arch/microblaze/Kconfig.debug"
  226. source "security/Kconfig"
  227. source "crypto/Kconfig"
  228. source "lib/Kconfig"