bsd-setjmp.S 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. ;
  2. ; Port of uClibc for TMS320C6000 DSP architecture
  3. ; Copyright (C) 2004 Texas Instruments Incorporated
  4. ; Author of TMS320C6000 port: Aurelien Jacquiot
  5. ;
  6. ; This program is free software; you can redistribute it and/or modify it
  7. ; under the terms of the GNU Library General Public License as published by
  8. ; the Free Software Foundation; either version 2 of the License, or (at your
  9. ; option) any later version.
  10. ;
  11. ; This program is distributed in the hope that it will be useful, but WITHOUT
  12. ; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13. ; FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
  14. ; for more details.
  15. ;
  16. ; You should have received a copy of the GNU Library General Public License
  17. ; along with this program; if not, see <http://www.gnu.org/licenses/>.
  18. ;
  19. .global setjmp
  20. setjmp:
  21. #if 0
  22. .if 1 /* was: .if (CONFIG_UCLIBC_SHARED == 0) */
  23. MVKL .S1 ___curr_eh_stack_entry,A6
  24. || SUB .D1X A4,B15,A3
  25. MVKH .S1 ___curr_eh_stack_entry,A6
  26. || CMPGT .L1 A3,4,A0 ; A0 set if C++ exceptions case
  27. LDW .D1T1 *A6,A2
  28. .else
  29. MVKL .S2 (___curr_eh_stack_entry - $bss)/4,B6
  30. || SUB .D1X A4,B15,A3
  31. MVKH .S2 (___curr_eh_stack_entry - $bss)/4,B6
  32. || CMPGT .L1 A3,4,A0 ; A0 set if C++ exceptions case
  33. LDW .D2T1 *+B14[B6],A2
  34. .endif
  35. NOP
  36. #else
  37. MVK .S1 0, A0
  38. #endif
  39. MVK .L2 1,B4 ; indicate to ___sigjmp_save to save signal mask
  40. || MV .D2X A4,B6 ; jmp_buf address
  41. || STW .D1T2 B3,*+A4(48) ; return address
  42. ADDAW .D1 A2,2,A2
  43. [A0] CMPEQ .L1 A4,A2,A0 ; A0 set if C++ exceptions case
  44. STW .D1T1 A10,*+A4(0)
  45. || STW .D2T2 B10,*+B6(4)
  46. ||[!A0] B .S1 __sigjmp_save ; branch to ___sigjmp_save in 5 cycles
  47. ||[A0] B .S2 B3
  48. STW .D1T1 A11,*+A4(8)
  49. || STW .D2T2 B11,*+B6(12)
  50. STW .D1T1 A12,*+A4(16)
  51. || STW .D2T2 B12,*+B6(20)
  52. STW .D1T1 A13,*+A4(24)
  53. || STW .D2T2 B13,*+B6(28)
  54. STW .D1T1 A14,*+A4(32)
  55. || STW .D2T2 B14,*+B6(36)
  56. STW .D1T1 A15,*+A4(40)
  57. || STW .D2T2 B15,*+B6(44)
  58. ||[A0] ZERO .L1 A4 ; returns 0 for the C++ case