flag.S 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386
  1. /* Tests the set flag (l.sf*) instructions.
  2. Copyright (C) 2017-2022 Free Software Foundation, Inc.
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation; either version 3 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>. */
  13. # mach: or1k
  14. # output: exit(0)\n
  15. #include "or1k-asm-test-helpers.h"
  16. #define INT_MAX 2147483647 /* 0x7fffffff */
  17. #define INT_MAX_MIN1 2147483646 /* 0x7ffffffe */
  18. #define NEG_INT_MAX -2147483648 /* 0x80000000 */
  19. #define NEG_INT_MAX_PL1 -2147483647 /* 0x80000001 */
  20. #define MIN1 -1 /* 0xffffffff */
  21. #define SHRT_MIN (-32768)
  22. #define SHRT_MAX 32767
  23. #define UINT_MAX 4294967295 /* 0xffffffff */
  24. #define UINT_MAX_MIN1 4294967294 /* 0xfffffffe */
  25. #define USHRT_MAX 65535
  26. .macro MOVE_TO_R4_R5_AND_REPORT a, b
  27. LOAD_IMMEDIATE r4, \a
  28. LOAD_IMMEDIATE r5, \b
  29. /* During development, add REPORT_xxx statements here to see the
  30. operands. */
  31. .endm
  32. .macro MOVE_TO_R4_AND_REPORT_I a, b
  33. LOAD_IMMEDIATE r4, \a
  34. /* During development, add REPORT_xxx statements here to see the
  35. operands. */
  36. .endm
  37. .macro SHOULD_BE_SET
  38. OR1K_DELAYED_NOP (l.bnf failed)
  39. .endm
  40. .macro SHOULDNT_BE_SET
  41. OR1K_DELAYED_NOP (l.bf failed)
  42. .endm
  43. .macro SHOULD_BE_LESS_THAN_SIGNED a, b
  44. MOVE_TO_R4_R5_AND_REPORT \a , \b
  45. l.sfeq r4, r5
  46. SHOULDNT_BE_SET
  47. l.sfne r4, r5
  48. SHOULD_BE_SET
  49. l.sfgts r4, r5
  50. SHOULDNT_BE_SET
  51. l.sfges r4, r5
  52. SHOULDNT_BE_SET
  53. l.sfles r4, r5
  54. SHOULD_BE_SET
  55. l.sflts r4, r5
  56. SHOULD_BE_SET
  57. .endm
  58. .macro SHOULD_BE_GREATER_THAN_SIGNED a, b
  59. MOVE_TO_R4_R5_AND_REPORT \a , \b
  60. l.sfeq r4, r5
  61. SHOULDNT_BE_SET
  62. l.sfne r4, r5
  63. SHOULD_BE_SET
  64. l.sfgts r4, r5
  65. SHOULD_BE_SET
  66. l.sfges r4, r5
  67. SHOULD_BE_SET
  68. l.sfles r4, r5
  69. SHOULDNT_BE_SET
  70. l.sflts r4, r5
  71. SHOULDNT_BE_SET
  72. .endm
  73. .macro SHOULD_BE_LESS_THAN_UNSIGNED a, b
  74. MOVE_TO_R4_R5_AND_REPORT \a , \b
  75. l.sfeq r4, r5
  76. SHOULDNT_BE_SET
  77. l.sfne r4, r5
  78. SHOULD_BE_SET
  79. l.sfgtu r4, r5
  80. SHOULDNT_BE_SET
  81. l.sfgeu r4, r5
  82. SHOULDNT_BE_SET
  83. l.sfleu r4, r5
  84. SHOULD_BE_SET
  85. l.sfltu r4, r5
  86. SHOULD_BE_SET
  87. .endm
  88. .macro SHOULD_BE_GREATER_THAN_UNSIGNED a, b
  89. MOVE_TO_R4_R5_AND_REPORT \a , \b
  90. l.sfeq r4, r5
  91. SHOULDNT_BE_SET
  92. l.sfne r4, r5
  93. SHOULD_BE_SET
  94. l.sfgtu r4, r5
  95. SHOULD_BE_SET
  96. l.sfgeu r4, r5
  97. SHOULD_BE_SET
  98. l.sfleu r4, r5
  99. SHOULDNT_BE_SET
  100. l.sfltu r4, r5
  101. SHOULDNT_BE_SET
  102. .endm
  103. .macro SHOULD_BE_EQUAL a, b
  104. MOVE_TO_R4_R5_AND_REPORT \a , \b
  105. l.sfeq r4, r5
  106. SHOULD_BE_SET
  107. l.sfne r4, r5
  108. SHOULDNT_BE_SET
  109. /* Signed tests. */
  110. l.sfgts r4, r5
  111. SHOULDNT_BE_SET
  112. l.sfges r4, r5
  113. SHOULD_BE_SET
  114. l.sfles r4, r5
  115. SHOULD_BE_SET
  116. l.sflts r4, r5
  117. SHOULDNT_BE_SET
  118. /* Unsigned tests. */
  119. l.sfgtu r4, r5
  120. SHOULDNT_BE_SET
  121. l.sfgeu r4, r5
  122. SHOULD_BE_SET
  123. l.sfleu r4, r5
  124. SHOULD_BE_SET
  125. l.sfltu r4, r5
  126. SHOULDNT_BE_SET
  127. .endm
  128. .macro SHOULDNT_BE_EQUAL a, b
  129. MOVE_TO_R4_R5_AND_REPORT \a , \b
  130. l.sfeq r4, r5
  131. SHOULDNT_BE_SET
  132. l.sfne r4, r5
  133. SHOULD_BE_SET
  134. .endm
  135. .macro SHOULD_BE_EQUAL_I a, b
  136. MOVE_TO_R4_AND_REPORT_I \a, \b
  137. l.sfeqi r4, \b
  138. SHOULD_BE_SET
  139. l.sfnei r4, \b
  140. SHOULDNT_BE_SET
  141. /* Signed tests. */
  142. l.sfgtsi r4, \b
  143. SHOULDNT_BE_SET
  144. l.sfgesi r4, \b
  145. SHOULD_BE_SET
  146. l.sflesi r4, \b
  147. SHOULD_BE_SET
  148. l.sfltsi r4, \b
  149. SHOULDNT_BE_SET
  150. /* Unsigned tests. */
  151. l.sfgtui r4, \b
  152. SHOULDNT_BE_SET
  153. l.sfgeui r4, \b
  154. SHOULD_BE_SET
  155. l.sfleui r4, \b
  156. SHOULD_BE_SET
  157. l.sfltui r4, \b
  158. SHOULDNT_BE_SET
  159. .endm
  160. .macro SHOULDNT_BE_EQUAL_I a, b
  161. MOVE_TO_R4_AND_REPORT_I \a, \b
  162. l.sfeqi r4, \b
  163. SHOULDNT_BE_SET
  164. l.sfnei r4, \b
  165. SHOULD_BE_SET
  166. .endm
  167. .macro SHOULD_BE_LESS_THAN_SIGNED_I a, b
  168. MOVE_TO_R4_AND_REPORT_I \a, \b
  169. l.sfeqi r4, \b
  170. SHOULDNT_BE_SET
  171. l.sfnei r4, \b
  172. SHOULD_BE_SET
  173. l.sfgtsi r4, \b
  174. SHOULDNT_BE_SET
  175. l.sfgesi r4, \b
  176. SHOULDNT_BE_SET
  177. l.sflesi r4, \b
  178. SHOULD_BE_SET
  179. l.sfltsi r4, \b
  180. SHOULD_BE_SET
  181. .endm
  182. .macro SHOULD_BE_GREATER_THAN_SIGNED_I a, b
  183. MOVE_TO_R4_AND_REPORT_I \a, \b
  184. l.sfeqi r4, \b
  185. SHOULDNT_BE_SET
  186. l.sfnei r4, \b
  187. SHOULD_BE_SET
  188. l.sfgtsi r4, \b
  189. SHOULD_BE_SET
  190. l.sfgesi r4, \b
  191. SHOULD_BE_SET
  192. l.sflesi r4, \b
  193. SHOULDNT_BE_SET
  194. l.sfltsi r4, \b
  195. SHOULDNT_BE_SET
  196. .endm
  197. .macro SHOULD_BE_LESS_THAN_UNSIGNED_I a, b
  198. MOVE_TO_R4_AND_REPORT_I \a, \b
  199. l.sfeqi r4, \b
  200. SHOULDNT_BE_SET
  201. l.sfnei r4, \b
  202. SHOULD_BE_SET
  203. l.sfgtui r4, \b
  204. SHOULDNT_BE_SET
  205. l.sfgeui r4, \b
  206. SHOULDNT_BE_SET
  207. l.sfleui r4, \b
  208. SHOULD_BE_SET
  209. l.sfltui r4, \b
  210. SHOULD_BE_SET
  211. .endm
  212. .macro SHOULD_BE_GREATER_THAN_UNSIGNED_I a, b
  213. MOVE_TO_R4_AND_REPORT_I \a, \b
  214. l.sfeqi r4, \b
  215. SHOULDNT_BE_SET
  216. l.sfnei r4, \b
  217. SHOULD_BE_SET
  218. l.sfgtui r4, \b
  219. SHOULD_BE_SET
  220. l.sfgeui r4, \b
  221. SHOULD_BE_SET
  222. l.sfleui r4, \b
  223. SHOULDNT_BE_SET
  224. l.sfltui r4, \b
  225. SHOULDNT_BE_SET
  226. .endm
  227. STANDARD_TEST_ENVIRONMENT
  228. .section .text
  229. start_tests:
  230. PUSH LINK_REGISTER_R9
  231. /* Signed tests */
  232. SHOULD_BE_LESS_THAN_SIGNED 0, 1
  233. SHOULD_BE_LESS_THAN_SIGNED MIN1, 0
  234. SHOULD_BE_LESS_THAN_SIGNED INT_MAX_MIN1, INT_MAX
  235. SHOULD_BE_LESS_THAN_SIGNED NEG_INT_MAX, INT_MAX
  236. SHOULD_BE_LESS_THAN_SIGNED NEG_INT_MAX, INT_MAX_MIN1
  237. SHOULD_BE_LESS_THAN_SIGNED NEG_INT_MAX_PL1, INT_MAX
  238. SHOULD_BE_LESS_THAN_SIGNED NEG_INT_MAX_PL1, INT_MAX_MIN1
  239. SHOULD_BE_LESS_THAN_SIGNED -7, -6
  240. SHOULD_BE_LESS_THAN_SIGNED NEG_INT_MAX, NEG_INT_MAX_PL1
  241. SHOULD_BE_LESS_THAN_SIGNED NEG_INT_MAX, MIN1
  242. SHOULD_BE_LESS_THAN_SIGNED NEG_INT_MAX, 0
  243. SHOULD_BE_GREATER_THAN_SIGNED 1, 0
  244. SHOULD_BE_GREATER_THAN_SIGNED 0, MIN1
  245. SHOULD_BE_GREATER_THAN_SIGNED INT_MAX, INT_MAX_MIN1
  246. SHOULD_BE_GREATER_THAN_SIGNED INT_MAX, NEG_INT_MAX
  247. SHOULD_BE_GREATER_THAN_SIGNED INT_MAX_MIN1, NEG_INT_MAX
  248. SHOULD_BE_GREATER_THAN_SIGNED INT_MAX, NEG_INT_MAX_PL1
  249. SHOULD_BE_GREATER_THAN_SIGNED INT_MAX_MIN1, NEG_INT_MAX_PL1
  250. SHOULD_BE_GREATER_THAN_SIGNED -6, -7
  251. SHOULD_BE_GREATER_THAN_SIGNED NEG_INT_MAX_PL1, NEG_INT_MAX
  252. SHOULD_BE_GREATER_THAN_SIGNED MIN1, NEG_INT_MAX
  253. SHOULD_BE_GREATER_THAN_SIGNED 0, NEG_INT_MAX
  254. /* See the immediate tests below. */
  255. SHOULD_BE_LESS_THAN_SIGNED 0xFFFF7FFF, 0xFFFF8000
  256. /* See the immediate tests below. */
  257. SHOULD_BE_GREATER_THAN_SIGNED 0xFFFF8001, 0xFFFF8000
  258. /* Signed tests, immediate */
  259. SHOULD_BE_LESS_THAN_SIGNED_I 0, 1
  260. SHOULD_BE_LESS_THAN_SIGNED_I -1, 0
  261. SHOULD_BE_LESS_THAN_SIGNED_I -7, -6
  262. SHOULD_BE_GREATER_THAN_SIGNED_I 0x00008000, 0x7FFF
  263. SHOULD_BE_LESS_THAN_SIGNED_I 0xFFFFFFFF, 0x7FFF
  264. /* 0x8000 gets sign-extended to 0xFFFF8000. */
  265. SHOULD_BE_LESS_THAN_SIGNED_I 0xFFFF7FFF, 0x8000
  266. /* 0x8000 gets sign-extended to 0xFFFF8000. */
  267. SHOULD_BE_GREATER_THAN_SIGNED_I 0xFFFF8001, 0x8000
  268. /* 0x8000 gets sign-extended to 0xFFFF8000. */
  269. SHOULD_BE_GREATER_THAN_SIGNED_I 0x00008000, 0x8000
  270. /* Unsigned tests */
  271. SHOULD_BE_LESS_THAN_UNSIGNED 0, 1
  272. SHOULD_BE_LESS_THAN_UNSIGNED UINT_MAX_MIN1, UINT_MAX
  273. SHOULD_BE_GREATER_THAN_UNSIGNED 1, 0
  274. SHOULD_BE_GREATER_THAN_UNSIGNED UINT_MAX, UINT_MAX_MIN1
  275. SHOULD_BE_GREATER_THAN_UNSIGNED UINT_MAX, 0
  276. SHOULD_BE_GREATER_THAN_UNSIGNED 0x80000001, 0x80000000
  277. SHOULD_BE_LESS_THAN_UNSIGNED 0x80000000, 0x80000001
  278. SHOULD_BE_GREATER_THAN_UNSIGNED 0x80000000, 0x7fffffff
  279. SHOULD_BE_LESS_THAN_UNSIGNED 0x7fffffff, 0x80000000
  280. SHOULD_BE_GREATER_THAN_UNSIGNED 0x7fffffff, 0x7ffffffe
  281. SHOULD_BE_LESS_THAN_UNSIGNED 0x7ffffffe, 0x7fffffff
  282. SHOULD_BE_LESS_THAN_UNSIGNED 0x2024fae0, 0xfef03220
  283. /* Unsigned tests, immediate */
  284. SHOULD_BE_LESS_THAN_UNSIGNED_I 0, 1
  285. SHOULD_BE_GREATER_THAN_UNSIGNED_I 1, 0
  286. SHOULD_BE_LESS_THAN_UNSIGNED_I SHRT_MAX - 1, SHRT_MAX
  287. SHOULD_BE_GREATER_THAN_UNSIGNED_I SHRT_MAX , SHRT_MAX - 1
  288. /* The sign extension produces unexpected results here. */
  289. /* 0xFFFF gets sign-extended to 0xFFFFFFFF. */
  290. SHOULD_BE_LESS_THAN_UNSIGNED_I 0xFFFFFFFF - 1, 0xFFFF
  291. /* 0x8000 gets sign-extended to 0xFFFF8000. */
  292. SHOULD_BE_LESS_THAN_UNSIGNED_I 0xFFFF7FFF, 0x8000
  293. /* Equal tests. */
  294. SHOULD_BE_EQUAL 0, 0
  295. SHOULD_BE_EQUAL UINT_MAX, UINT_MAX
  296. SHOULD_BE_EQUAL MIN1, UINT_MAX
  297. SHOULD_BE_EQUAL INT_MAX, INT_MAX
  298. SHOULD_BE_EQUAL NEG_INT_MAX, NEG_INT_MAX
  299. /* Equal tests, immediate. Test the 16-to-32-bit sign extension. */
  300. SHOULD_BE_EQUAL_I 0, 0
  301. SHOULD_BE_EQUAL_I 0x00007FFF, 0x7FFF
  302. SHOULD_BE_EQUAL_I 0xFFFF8000, 0x8000
  303. SHOULD_BE_EQUAL_I 0xFFFFFFFF, 0xFFFF
  304. /* Non-equal tests. */
  305. SHOULDNT_BE_EQUAL 0, 1
  306. SHOULDNT_BE_EQUAL UINT_MAX, INT_MAX
  307. SHOULDNT_BE_EQUAL UINT_MAX, NEG_INT_MAX
  308. SHOULDNT_BE_EQUAL MIN1, NEG_INT_MAX_PL1
  309. SHOULDNT_BE_EQUAL INT_MAX, NEG_INT_MAX
  310. SHOULDNT_BE_EQUAL NEG_INT_MAX_PL1, UINT_MAX_MIN1
  311. /* Non-equal tests, immediate. Test the 16-to-32-bit sign
  312. extension. */
  313. SHOULDNT_BE_EQUAL_I 0x00008000, 0x8000
  314. POP LINK_REGISTER_R9
  315. RETURN_TO_LINK_REGISTER_R9
  316. failed:
  317. EXIT_SIMULATION_WITH_IMMEDIATE_EXIT_CODE SEC_GENERIC_ERROR