cldbfu.cgs 3.1 KB

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