2
1

Config.in.arm 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454
  1. # arm cpu features
  2. config BR2_ARM_CPU_HAS_NEON
  3. bool
  4. # for some cores, NEON support is optional
  5. config BR2_ARM_CPU_MAYBE_HAS_NEON
  6. bool
  7. # for some cores, VFPv2 is optional
  8. config BR2_ARM_CPU_MAYBE_HAS_VFPV2
  9. bool
  10. config BR2_ARM_CPU_HAS_VFPV2
  11. bool
  12. # for some cores, VFPv3 is optional
  13. config BR2_ARM_CPU_MAYBE_HAS_VFPV3
  14. bool
  15. select BR2_ARM_CPU_MAYBE_HAS_VFPV2
  16. config BR2_ARM_CPU_HAS_VFPV3
  17. bool
  18. select BR2_ARM_CPU_HAS_VFPV2
  19. # for some cores, VFPv4 is optional
  20. config BR2_ARM_CPU_MAYBE_HAS_VFPV4
  21. bool
  22. select BR2_ARM_CPU_MAYBE_HAS_VFPV3
  23. config BR2_ARM_CPU_HAS_VFPV4
  24. bool
  25. select BR2_ARM_CPU_HAS_VFPV3
  26. config BR2_ARM_CPU_HAS_ARM
  27. bool
  28. config BR2_ARM_CPU_HAS_THUMB
  29. bool
  30. config BR2_ARM_CPU_HAS_THUMB2
  31. bool
  32. config BR2_ARM_CPU_ARMV4
  33. bool
  34. config BR2_ARM_CPU_ARMV5
  35. bool
  36. config BR2_ARM_CPU_ARMV6
  37. bool
  38. config BR2_ARM_CPU_ARMV7A
  39. bool
  40. choice
  41. prompt "Target Architecture Variant"
  42. depends on BR2_arm || BR2_armeb
  43. default BR2_arm926t
  44. help
  45. Specific CPU variant to use
  46. config BR2_arm920t
  47. bool "arm920t"
  48. select BR2_ARM_CPU_HAS_ARM
  49. select BR2_ARM_CPU_HAS_THUMB
  50. select BR2_ARM_CPU_ARMV4
  51. select BR2_ARCH_HAS_MMU_OPTIONAL
  52. config BR2_arm922t
  53. bool "arm922t"
  54. select BR2_ARM_CPU_HAS_ARM
  55. select BR2_ARM_CPU_HAS_THUMB
  56. select BR2_ARM_CPU_ARMV4
  57. select BR2_ARCH_HAS_MMU_OPTIONAL
  58. config BR2_arm926t
  59. bool "arm926t"
  60. select BR2_ARM_CPU_HAS_ARM
  61. select BR2_ARM_CPU_MAYBE_HAS_VFPV2
  62. select BR2_ARM_CPU_HAS_THUMB
  63. select BR2_ARM_CPU_ARMV5
  64. select BR2_ARCH_HAS_MMU_OPTIONAL
  65. config BR2_arm1136j_s
  66. bool "arm1136j-s"
  67. select BR2_ARM_CPU_HAS_ARM
  68. select BR2_ARM_CPU_HAS_THUMB
  69. select BR2_ARM_CPU_ARMV6
  70. select BR2_ARCH_HAS_MMU_OPTIONAL
  71. config BR2_arm1136jf_s
  72. bool "arm1136jf-s"
  73. select BR2_ARM_CPU_HAS_ARM
  74. select BR2_ARM_CPU_HAS_VFPV2
  75. select BR2_ARM_CPU_HAS_THUMB
  76. select BR2_ARM_CPU_ARMV6
  77. select BR2_ARCH_HAS_MMU_OPTIONAL
  78. config BR2_arm1176jz_s
  79. bool "arm1176jz-s"
  80. select BR2_ARM_CPU_HAS_ARM
  81. select BR2_ARM_CPU_HAS_THUMB
  82. select BR2_ARM_CPU_ARMV6
  83. select BR2_ARCH_HAS_MMU_OPTIONAL
  84. config BR2_arm1176jzf_s
  85. bool "arm1176jzf-s"
  86. select BR2_ARM_CPU_HAS_ARM
  87. select BR2_ARM_CPU_HAS_VFPV2
  88. select BR2_ARM_CPU_HAS_THUMB
  89. select BR2_ARM_CPU_ARMV6
  90. select BR2_ARCH_HAS_MMU_OPTIONAL
  91. config BR2_cortex_a5
  92. bool "cortex-A5"
  93. select BR2_ARM_CPU_HAS_ARM
  94. select BR2_ARM_CPU_MAYBE_HAS_NEON
  95. select BR2_ARM_CPU_MAYBE_HAS_VFPV4
  96. select BR2_ARM_CPU_HAS_THUMB2
  97. select BR2_ARM_CPU_ARMV7A
  98. select BR2_ARCH_HAS_MMU_OPTIONAL
  99. config BR2_cortex_a7
  100. bool "cortex-A7"
  101. select BR2_ARM_CPU_HAS_ARM
  102. select BR2_ARM_CPU_HAS_NEON
  103. select BR2_ARM_CPU_HAS_VFPV4
  104. select BR2_ARM_CPU_HAS_THUMB2
  105. select BR2_ARM_CPU_ARMV7A
  106. select BR2_ARCH_HAS_MMU_OPTIONAL
  107. config BR2_cortex_a8
  108. bool "cortex-A8"
  109. select BR2_ARM_CPU_HAS_ARM
  110. select BR2_ARM_CPU_HAS_NEON
  111. select BR2_ARM_CPU_HAS_VFPV3
  112. select BR2_ARM_CPU_HAS_THUMB2
  113. select BR2_ARM_CPU_ARMV7A
  114. select BR2_ARCH_HAS_MMU_OPTIONAL
  115. config BR2_cortex_a9
  116. bool "cortex-A9"
  117. select BR2_ARM_CPU_HAS_ARM
  118. select BR2_ARM_CPU_MAYBE_HAS_NEON
  119. select BR2_ARM_CPU_MAYBE_HAS_VFPV3
  120. select BR2_ARM_CPU_HAS_THUMB2
  121. select BR2_ARM_CPU_ARMV7A
  122. select BR2_ARCH_HAS_MMU_OPTIONAL
  123. config BR2_cortex_a12
  124. bool "cortex-A12"
  125. select BR2_ARM_CPU_HAS_ARM
  126. select BR2_ARM_CPU_HAS_NEON
  127. select BR2_ARM_CPU_HAS_VFPV4
  128. select BR2_ARM_CPU_HAS_THUMB2
  129. select BR2_ARM_CPU_ARMV7A
  130. select BR2_ARCH_HAS_MMU_OPTIONAL
  131. config BR2_cortex_a15
  132. bool "cortex-A15"
  133. select BR2_ARM_CPU_HAS_ARM
  134. select BR2_ARM_CPU_HAS_NEON
  135. select BR2_ARM_CPU_HAS_VFPV4
  136. select BR2_ARM_CPU_HAS_THUMB2
  137. select BR2_ARM_CPU_ARMV7A
  138. select BR2_ARCH_HAS_MMU_OPTIONAL
  139. config BR2_cortex_m3
  140. bool "cortex-M3"
  141. select BR2_ARM_CPU_HAS_THUMB
  142. select BR2_ARM_CPU_HAS_THUMB2
  143. config BR2_fa526
  144. bool "fa526/626"
  145. select BR2_ARM_CPU_HAS_ARM
  146. select BR2_ARM_CPU_ARMV4
  147. select BR2_ARCH_HAS_MMU_OPTIONAL
  148. config BR2_pj4
  149. bool "pj4"
  150. select BR2_ARM_CPU_HAS_ARM
  151. select BR2_ARM_CPU_HAS_VFPV3
  152. select BR2_ARM_CPU_ARMV7A
  153. select BR2_ARCH_HAS_MMU_OPTIONAL
  154. config BR2_strongarm
  155. bool "strongarm sa110/sa1100"
  156. select BR2_ARM_CPU_HAS_ARM
  157. select BR2_ARM_CPU_ARMV4
  158. select BR2_ARCH_HAS_MMU_OPTIONAL
  159. config BR2_xscale
  160. bool "xscale"
  161. select BR2_ARM_CPU_HAS_ARM
  162. select BR2_ARM_CPU_HAS_THUMB
  163. select BR2_ARM_CPU_ARMV5
  164. select BR2_ARCH_HAS_MMU_OPTIONAL
  165. config BR2_iwmmxt
  166. bool "iwmmxt"
  167. select BR2_ARM_CPU_HAS_ARM
  168. select BR2_ARM_CPU_ARMV5
  169. select BR2_ARCH_HAS_MMU_OPTIONAL
  170. endchoice
  171. choice
  172. prompt "Target ABI"
  173. depends on BR2_arm || BR2_armeb
  174. default BR2_ARM_EABIHF if BR2_ARM_CPU_HAS_VFPV2
  175. default BR2_ARM_EABI
  176. help
  177. Application Binary Interface to use. The Application Binary
  178. Interface describes the calling conventions (how arguments
  179. are passed to functions, how the return value is passed, how
  180. system calls are made, etc.).
  181. config BR2_ARM_EABI
  182. bool "EABI"
  183. help
  184. The EABI is currently the standard ARM ABI, which is used in
  185. most projects. It supports both the 'soft' floating point
  186. model (in which floating point instructions are emulated in
  187. software) and the 'softfp' floating point model (in which
  188. floating point instructions are executed using an hardware
  189. floating point unit, but floating point arguments to
  190. functions are passed in integer registers).
  191. The 'softfp' floating point model is link-compatible with
  192. the 'soft' floating point model, i.e you can link a library
  193. built 'soft' with some other code built 'softfp'.
  194. However, passing the floating point arguments in integer
  195. registers is a bit inefficient, so if your ARM processor has
  196. a floating point unit, and you don't have pre-compiled
  197. 'soft' or 'softfp' code, using the EABIhf ABI will provide
  198. better floating point performances.
  199. If your processor does not have a floating point unit, then
  200. you must use this ABI.
  201. config BR2_ARM_EABIHF
  202. bool "EABIhf"
  203. depends on BR2_ARM_CPU_MAYBE_HAS_VFPV2 || BR2_ARM_CPU_HAS_VFPV2
  204. help
  205. The EABIhf is an extension of EABI which supports the 'hard'
  206. floating point model. This model uses the floating point
  207. unit to execute floating point instructions, and passes
  208. floating point arguments in floating point registers.
  209. It is more efficient than EABI for floating point related
  210. workload. However, it does not allow to link against code
  211. that has been pre-built for the 'soft' or 'softfp' floating
  212. point models.
  213. If your processor has a floating point unit, and you don't
  214. depend on existing pre-compiled code, this option is most
  215. likely the best choice.
  216. endchoice
  217. config BR2_ARM_ENABLE_NEON
  218. bool "Enable NEON SIMD extension support"
  219. depends on BR2_ARM_CPU_MAYBE_HAS_NEON
  220. select BR2_ARM_CPU_HAS_NEON
  221. help
  222. For some CPU cores, the NEON SIMD extension is optional.
  223. Select this option if you are certain your particular
  224. implementation has NEON support and you want to use it.
  225. choice
  226. prompt "Floating point strategy"
  227. depends on BR2_ARM_EABI || BR2_ARM_EABIHF
  228. default BR2_ARM_FPU_VFPV4D16 if BR2_ARM_CPU_HAS_VFPV4
  229. default BR2_ARM_FPU_VFPV3D16 if BR2_ARM_CPU_HAS_VFPV3
  230. default BR2_ARM_FPU_VFPV2 if BR2_ARM_CPU_HAS_VFPV2
  231. default BR2_ARM_SOFT_FLOAT if !BR2_ARM_CPU_HAS_VFPV2
  232. config BR2_ARM_SOFT_FLOAT
  233. bool "Soft float"
  234. depends on BR2_ARM_EABI
  235. select BR2_SOFT_FLOAT
  236. help
  237. This option allows to use software emulated floating
  238. point. It should be used for ARM cores that do not include a
  239. Vector Floating Point unit, such as ARMv5 cores (ARM926 for
  240. example) or certain ARMv6 cores.
  241. config BR2_ARM_FPU_VFPV2
  242. bool "VFPv2"
  243. depends on BR2_ARM_CPU_HAS_VFPV2 || BR2_ARM_CPU_MAYBE_HAS_VFPV2
  244. help
  245. This option allows to use the VFPv2 floating point unit, as
  246. available in some ARMv5 processors (ARM926EJ-S) and some
  247. ARMv6 processors (ARM1136JF-S, ARM1176JZF-S and ARM11
  248. MPCore).
  249. Note that this option is also safe to use for newer cores
  250. such as Cortex-A, because the VFPv3 and VFPv4 units are
  251. backward compatible with VFPv2.
  252. config BR2_ARM_FPU_VFPV3
  253. bool "VFPv3"
  254. depends on BR2_ARM_CPU_HAS_VFPV3 || BR2_ARM_CPU_MAYBE_HAS_VFPV3
  255. help
  256. This option allows to use the VFPv3 floating point unit, as
  257. available in some ARMv7 processors (Cortex-A{8, 9}). This
  258. option requires a VFPv3 unit that has 32 double-precision
  259. registers, which is not necessarily the case in all SOCs
  260. based on Cortex-A{8, 9}. If you're unsure, use VFPv3-D16
  261. instead, which is guaranteed to work on all Cortex-A{8, 9}.
  262. Note that this option is also safe to use for newer cores
  263. that have a VFPv4 unit, because VFPv4 is backward compatible
  264. with VFPv3. They must of course also have 32
  265. double-precision registers.
  266. config BR2_ARM_FPU_VFPV3D16
  267. bool "VFPv3-D16"
  268. depends on BR2_ARM_CPU_HAS_VFPV3 || BR2_ARM_CPU_MAYBE_HAS_VFPV3
  269. help
  270. This option allows to use the VFPv3 floating point unit, as
  271. available in some ARMv7 processors (Cortex-A{8, 9}). This
  272. option requires a VFPv3 unit that has 16 double-precision
  273. registers, which is generally the case in all SOCs based on
  274. Cortex-A{8, 9}, even though VFPv3 is technically optional on
  275. Cortex-A9. This is the safest option for those cores.
  276. Note that this option is also safe to use for newer cores
  277. such that have a VFPv4 unit, because the VFPv4 is backward
  278. compatible with VFPv3.
  279. config BR2_ARM_FPU_VFPV4
  280. bool "VFPv4"
  281. depends on BR2_ARM_CPU_HAS_VFPV4 || BR2_ARM_CPU_MAYBE_HAS_VFPV4
  282. help
  283. This option allows to use the VFPv4 floating point unit, as
  284. available in some ARMv7 processors (Cortex-A{5, 7, 12,
  285. 15}). This option requires a VFPv4 unit that has 32
  286. double-precision registers, which is not necessarily the
  287. case in all SOCs based on Cortex-A{5, 7, 12, 15}. If you're
  288. unsure, you should probably use VFPv4-D16 instead.
  289. Note that if you want binary code that works on all ARMv7
  290. cores, including the earlier Cortex-A{8, 9}, you should
  291. instead select VFPv3.
  292. config BR2_ARM_FPU_VFPV4D16
  293. bool "VFPv4-D16"
  294. depends on BR2_ARM_CPU_HAS_VFPV4 || BR2_ARM_CPU_MAYBE_HAS_VFPV4
  295. help
  296. This option allows to use the VFPv4 floating point unit, as
  297. available in some ARMv7 processors (Cortex-A{5, 7, 12,
  298. 15}). This option requires a VFPv4 unit that has 16
  299. double-precision registers, which is always available on
  300. Cortex-A12 and Cortex-A15, but optional on Cortex-A5 and
  301. Cortex-A7.
  302. Note that if you want binary code that works on all ARMv7
  303. cores, including the earlier Cortex-A{8, 9}, you should
  304. instead select VFPv3-D16.
  305. config BR2_ARM_FPU_NEON
  306. bool "NEON"
  307. depends on BR2_ARM_CPU_HAS_NEON
  308. help
  309. This option allows to use the NEON SIMD unit, as available
  310. in some ARMv7 processors, as a floating-point unit. It
  311. should however be noted that using NEON for floating point
  312. operations doesn't provide a complete compatibility with the
  313. IEEE 754.
  314. config BR2_ARM_FPU_NEON_VFPV4
  315. bool "NEON/VFPv4"
  316. depends on BR2_ARM_CPU_HAS_VFPV4 || BR2_ARM_CPU_MAYBE_HAS_VFPV4
  317. depends on BR2_ARM_CPU_HAS_NEON
  318. help
  319. This option allows to use both the VFPv4 and the NEON SIMD
  320. units for floating point operations. Note that some ARMv7
  321. cores do not necessarily have VFPv4 and/or NEON support, for
  322. example on Cortex-A5 and Cortex-A7, support for VFPv4 and
  323. NEON is optional.
  324. endchoice
  325. choice
  326. prompt "ARM instruction set"
  327. config BR2_ARM_INSTRUCTIONS_ARM
  328. bool "ARM"
  329. depends on BR2_ARM_CPU_HAS_ARM
  330. help
  331. This option instructs the compiler to generate regular ARM
  332. instructions, that are all 32 bits wide.
  333. config BR2_ARM_INSTRUCTIONS_THUMB
  334. bool "Thumb"
  335. depends on BR2_ARM_CPU_HAS_THUMB
  336. # Thumb-1 and VFP are not compatible
  337. depends on BR2_ARM_SOFT_FLOAT
  338. help
  339. This option instructions the compiler to generate Thumb
  340. instructions, which allows to mix 16 bits instructions and
  341. 32 bits instructions. This generally provides a much smaller
  342. compiled binary size.
  343. comment "Thumb1 is not compatible with VFP"
  344. depends on BR2_ARM_CPU_HAS_THUMB
  345. depends on !BR2_ARM_SOFT_FLOAT
  346. config BR2_ARM_INSTRUCTIONS_THUMB2
  347. bool "Thumb2"
  348. depends on BR2_ARM_CPU_HAS_THUMB2
  349. help
  350. This option instructions the compiler to generate Thumb2
  351. instructions, which allows to mix 16 bits instructions and
  352. 32 bits instructions. This generally provides a much smaller
  353. compiled binary size.
  354. endchoice
  355. config BR2_ARCH
  356. default "arm" if BR2_arm
  357. default "armeb" if BR2_armeb
  358. config BR2_ENDIAN
  359. default "LITTLE" if BR2_arm
  360. default "BIG" if BR2_armeb
  361. config BR2_ARCH_HAS_ATOMICS
  362. default y
  363. config BR2_GCC_TARGET_CPU
  364. default "arm920t" if BR2_arm920t
  365. default "arm922t" if BR2_arm922t
  366. default "arm926ej-s" if BR2_arm926t
  367. default "arm1136j-s" if BR2_arm1136j_s
  368. default "arm1136jf-s" if BR2_arm1136jf_s
  369. default "arm1176jz-s" if BR2_arm1176jz_s
  370. default "arm1176jzf-s" if BR2_arm1176jzf_s
  371. default "cortex-a5" if BR2_cortex_a5
  372. default "cortex-a7" if BR2_cortex_a7
  373. default "cortex-a8" if BR2_cortex_a8
  374. default "cortex-a9" if BR2_cortex_a9
  375. default "cortex-a12" if BR2_cortex_a12
  376. default "cortex-a15" if BR2_cortex_a15
  377. default "cortex-m3" if BR2_cortex_m3
  378. default "fa526" if BR2_fa526
  379. default "marvell-pj4" if BR2_pj4
  380. default "strongarm" if BR2_strongarm
  381. default "xscale" if BR2_xscale
  382. default "iwmmxt" if BR2_iwmmxt
  383. config BR2_GCC_TARGET_ABI
  384. default "aapcs-linux"
  385. config BR2_GCC_TARGET_FPU
  386. default "vfp" if BR2_ARM_FPU_VFPV2
  387. default "vfpv3" if BR2_ARM_FPU_VFPV3
  388. default "vfpv3-d16" if BR2_ARM_FPU_VFPV3D16
  389. default "vfpv4" if BR2_ARM_FPU_VFPV4
  390. default "vfpv4-d16" if BR2_ARM_FPU_VFPV4D16
  391. default "neon" if BR2_ARM_FPU_NEON
  392. default "neon-vfpv4" if BR2_ARM_FPU_NEON_VFPV4
  393. config BR2_GCC_TARGET_FLOAT_ABI
  394. default "soft" if BR2_ARM_SOFT_FLOAT
  395. default "softfp" if !BR2_ARM_SOFT_FLOAT && BR2_ARM_EABI
  396. default "hard" if !BR2_ARM_SOFT_FLOAT && BR2_ARM_EABIHF
  397. config BR2_GCC_TARGET_MODE
  398. default "arm" if BR2_ARM_INSTRUCTIONS_ARM
  399. default "thumb" if BR2_ARM_INSTRUCTIONS_THUMB || BR2_ARM_INSTRUCTIONS_THUMB2