cldfu.cgs 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. # frv testcase for cldfu @($GRi,$GRj),$FRk,$CCi,$cond
  2. # mach: all
  3. .include "testutils.inc"
  4. start
  5. .global cldfu
  6. cldfu:
  7. set_spr_immed 0x1b1b,cccr
  8. set_gr_gr sp,gr21
  9. set_gr_gr sp,gr20
  10. set_mem_limmed 0xdead,0xbeef,sp
  11. set_fr_iimmed 0xbeef,0xdead,fr8
  12. set_gr_immed 0,gr7
  13. cldfu @(sp,gr7),fr8,cc0,1
  14. test_fr_limmed 0xdead,0xbeef,fr8
  15. test_gr_gr sp,gr20
  16. set_fr_iimmed 0xbeef,0xdead,fr8
  17. inc_gr_immed -4,sp
  18. set_gr_immed 4,gr7
  19. cldfu @(sp,gr7),fr8,cc0,1
  20. test_fr_limmed 0xdead,0xbeef,fr8
  21. test_gr_gr sp,gr20
  22. set_fr_iimmed 0xbeef,0xdead,fr8
  23. inc_gr_immed 4,sp
  24. set_gr_immed -4,gr7
  25. cldfu @(sp,gr7),fr8,cc4,1
  26. test_fr_limmed 0xdead,0xbeef,fr8
  27. test_gr_gr sp,gr20
  28. set_gr_gr gr21,sp
  29. set_gr_gr sp,gr20
  30. set_mem_limmed 0xdead,0xbeef,sp
  31. set_fr_iimmed 0xbeef,0xdead,fr8
  32. set_gr_immed 0,gr7
  33. cldfu @(sp,gr7),fr8,cc0,0
  34. test_fr_limmed 0xbeef,0xdead,fr8
  35. test_gr_gr sp,gr20
  36. set_fr_iimmed 0xbeef,0xdead,fr8
  37. inc_gr_immed -4,gr20
  38. inc_gr_immed -4,sp
  39. set_gr_immed 4,gr7
  40. cldfu @(sp,gr7),fr8,cc0,0
  41. test_fr_limmed 0xbeef,0xdead,fr8
  42. test_gr_gr sp,gr20
  43. set_fr_iimmed 0xbeef,0xdead,fr8
  44. inc_gr_immed 8,gr20
  45. inc_gr_immed 8,sp
  46. set_gr_immed -4,gr7
  47. cldfu @(sp,gr7),fr8,cc4,0
  48. test_fr_limmed 0xbeef,0xdead,fr8
  49. test_gr_gr sp,gr20
  50. set_gr_gr gr21,sp
  51. set_gr_gr sp,gr20
  52. set_mem_limmed 0xdead,0xbeef,sp
  53. set_fr_iimmed 0xbeef,0xdead,fr8
  54. set_gr_immed 0,gr7
  55. cldfu @(sp,gr7),fr8,cc1,0
  56. test_fr_limmed 0xdead,0xbeef,fr8
  57. test_gr_gr sp,gr20
  58. set_fr_iimmed 0xbeef,0xdead,fr8
  59. inc_gr_immed -4,sp
  60. set_gr_immed 4,gr7
  61. cldfu @(sp,gr7),fr8,cc1,0
  62. test_fr_limmed 0xdead,0xbeef,fr8
  63. test_gr_gr sp,gr20
  64. set_fr_iimmed 0xbeef,0xdead,fr8
  65. inc_gr_immed 4,sp
  66. set_gr_immed -4,gr7
  67. cldfu @(sp,gr7),fr8,cc5,0
  68. test_fr_limmed 0xdead,0xbeef,fr8
  69. test_gr_gr sp,gr20
  70. set_gr_gr gr21,sp
  71. set_gr_gr sp,gr20
  72. set_mem_limmed 0xdead,0xbeef,sp
  73. set_fr_iimmed 0xbeef,0xdead,fr8
  74. set_gr_immed 0,gr7
  75. cldfu @(sp,gr7),fr8,cc1,1
  76. test_fr_limmed 0xbeef,0xdead,fr8
  77. test_gr_gr sp,gr20
  78. set_fr_iimmed 0xbeef,0xdead,fr8
  79. inc_gr_immed -4,gr20
  80. inc_gr_immed -4,sp
  81. set_gr_immed 4,gr7
  82. cldfu @(sp,gr7),fr8,cc1,1
  83. test_fr_limmed 0xbeef,0xdead,fr8
  84. test_gr_gr sp,gr20
  85. set_fr_iimmed 0xbeef,0xdead,fr8
  86. inc_gr_immed 8,gr20
  87. inc_gr_immed 8,sp
  88. set_gr_immed -4,gr7
  89. cldfu @(sp,gr7),fr8,cc5,1
  90. test_fr_limmed 0xbeef,0xdead,fr8
  91. test_gr_gr sp,gr20
  92. set_gr_gr gr21,sp
  93. set_gr_gr sp,gr20
  94. set_mem_limmed 0xdead,0xbeef,sp
  95. set_fr_iimmed 0xbeef,0xdead,fr8
  96. set_gr_immed 0,gr7
  97. cldfu @(sp,gr7),fr8,cc2,0
  98. test_fr_limmed 0xbeef,0xdead,fr8
  99. test_gr_gr sp,gr20
  100. set_fr_iimmed 0xbeef,0xdead,fr8
  101. inc_gr_immed -4,gr20
  102. inc_gr_immed -4,sp
  103. set_gr_immed 4,gr7
  104. cldfu @(sp,gr7),fr8,cc2,1
  105. test_fr_limmed 0xbeef,0xdead,fr8
  106. test_gr_gr sp,gr20
  107. set_fr_iimmed 0xbeef,0xdead,fr8
  108. inc_gr_immed 8,gr20
  109. inc_gr_immed 8,sp
  110. set_gr_immed -4,gr7
  111. cldfu @(sp,gr7),fr8,cc6,0
  112. test_fr_limmed 0xbeef,0xdead,fr8
  113. test_gr_gr sp,gr20
  114. set_gr_gr gr21,sp
  115. set_gr_gr sp,gr20
  116. set_mem_limmed 0xdead,0xbeef,sp
  117. set_fr_iimmed 0xbeef,0xdead,fr8
  118. set_gr_immed 0,gr7
  119. cldfu @(sp,gr7),fr8,cc3,1
  120. test_fr_limmed 0xbeef,0xdead,fr8
  121. test_gr_gr sp,gr20
  122. set_fr_iimmed 0xbeef,0xdead,fr8
  123. inc_gr_immed -4,gr20
  124. inc_gr_immed -4,sp
  125. set_gr_immed 4,gr7
  126. cldfu @(sp,gr7),fr8,cc3,0
  127. test_fr_limmed 0xbeef,0xdead,fr8
  128. test_gr_gr sp,gr20
  129. set_fr_iimmed 0xbeef,0xdead,fr8
  130. inc_gr_immed 8,gr20
  131. inc_gr_immed 8,sp
  132. set_gr_immed -4,gr7
  133. cldfu @(sp,gr7),fr8,cc7,1
  134. test_fr_limmed 0xbeef,0xdead,fr8
  135. test_gr_gr sp,gr20
  136. pass