2
1

Config.in.arm 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839
  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, the FPU is optional
  8. config BR2_ARM_CPU_MAYBE_HAS_FPU
  9. bool
  10. config BR2_ARM_CPU_HAS_FPU
  11. bool
  12. # for some cores, VFPv2 is optional
  13. config BR2_ARM_CPU_MAYBE_HAS_VFPV2
  14. bool
  15. select BR2_ARM_CPU_MAYBE_HAS_FPU
  16. config BR2_ARM_CPU_HAS_VFPV2
  17. bool
  18. select BR2_ARM_CPU_HAS_FPU
  19. # for some cores, VFPv3 is optional
  20. config BR2_ARM_CPU_MAYBE_HAS_VFPV3
  21. bool
  22. select BR2_ARM_CPU_MAYBE_HAS_VFPV2
  23. config BR2_ARM_CPU_HAS_VFPV3
  24. bool
  25. select BR2_ARM_CPU_HAS_VFPV2
  26. # for some cores, VFPv4 is optional
  27. config BR2_ARM_CPU_MAYBE_HAS_VFPV4
  28. bool
  29. select BR2_ARM_CPU_MAYBE_HAS_VFPV3
  30. config BR2_ARM_CPU_HAS_VFPV4
  31. bool
  32. select BR2_ARM_CPU_HAS_VFPV3
  33. # FPv4 is always optional
  34. config BR2_ARM_CPU_MAYBE_HAS_FPV4
  35. bool
  36. select BR2_ARM_CPU_MAYBE_HAS_FPU
  37. config BR2_ARM_CPU_HAS_FPV4
  38. bool
  39. select BR2_ARM_CPU_HAS_FPU
  40. # FPv5 is always optional
  41. config BR2_ARM_CPU_MAYBE_HAS_FPV5
  42. bool
  43. select BR2_ARM_CPU_MAYBE_HAS_FPV4
  44. config BR2_ARM_CPU_HAS_FPV5
  45. bool
  46. select BR2_ARM_CPU_HAS_FPV4
  47. config BR2_ARM_CPU_HAS_FP_ARMV8
  48. bool
  49. select BR2_ARM_CPU_HAS_VFPV4
  50. config BR2_ARM_CPU_HAS_ARM
  51. bool
  52. config BR2_ARM_CPU_HAS_THUMB
  53. bool
  54. config BR2_ARM_CPU_HAS_THUMB2
  55. bool
  56. config BR2_ARM_CPU_ARMV4
  57. bool
  58. config BR2_ARM_CPU_ARMV5
  59. bool
  60. config BR2_ARM_CPU_ARMV6
  61. bool
  62. config BR2_ARM_CPU_ARMV7A
  63. bool
  64. config BR2_ARM_CPU_ARMV7M
  65. bool
  66. config BR2_ARM_CPU_ARMV8A
  67. bool
  68. choice
  69. prompt "Target Architecture Variant"
  70. default BR2_cortex_a53 if BR2_ARCH_IS_64
  71. default BR2_arm926t
  72. help
  73. Specific CPU variant to use
  74. if !BR2_ARCH_IS_64
  75. comment "armv4 cores"
  76. config BR2_arm920t
  77. bool "arm920t"
  78. select BR2_ARM_CPU_HAS_ARM
  79. select BR2_ARM_CPU_HAS_THUMB
  80. select BR2_ARM_CPU_ARMV4
  81. select BR2_ARCH_HAS_MMU_OPTIONAL
  82. config BR2_arm922t
  83. bool "arm922t"
  84. select BR2_ARM_CPU_HAS_ARM
  85. select BR2_ARM_CPU_HAS_THUMB
  86. select BR2_ARM_CPU_ARMV4
  87. select BR2_ARCH_HAS_MMU_OPTIONAL
  88. config BR2_fa526
  89. bool "fa526/626"
  90. select BR2_ARM_CPU_HAS_ARM
  91. select BR2_ARM_CPU_ARMV4
  92. select BR2_ARCH_HAS_MMU_OPTIONAL
  93. config BR2_strongarm
  94. bool "strongarm sa110/sa1100"
  95. select BR2_ARM_CPU_HAS_ARM
  96. select BR2_ARM_CPU_ARMV4
  97. select BR2_ARCH_HAS_MMU_OPTIONAL
  98. comment "armv5 cores"
  99. config BR2_arm926t
  100. bool "arm926t"
  101. select BR2_ARM_CPU_HAS_ARM
  102. select BR2_ARM_CPU_MAYBE_HAS_VFPV2
  103. select BR2_ARM_CPU_HAS_THUMB
  104. select BR2_ARM_CPU_ARMV5
  105. select BR2_ARCH_HAS_MMU_OPTIONAL
  106. config BR2_iwmmxt
  107. bool "iwmmxt"
  108. select BR2_ARM_CPU_HAS_ARM
  109. select BR2_ARM_CPU_ARMV5
  110. select BR2_ARCH_HAS_MMU_OPTIONAL
  111. config BR2_xscale
  112. bool "xscale"
  113. select BR2_ARM_CPU_HAS_ARM
  114. select BR2_ARM_CPU_HAS_THUMB
  115. select BR2_ARM_CPU_ARMV5
  116. select BR2_ARCH_HAS_MMU_OPTIONAL
  117. comment "armv6 cores"
  118. config BR2_arm1136j_s
  119. bool "arm1136j-s"
  120. select BR2_ARM_CPU_HAS_ARM
  121. select BR2_ARM_CPU_HAS_THUMB
  122. select BR2_ARM_CPU_ARMV6
  123. select BR2_ARCH_HAS_MMU_OPTIONAL
  124. config BR2_arm1136jf_s
  125. bool "arm1136jf-s"
  126. select BR2_ARM_CPU_HAS_ARM
  127. select BR2_ARM_CPU_HAS_VFPV2
  128. select BR2_ARM_CPU_HAS_THUMB
  129. select BR2_ARM_CPU_ARMV6
  130. select BR2_ARCH_HAS_MMU_OPTIONAL
  131. config BR2_arm1176jz_s
  132. bool "arm1176jz-s"
  133. select BR2_ARM_CPU_HAS_ARM
  134. select BR2_ARM_CPU_HAS_THUMB
  135. select BR2_ARM_CPU_ARMV6
  136. select BR2_ARCH_HAS_MMU_OPTIONAL
  137. config BR2_arm1176jzf_s
  138. bool "arm1176jzf-s"
  139. select BR2_ARM_CPU_HAS_ARM
  140. select BR2_ARM_CPU_HAS_VFPV2
  141. select BR2_ARM_CPU_HAS_THUMB
  142. select BR2_ARM_CPU_ARMV6
  143. select BR2_ARCH_HAS_MMU_OPTIONAL
  144. config BR2_arm11mpcore
  145. bool "mpcore"
  146. select BR2_ARM_CPU_HAS_ARM
  147. select BR2_ARM_CPU_MAYBE_HAS_VFPV2
  148. select BR2_ARM_CPU_HAS_THUMB
  149. select BR2_ARM_CPU_ARMV6
  150. select BR2_ARCH_HAS_MMU_OPTIONAL
  151. comment "armv7a cores"
  152. config BR2_cortex_a5
  153. bool "cortex-A5"
  154. select BR2_ARM_CPU_HAS_ARM
  155. select BR2_ARM_CPU_MAYBE_HAS_NEON
  156. select BR2_ARM_CPU_MAYBE_HAS_VFPV4
  157. select BR2_ARM_CPU_HAS_THUMB2
  158. select BR2_ARM_CPU_ARMV7A
  159. select BR2_ARCH_HAS_MMU_OPTIONAL
  160. config BR2_cortex_a7
  161. bool "cortex-A7"
  162. select BR2_ARM_CPU_HAS_ARM
  163. select BR2_ARM_CPU_HAS_NEON
  164. select BR2_ARM_CPU_HAS_VFPV4
  165. select BR2_ARM_CPU_HAS_THUMB2
  166. select BR2_ARM_CPU_ARMV7A
  167. select BR2_ARCH_HAS_MMU_OPTIONAL
  168. config BR2_cortex_a8
  169. bool "cortex-A8"
  170. select BR2_ARM_CPU_HAS_ARM
  171. select BR2_ARM_CPU_HAS_NEON
  172. select BR2_ARM_CPU_HAS_VFPV3
  173. select BR2_ARM_CPU_HAS_THUMB2
  174. select BR2_ARM_CPU_ARMV7A
  175. select BR2_ARCH_HAS_MMU_OPTIONAL
  176. config BR2_cortex_a9
  177. bool "cortex-A9"
  178. select BR2_ARM_CPU_HAS_ARM
  179. select BR2_ARM_CPU_MAYBE_HAS_NEON
  180. select BR2_ARM_CPU_MAYBE_HAS_VFPV3
  181. select BR2_ARM_CPU_HAS_THUMB2
  182. select BR2_ARM_CPU_ARMV7A
  183. select BR2_ARCH_HAS_MMU_OPTIONAL
  184. config BR2_cortex_a12
  185. bool "cortex-A12"
  186. select BR2_ARM_CPU_HAS_ARM
  187. select BR2_ARM_CPU_HAS_NEON
  188. select BR2_ARM_CPU_HAS_VFPV4
  189. select BR2_ARM_CPU_HAS_THUMB2
  190. select BR2_ARM_CPU_ARMV7A
  191. select BR2_ARCH_HAS_MMU_OPTIONAL
  192. config BR2_cortex_a15
  193. bool "cortex-A15"
  194. select BR2_ARM_CPU_HAS_ARM
  195. select BR2_ARM_CPU_HAS_NEON
  196. select BR2_ARM_CPU_HAS_VFPV4
  197. select BR2_ARM_CPU_HAS_THUMB2
  198. select BR2_ARM_CPU_ARMV7A
  199. select BR2_ARCH_HAS_MMU_OPTIONAL
  200. config BR2_cortex_a15_a7
  201. bool "cortex-A15/A7 big.LITTLE"
  202. select BR2_ARM_CPU_HAS_ARM
  203. select BR2_ARM_CPU_HAS_NEON
  204. select BR2_ARM_CPU_HAS_VFPV4
  205. select BR2_ARM_CPU_HAS_THUMB2
  206. select BR2_ARM_CPU_ARMV7A
  207. select BR2_ARCH_HAS_MMU_OPTIONAL
  208. select BR2_ARCH_NEEDS_GCC_AT_LEAST_4_9
  209. config BR2_cortex_a17
  210. bool "cortex-A17"
  211. select BR2_ARM_CPU_HAS_ARM
  212. select BR2_ARM_CPU_HAS_NEON
  213. select BR2_ARM_CPU_HAS_VFPV4
  214. select BR2_ARM_CPU_HAS_THUMB2
  215. select BR2_ARM_CPU_ARMV7A
  216. select BR2_ARCH_HAS_MMU_OPTIONAL
  217. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  218. config BR2_cortex_a17_a7
  219. bool "cortex-A17/A7 big.LITTLE"
  220. select BR2_ARM_CPU_HAS_ARM
  221. select BR2_ARM_CPU_HAS_NEON
  222. select BR2_ARM_CPU_HAS_VFPV4
  223. select BR2_ARM_CPU_HAS_THUMB2
  224. select BR2_ARM_CPU_ARMV7A
  225. select BR2_ARCH_HAS_MMU_OPTIONAL
  226. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  227. config BR2_pj4
  228. bool "pj4"
  229. select BR2_ARM_CPU_HAS_ARM
  230. select BR2_ARM_CPU_HAS_VFPV3
  231. select BR2_ARM_CPU_ARMV7A
  232. select BR2_ARCH_HAS_MMU_OPTIONAL
  233. comment "armv7m cores"
  234. config BR2_cortex_m3
  235. bool "cortex-M3"
  236. select BR2_ARM_CPU_HAS_THUMB2
  237. select BR2_ARM_CPU_ARMV7M
  238. config BR2_cortex_m4
  239. bool "cortex-M4"
  240. select BR2_ARM_CPU_HAS_THUMB2
  241. select BR2_ARM_CPU_MAYBE_HAS_FPV4
  242. select BR2_ARM_CPU_ARMV7M
  243. config BR2_cortex_m7
  244. bool "cortex-M7"
  245. select BR2_ARM_CPU_HAS_THUMB2
  246. select BR2_ARM_CPU_MAYBE_HAS_FPV5
  247. select BR2_ARM_CPU_ARMV7M
  248. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  249. endif # !BR2_ARCH_IS_64
  250. comment "armv8 cores"
  251. config BR2_cortex_a32
  252. bool "cortex-A32"
  253. depends on !BR2_ARCH_IS_64
  254. select BR2_ARM_CPU_HAS_ARM
  255. select BR2_ARM_CPU_HAS_NEON
  256. select BR2_ARM_CPU_HAS_THUMB2
  257. select BR2_ARM_CPU_HAS_FP_ARMV8
  258. select BR2_ARM_CPU_ARMV8A
  259. select BR2_ARCH_HAS_MMU_OPTIONAL
  260. select BR2_ARCH_NEEDS_GCC_AT_LEAST_6
  261. config BR2_cortex_a35
  262. bool "cortex-A35"
  263. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  264. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  265. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  266. select BR2_ARM_CPU_HAS_FP_ARMV8
  267. select BR2_ARM_CPU_ARMV8A
  268. select BR2_ARCH_HAS_MMU_OPTIONAL
  269. select BR2_ARCH_NEEDS_GCC_AT_LEAST_6
  270. config BR2_cortex_a53
  271. bool "cortex-A53"
  272. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  273. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  274. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  275. select BR2_ARM_CPU_HAS_FP_ARMV8
  276. select BR2_ARM_CPU_ARMV8A
  277. select BR2_ARCH_HAS_MMU_OPTIONAL
  278. config BR2_cortex_a57
  279. bool "cortex-A57"
  280. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  281. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  282. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  283. select BR2_ARM_CPU_HAS_FP_ARMV8
  284. select BR2_ARM_CPU_ARMV8A
  285. select BR2_ARCH_HAS_MMU_OPTIONAL
  286. config BR2_cortex_a57_a53
  287. bool "cortex-A57/A53 big.LITTLE"
  288. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  289. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  290. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  291. select BR2_ARM_CPU_HAS_FP_ARMV8
  292. select BR2_ARM_CPU_ARMV8A
  293. select BR2_ARCH_HAS_MMU_OPTIONAL
  294. select BR2_ARCH_NEEDS_GCC_AT_LEAST_6
  295. config BR2_cortex_a72
  296. bool "cortex-A72"
  297. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  298. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  299. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  300. select BR2_ARM_CPU_HAS_FP_ARMV8
  301. select BR2_ARM_CPU_ARMV8A
  302. select BR2_ARCH_HAS_MMU_OPTIONAL
  303. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  304. config BR2_cortex_a72_a53
  305. bool "cortex-A72/A53 big.LITTLE"
  306. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  307. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  308. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  309. select BR2_ARM_CPU_HAS_FP_ARMV8
  310. select BR2_ARM_CPU_ARMV8A
  311. select BR2_ARCH_HAS_MMU_OPTIONAL
  312. select BR2_ARCH_NEEDS_GCC_AT_LEAST_6
  313. config BR2_cortex_a73
  314. bool "cortex-A73"
  315. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  316. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  317. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  318. select BR2_ARM_CPU_HAS_FP_ARMV8
  319. select BR2_ARM_CPU_ARMV8A
  320. select BR2_ARCH_HAS_MMU_OPTIONAL
  321. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  322. config BR2_cortex_a73_a35
  323. bool "cortex-A73/A35 big.LITTLE"
  324. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  325. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  326. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  327. select BR2_ARM_CPU_HAS_FP_ARMV8
  328. select BR2_ARM_CPU_ARMV8A
  329. select BR2_ARCH_HAS_MMU_OPTIONAL
  330. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  331. config BR2_cortex_a73_a53
  332. bool "cortex-A73/A53 big.LITTLE"
  333. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  334. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  335. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  336. select BR2_ARM_CPU_HAS_FP_ARMV8
  337. select BR2_ARM_CPU_ARMV8A
  338. select BR2_ARCH_HAS_MMU_OPTIONAL
  339. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  340. config BR2_exynos_m1
  341. bool "exynos-m1"
  342. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  343. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  344. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  345. select BR2_ARM_CPU_HAS_FP_ARMV8
  346. select BR2_ARM_CPU_ARMV8A
  347. select BR2_ARCH_HAS_MMU_OPTIONAL
  348. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  349. if BR2_ARCH_IS_64
  350. config BR2_falkor
  351. bool "falkor"
  352. select BR2_ARM_CPU_HAS_FP_ARMV8
  353. select BR2_ARM_CPU_ARMV8A
  354. select BR2_ARCH_HAS_MMU_OPTIONAL
  355. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  356. config BR2_qdf24xx
  357. bool "qdf24xx"
  358. select BR2_ARM_CPU_HAS_FP_ARMV8
  359. select BR2_ARM_CPU_ARMV8A
  360. select BR2_ARCH_HAS_MMU_OPTIONAL
  361. select BR2_ARCH_NEEDS_GCC_AT_LEAST_6
  362. config BR2_thunderx
  363. bool "thunderx"
  364. select BR2_ARM_CPU_HAS_FP_ARMV8
  365. select BR2_ARM_CPU_ARMV8A
  366. select BR2_ARCH_HAS_MMU_OPTIONAL
  367. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  368. config BR2_thunderxt81
  369. bool "thunderxt81"
  370. select BR2_ARM_CPU_HAS_FP_ARMV8
  371. select BR2_ARM_CPU_ARMV8A
  372. select BR2_ARCH_HAS_MMU_OPTIONAL
  373. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  374. config BR2_thunderxt83
  375. bool "thunderxt83"
  376. select BR2_ARM_CPU_HAS_FP_ARMV8
  377. select BR2_ARM_CPU_ARMV8A
  378. select BR2_ARCH_HAS_MMU_OPTIONAL
  379. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  380. config BR2_thunderxt88
  381. bool "thunderxt88"
  382. select BR2_ARM_CPU_HAS_FP_ARMV8
  383. select BR2_ARM_CPU_ARMV8A
  384. select BR2_ARCH_HAS_MMU_OPTIONAL
  385. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  386. config BR2_thunderxt88p1
  387. bool "thunderxt88p1"
  388. select BR2_ARM_CPU_HAS_FP_ARMV8
  389. select BR2_ARM_CPU_ARMV8A
  390. select BR2_ARCH_HAS_MMU_OPTIONAL
  391. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  392. endif # BR2_ARCH_IS_64
  393. config BR2_xgene1
  394. bool "xgene1"
  395. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  396. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  397. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  398. select BR2_ARM_CPU_HAS_FP_ARMV8
  399. select BR2_ARM_CPU_ARMV8A
  400. select BR2_ARCH_HAS_MMU_OPTIONAL
  401. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  402. if BR2_ARCH_IS_64
  403. comment "armv8.1a cores"
  404. config BR2_thunderx2t99
  405. bool "thunderx2t99"
  406. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  407. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  408. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  409. select BR2_ARM_CPU_HAS_FP_ARMV8
  410. select BR2_ARM_CPU_ARMV8A
  411. select BR2_ARCH_HAS_MMU_OPTIONAL
  412. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  413. config BR2_thunderx2t99p1
  414. bool "thunderx2t99p1"
  415. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  416. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  417. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  418. select BR2_ARM_CPU_HAS_FP_ARMV8
  419. select BR2_ARM_CPU_ARMV8A
  420. select BR2_ARCH_HAS_MMU_OPTIONAL
  421. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  422. config BR2_vulcan
  423. bool "vulcan"
  424. select BR2_ARM_CPU_HAS_ARM if !BR2_ARCH_IS_64
  425. select BR2_ARM_CPU_HAS_NEON if !BR2_ARCH_IS_64
  426. select BR2_ARM_CPU_HAS_THUMB2 if !BR2_ARCH_IS_64
  427. select BR2_ARM_CPU_HAS_FP_ARMV8
  428. select BR2_ARM_CPU_ARMV8A
  429. select BR2_ARCH_HAS_MMU_OPTIONAL
  430. select BR2_ARCH_NEEDS_GCC_AT_LEAST_7
  431. endif # BR2_ARCH_IS_64
  432. endchoice
  433. config BR2_ARM_ENABLE_NEON
  434. bool "Enable NEON SIMD extension support"
  435. depends on BR2_ARM_CPU_MAYBE_HAS_NEON
  436. select BR2_ARM_CPU_HAS_NEON
  437. help
  438. For some CPU cores, the NEON SIMD extension is optional.
  439. Select this option if you are certain your particular
  440. implementation has NEON support and you want to use it.
  441. config BR2_ARM_ENABLE_VFP
  442. bool "Enable VFP extension support"
  443. depends on BR2_ARM_CPU_MAYBE_HAS_FPU
  444. select BR2_ARM_CPU_HAS_FPV5 if BR2_ARM_CPU_MAYBE_HAS_FPV5
  445. select BR2_ARM_CPU_HAS_FPV4 if BR2_ARM_CPU_MAYBE_HAS_FPV4
  446. select BR2_ARM_CPU_HAS_VFPV4 if BR2_ARM_CPU_MAYBE_HAS_VFPV4
  447. select BR2_ARM_CPU_HAS_VFPV3 if BR2_ARM_CPU_MAYBE_HAS_VFPV3
  448. select BR2_ARM_CPU_HAS_VFPV2 if BR2_ARM_CPU_MAYBE_HAS_VFPV2
  449. help
  450. For some CPU cores, the VFP extension is optional. Select
  451. this option if you are certain your particular
  452. implementation has VFP support and you want to use it.
  453. choice
  454. prompt "Target ABI"
  455. default BR2_ARM_EABIHF if BR2_ARM_CPU_HAS_FPU
  456. default BR2_ARM_EABI
  457. depends on BR2_arm || BR2_armeb
  458. help
  459. Application Binary Interface to use. The Application Binary
  460. Interface describes the calling conventions (how arguments
  461. are passed to functions, how the return value is passed, how
  462. system calls are made, etc.).
  463. config BR2_ARM_EABI
  464. bool "EABI"
  465. help
  466. The EABI is currently the standard ARM ABI, which is used in
  467. most projects. It supports both the 'soft' floating point
  468. model (in which floating point instructions are emulated in
  469. software) and the 'softfp' floating point model (in which
  470. floating point instructions are executed using an hardware
  471. floating point unit, but floating point arguments to
  472. functions are passed in integer registers).
  473. The 'softfp' floating point model is link-compatible with
  474. the 'soft' floating point model, i.e you can link a library
  475. built 'soft' with some other code built 'softfp'.
  476. However, passing the floating point arguments in integer
  477. registers is a bit inefficient, so if your ARM processor has
  478. a floating point unit, and you don't have pre-compiled
  479. 'soft' or 'softfp' code, using the EABIhf ABI will provide
  480. better floating point performances.
  481. If your processor does not have a floating point unit, then
  482. you must use this ABI.
  483. config BR2_ARM_EABIHF
  484. bool "EABIhf"
  485. depends on BR2_ARM_CPU_HAS_FPU
  486. help
  487. The EABIhf is an extension of EABI which supports the 'hard'
  488. floating point model. This model uses the floating point
  489. unit to execute floating point instructions, and passes
  490. floating point arguments in floating point registers.
  491. It is more efficient than EABI for floating point related
  492. workload. However, it does not allow to link against code
  493. that has been pre-built for the 'soft' or 'softfp' floating
  494. point models.
  495. If your processor has a floating point unit, and you don't
  496. depend on existing pre-compiled code, this option is most
  497. likely the best choice.
  498. endchoice
  499. choice
  500. prompt "Floating point strategy"
  501. default BR2_ARM_FPU_FP_ARMV8 if BR2_ARM_CPU_HAS_FP_ARMV8
  502. default BR2_ARM_FPU_FPV5D16 if BR2_ARM_CPU_HAS_FPV5
  503. default BR2_ARM_FPU_FPV4D16 if BR2_ARM_CPU_HAS_FPV4
  504. default BR2_ARM_FPU_VFPV4D16 if BR2_ARM_CPU_HAS_VFPV4
  505. default BR2_ARM_FPU_VFPV3D16 if BR2_ARM_CPU_HAS_VFPV3
  506. default BR2_ARM_FPU_VFPV2 if BR2_ARM_CPU_HAS_VFPV2
  507. default BR2_ARM_SOFT_FLOAT if !BR2_ARM_CPU_HAS_FPU
  508. config BR2_ARM_SOFT_FLOAT
  509. bool "Soft float"
  510. depends on BR2_ARM_EABI
  511. select BR2_SOFT_FLOAT
  512. help
  513. This option allows to use software emulated floating
  514. point. It should be used for ARM cores that do not include a
  515. Vector Floating Point unit, such as ARMv5 cores (ARM926 for
  516. example) or certain ARMv6 cores.
  517. config BR2_ARM_FPU_VFPV2
  518. bool "VFPv2"
  519. depends on BR2_ARM_CPU_HAS_VFPV2
  520. help
  521. This option allows to use the VFPv2 floating point unit, as
  522. available in some ARMv5 processors (ARM926EJ-S) and some
  523. ARMv6 processors (ARM1136JF-S, ARM1176JZF-S and ARM11
  524. MPCore).
  525. Note that this option is also safe to use for newer cores
  526. such as Cortex-A, because the VFPv3 and VFPv4 units are
  527. backward compatible with VFPv2.
  528. config BR2_ARM_FPU_VFPV3
  529. bool "VFPv3"
  530. depends on BR2_ARM_CPU_HAS_VFPV3
  531. help
  532. This option allows to use the VFPv3 floating point unit, as
  533. available in some ARMv7 processors (Cortex-A{8, 9}). This
  534. option requires a VFPv3 unit that has 32 double-precision
  535. registers, which is not necessarily the case in all SOCs
  536. based on Cortex-A{8, 9}. If you're unsure, use VFPv3-D16
  537. instead, which is guaranteed to work on all Cortex-A{8, 9}.
  538. Note that this option is also safe to use for newer cores
  539. that have a VFPv4 unit, because VFPv4 is backward compatible
  540. with VFPv3. They must of course also have 32
  541. double-precision registers.
  542. config BR2_ARM_FPU_VFPV3D16
  543. bool "VFPv3-D16"
  544. depends on BR2_ARM_CPU_HAS_VFPV3
  545. help
  546. This option allows to use the VFPv3 floating point unit, as
  547. available in some ARMv7 processors (Cortex-A{8, 9}). This
  548. option requires a VFPv3 unit that has 16 double-precision
  549. registers, which is generally the case in all SOCs based on
  550. Cortex-A{8, 9}, even though VFPv3 is technically optional on
  551. Cortex-A9. This is the safest option for those cores.
  552. Note that this option is also safe to use for newer cores
  553. such that have a VFPv4 unit, because the VFPv4 is backward
  554. compatible with VFPv3.
  555. config BR2_ARM_FPU_VFPV4
  556. bool "VFPv4"
  557. depends on BR2_ARM_CPU_HAS_VFPV4
  558. help
  559. This option allows to use the VFPv4 floating point unit, as
  560. available in some ARMv7 processors (Cortex-A{5, 7, 12,
  561. 15}). This option requires a VFPv4 unit that has 32
  562. double-precision registers, which is not necessarily the
  563. case in all SOCs based on Cortex-A{5, 7, 12, 15}. If you're
  564. unsure, you should probably use VFPv4-D16 instead.
  565. Note that if you want binary code that works on all ARMv7
  566. cores, including the earlier Cortex-A{8, 9}, you should
  567. instead select VFPv3.
  568. config BR2_ARM_FPU_VFPV4D16
  569. bool "VFPv4-D16"
  570. depends on BR2_ARM_CPU_HAS_VFPV4
  571. help
  572. This option allows to use the VFPv4 floating point unit, as
  573. available in some ARMv7 processors (Cortex-A{5, 7, 12,
  574. 15}). This option requires a VFPv4 unit that has 16
  575. double-precision registers, which is always available on
  576. Cortex-A12 and Cortex-A15, but optional on Cortex-A5 and
  577. Cortex-A7.
  578. Note that if you want binary code that works on all ARMv7
  579. cores, including the earlier Cortex-A{8, 9}, you should
  580. instead select VFPv3-D16.
  581. config BR2_ARM_FPU_NEON
  582. bool "NEON"
  583. depends on BR2_ARM_CPU_HAS_NEON
  584. help
  585. This option allows to use the NEON SIMD unit, as available
  586. in some ARMv7 processors, as a floating-point unit. It
  587. should however be noted that using NEON for floating point
  588. operations doesn't provide a complete compatibility with the
  589. IEEE 754.
  590. config BR2_ARM_FPU_NEON_VFPV4
  591. bool "NEON/VFPv4"
  592. depends on BR2_ARM_CPU_HAS_VFPV4
  593. depends on BR2_ARM_CPU_HAS_NEON
  594. help
  595. This option allows to use both the VFPv4 and the NEON SIMD
  596. units for floating point operations. Note that some ARMv7
  597. cores do not necessarily have VFPv4 and/or NEON support, for
  598. example on Cortex-A5 and Cortex-A7, support for VFPv4 and
  599. NEON is optional.
  600. config BR2_ARM_FPU_FPV4D16
  601. bool "FPv4-D16"
  602. depends on BR2_ARM_CPU_HAS_FPV4
  603. help
  604. This option allows to use the FPv4-SP (single precision)
  605. floating point unit, as available in some ARMv7m processors
  606. (Cortex-M4).
  607. config BR2_ARM_FPU_FPV5D16
  608. bool "FPv5-D16"
  609. depends on BR2_ARM_CPU_HAS_FPV5
  610. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  611. help
  612. This option allows to use the FPv5-SP (single precision)
  613. floating point unit, as available in some ARMv7m processors
  614. (Cortex-M7).
  615. Note that if you want binary code that works on the earlier
  616. Cortex-M4, you should instead select FPv4-D16.
  617. config BR2_ARM_FPU_FPV5DPD16
  618. bool "FPv5-DP-D16"
  619. depends on BR2_ARM_CPU_HAS_FPV5
  620. select BR2_ARCH_NEEDS_GCC_AT_LEAST_5
  621. help
  622. This option allows to use the FPv5-DP (double precision)
  623. floating point unit, as available in some ARMv7m processors
  624. (Cortex-M7).
  625. Note that if you want binary code that works on the earlier
  626. Cortex-M4, you should instead select FPv4-D16.
  627. config BR2_ARM_FPU_FP_ARMV8
  628. bool "FP-ARMv8"
  629. depends on BR2_ARM_CPU_HAS_FP_ARMV8
  630. help
  631. This option allows to use the ARMv8 floating point unit.
  632. config BR2_ARM_FPU_NEON_FP_ARMV8
  633. bool "NEON/FP-ARMv8"
  634. depends on BR2_ARM_CPU_HAS_FP_ARMV8
  635. depends on BR2_ARM_CPU_HAS_NEON
  636. help
  637. This option allows to use both the ARMv8 floating point unit
  638. and the NEON SIMD unit for floating point operations.
  639. endchoice
  640. choice
  641. prompt "ARM instruction set"
  642. depends on BR2_arm || BR2_armeb
  643. config BR2_ARM_INSTRUCTIONS_ARM
  644. bool "ARM"
  645. depends on BR2_ARM_CPU_HAS_ARM
  646. help
  647. This option instructs the compiler to generate regular ARM
  648. instructions, that are all 32 bits wide.
  649. config BR2_ARM_INSTRUCTIONS_THUMB
  650. bool "Thumb"
  651. depends on BR2_ARM_CPU_HAS_THUMB
  652. # Thumb-1 and VFP are not compatible
  653. depends on BR2_ARM_SOFT_FLOAT
  654. help
  655. This option instructions the compiler to generate Thumb
  656. instructions, which allows to mix 16 bits instructions and
  657. 32 bits instructions. This generally provides a much smaller
  658. compiled binary size.
  659. comment "Thumb1 is not compatible with VFP"
  660. depends on BR2_ARM_CPU_HAS_THUMB
  661. depends on !BR2_ARM_SOFT_FLOAT
  662. config BR2_ARM_INSTRUCTIONS_THUMB2
  663. bool "Thumb2"
  664. depends on BR2_ARM_CPU_HAS_THUMB2
  665. help
  666. This option instructions the compiler to generate Thumb2
  667. instructions, which allows to mix 16 bits instructions and
  668. 32 bits instructions. This generally provides a much smaller
  669. compiled binary size.
  670. endchoice
  671. config BR2_ARCH
  672. default "arm" if BR2_arm
  673. default "armeb" if BR2_armeb
  674. default "aarch64" if BR2_aarch64
  675. default "aarch64_be" if BR2_aarch64_be
  676. config BR2_ENDIAN
  677. default "LITTLE" if (BR2_arm || BR2_aarch64)
  678. default "BIG" if (BR2_armeb || BR2_aarch64_be)
  679. config BR2_GCC_TARGET_CPU
  680. # armv4
  681. default "arm920t" if BR2_arm920t
  682. default "arm922t" if BR2_arm922t
  683. default "fa526" if BR2_fa526
  684. default "strongarm" if BR2_strongarm
  685. # armv5
  686. default "arm926ej-s" if BR2_arm926t
  687. default "iwmmxt" if BR2_iwmmxt
  688. default "xscale" if BR2_xscale
  689. # armv6
  690. default "arm1136j-s" if BR2_arm1136j_s
  691. default "arm1136jf-s" if BR2_arm1136jf_s
  692. default "arm1176jz-s" if BR2_arm1176jz_s
  693. default "arm1176jzf-s" if BR2_arm1176jzf_s
  694. default "mpcore" if BR2_arm11mpcore && BR2_ARM_CPU_HAS_VFPV2
  695. default "mpcorenovfp" if BR2_arm11mpcore
  696. # armv7a
  697. default "cortex-a5" if BR2_cortex_a5
  698. default "cortex-a7" if BR2_cortex_a7
  699. default "cortex-a8" if BR2_cortex_a8
  700. default "cortex-a9" if BR2_cortex_a9
  701. default "cortex-a12" if BR2_cortex_a12
  702. default "cortex-a15" if BR2_cortex_a15
  703. default "cortex-a15.cortex-a7" if BR2_cortex_a15_a7
  704. default "cortex-a17" if BR2_cortex_a17
  705. default "cortex-a17.cortex-a7" if BR2_cortex_a17_a7
  706. default "marvell-pj4" if BR2_pj4
  707. # armv7m
  708. default "cortex-m3" if BR2_cortex_m3
  709. default "cortex-m4" if BR2_cortex_m4
  710. default "cortex-m7" if BR2_cortex_m7
  711. # armv8a
  712. default "cortex-a32" if BR2_cortex_a32
  713. default "cortex-a35" if BR2_cortex_a35
  714. default "cortex-a53" if BR2_cortex_a53
  715. default "cortex-a57" if BR2_cortex_a57
  716. default "cortex-a57.cortex-a53" if BR2_cortex_a57_a53
  717. default "cortex-a72" if BR2_cortex_a72
  718. default "cortex-a72.cortex-a53" if BR2_cortex_a72_a53
  719. default "cortex-a73" if BR2_cortex_a73
  720. default "cortex-a73.cortex-a35" if BR2_cortex_a73_a35
  721. default "cortex-a73.cortex-a53" if BR2_cortex_a73_a53
  722. default "exynos-m1" if BR2_exynos_m1
  723. default "falkor" if BR2_falkor
  724. default "qdf24xx" if BR2_qdf24xx
  725. default "thunderx" if BR2_thunderx
  726. default "thunderxt81" if BR2_thunderxt81
  727. default "thunderxt83" if BR2_thunderxt83
  728. default "thunderxt88" if BR2_thunderxt88
  729. default "thunderxt88p1" if BR2_thunderxt88p1
  730. default "xgene1" if BR2_xgene1
  731. # armv8.1a
  732. default "thunderx2t99" if BR2_thunderx2t99
  733. default "thunderx2t99p1" if BR2_thunderx2t99p1
  734. default "vulcan" if BR2_vulcan
  735. config BR2_GCC_TARGET_ABI
  736. default "aapcs-linux" if BR2_arm || BR2_armeb
  737. default "lp64" if BR2_aarch64 || BR2_aarch64_be
  738. config BR2_GCC_TARGET_FPU
  739. default "vfp" if BR2_ARM_FPU_VFPV2
  740. default "vfpv3" if BR2_ARM_FPU_VFPV3
  741. default "vfpv3-d16" if BR2_ARM_FPU_VFPV3D16
  742. default "vfpv4" if BR2_ARM_FPU_VFPV4
  743. default "vfpv4-d16" if BR2_ARM_FPU_VFPV4D16
  744. default "neon" if BR2_ARM_FPU_NEON
  745. default "neon-vfpv4" if BR2_ARM_FPU_NEON_VFPV4
  746. default "fpv4-sp-d16" if BR2_ARM_FPU_FPV4D16
  747. default "fpv5-sp-d16" if BR2_ARM_FPU_FPV5D16
  748. default "fpv5-d16" if BR2_ARM_FPU_FPV5DPD16
  749. default "fp-armv8" if BR2_ARM_FPU_FP_ARMV8
  750. default "neon-fp-armv8" if BR2_ARM_FPU_NEON_FP_ARMV8
  751. depends on BR2_arm || BR2_armeb
  752. config BR2_GCC_TARGET_FLOAT_ABI
  753. default "soft" if BR2_ARM_SOFT_FLOAT
  754. default "softfp" if !BR2_ARM_SOFT_FLOAT && BR2_ARM_EABI
  755. default "hard" if !BR2_ARM_SOFT_FLOAT && BR2_ARM_EABIHF
  756. config BR2_GCC_TARGET_MODE
  757. default "arm" if BR2_ARM_INSTRUCTIONS_ARM
  758. default "thumb" if BR2_ARM_INSTRUCTIONS_THUMB || BR2_ARM_INSTRUCTIONS_THUMB2
  759. config BR2_READELF_ARCH_NAME
  760. default "ARM" if BR2_arm || BR2_armeb
  761. default "AArch64" if BR2_aarch64 || BR2_aarch64_be