tine.cgs 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. # frv testcase for tine $ICCi_2,$GRi,$s12
  2. # mach: all
  3. .include "testutils.inc"
  4. start
  5. .global tine
  6. tine:
  7. and_spr_immed -4081,tbr ; clear tbr.tt
  8. set_gr_spr tbr,gr7
  9. inc_gr_immed 2112,gr7 ; address of exception handler
  10. set_bctrlr_0_0 gr7 ; bctrlr 0,0
  11. set_spr_immed 128,lcr
  12. set_gr_immed 0,gr7
  13. set_psr_et 1
  14. set_spr_addr ok0,lr
  15. set_icc 0x0 0
  16. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  17. fail
  18. ok0:
  19. set_psr_et 1
  20. set_spr_addr ok1,lr
  21. set_icc 0x1 0
  22. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  23. fail
  24. ok1:
  25. set_psr_et 1
  26. set_spr_addr ok2,lr
  27. set_icc 0x2 0
  28. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  29. fail
  30. ok2:
  31. set_psr_et 1
  32. set_spr_addr ok3,lr
  33. set_icc 0x3 0
  34. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  35. fail
  36. ok3:
  37. set_spr_addr bad,lr
  38. set_icc 0x4 0
  39. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  40. set_spr_addr bad,lr
  41. set_icc 0x5 0
  42. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  43. set_spr_addr bad,lr
  44. set_icc 0x6 0
  45. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  46. set_spr_addr bad,lr
  47. set_icc 0x7 0
  48. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  49. set_psr_et 1
  50. set_spr_addr ok8,lr
  51. set_icc 0x8 0
  52. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  53. fail
  54. ok8:
  55. set_psr_et 1
  56. set_spr_addr ok9,lr
  57. set_icc 0x9 0
  58. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  59. fail
  60. ok9:
  61. set_psr_et 1
  62. set_spr_addr oka,lr
  63. set_icc 0xa 0
  64. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  65. fail
  66. oka:
  67. set_psr_et 1
  68. set_spr_addr okb,lr
  69. set_icc 0xb 0
  70. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  71. fail
  72. okb:
  73. set_spr_addr bad,lr
  74. set_icc 0xc 0
  75. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  76. set_spr_addr bad,lr
  77. set_icc 0xd 0
  78. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  79. set_spr_addr bad,lr
  80. set_icc 0xe 0
  81. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  82. set_spr_addr bad,lr
  83. set_icc 0xf 0
  84. tine icc0,gr7,4 ; should branch to tbr + (128 + 4)*16
  85. pass
  86. bad:
  87. fail