mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-19 04:49:25 +08:00
a703e0f2ee
* configure.host: Recognize m6811-elf and m6812-elf targets. * libc/include/machine/setjmp.h (_JBLEN): Define for 68hc11/68hc12. * libc/include/machine/ieeefp.h (__IEEE_BIG_ENDIAN): Define for 68HC11. (_DOUBLE_IS_32BITS): Define when compiling with -fshort-double. * libc/include/sys/config.h (INT_MAX, UINT_MAX): Define according to __INT_MAX__. (_POINTER_INT): Define to short. * libc/machine/m68hc11/Makefile.am: New file. * libc/machine/m68hc11/Makefile.in: New file. * libc/machine/m68hc11/configure.in: New file. * libc/machine/m68hc11/configure: New file. * libc/machine/m68hc11/aclocal.m4: New file. * libc/machine/m68hc11/setjmp.S: New file.
142 lines
2.1 KiB
ArmAsm
142 lines
2.1 KiB
ArmAsm
/* setjmp/longjmp routines for M68HC11 & M68HC12.
|
|
* Copyright (C) 1999, 2000, 2001, 2002 Stephane Carrez (stcarrez@nerim.fr)
|
|
*
|
|
* The authors hereby grant permission to use, copy, modify, distribute,
|
|
* and license this software and its documentation for any purpose, provided
|
|
* that existing copyright notices are retained in all copies and that this
|
|
* notice is included verbatim in any distributions. No written agreement,
|
|
* license, or royalty fee is required for any of the authorized uses.
|
|
* Modifications to this software may be copyrighted by their authors
|
|
* and need not follow the licensing terms described here, provided that
|
|
* the new terms are clearly indicated on the first page of each file where
|
|
* they apply.
|
|
*/
|
|
|
|
#if __INT__ == 32
|
|
# define val 4
|
|
# define INT32(X) X
|
|
#else
|
|
# define val 2
|
|
# define INT32(X)
|
|
#endif
|
|
|
|
#ifdef mc6811
|
|
# define REG(X) *X
|
|
#else
|
|
# define REG(X) X
|
|
#endif
|
|
|
|
.sect .text
|
|
.global setjmp
|
|
.global longjmp
|
|
|
|
#ifdef mc6811
|
|
setjmp:
|
|
xgdx
|
|
tsy
|
|
ldd 0,y
|
|
std 0,x
|
|
sty 2,x
|
|
ldd REG(_.frame)
|
|
std 4,x
|
|
ldd REG(_.d1)
|
|
std 6,x
|
|
ldd REG(_.d2)
|
|
std 8,x
|
|
ldd REG(_.d3)
|
|
std 10,x
|
|
ldd REG(_.d4)
|
|
std 12,x
|
|
ldd REG(_.d5)
|
|
std 14,x
|
|
ldd REG(_.d6)
|
|
std 16,x
|
|
ldd REG(_.d7)
|
|
std 18,x
|
|
ldd REG(_.d8)
|
|
std 20,x
|
|
INT32( ldx #0)
|
|
clra
|
|
clrb
|
|
rts
|
|
#else
|
|
setjmp:
|
|
xgdx
|
|
movw 0,sp,2,x+
|
|
sts 2,x+
|
|
movw _.frame,2,x+
|
|
movw _.d1,2,x+
|
|
movw _.d2,2,x+
|
|
movw _.d3,2,x+
|
|
movw _.d4,2,x+
|
|
movw _.d5,2,x+
|
|
movw _.d6,2,x+
|
|
movw _.d7,2,x+
|
|
movw _.d8,2,x+
|
|
INT32( ldx #0)
|
|
clra
|
|
clrb
|
|
rts
|
|
#endif
|
|
|
|
#ifdef mc6811
|
|
longjmp:
|
|
xgdx
|
|
tsy
|
|
ldd val,y
|
|
bne do_jump
|
|
ldd #1
|
|
do_jump:
|
|
xgdy
|
|
ldd 4,x
|
|
std REG(_.frame)
|
|
ldd 6,x
|
|
std REG(_.d1)
|
|
ldd 8,x
|
|
std REG(_.d2)
|
|
ldd 10,x
|
|
std REG(_.d3)
|
|
ldd 12,x
|
|
std REG(_.d4)
|
|
ldd 14,x
|
|
std REG(_.d5)
|
|
ldd 16,x
|
|
std REG(_.d6)
|
|
ldd 18,x
|
|
std REG(_.d7)
|
|
ldd 20,x
|
|
std REG(_.d8)
|
|
ldd 0,x
|
|
ldx 2,x
|
|
txs
|
|
std 0,x
|
|
INT32( ldx #0)
|
|
xgdy
|
|
rts
|
|
#else
|
|
|
|
longjmp:
|
|
xgdx
|
|
ldy val,sp
|
|
bne do_jump
|
|
ldy #1
|
|
do_jump:
|
|
ldd 4,x+
|
|
movw 2,x+,_.frame
|
|
movw 0,x,_.d1
|
|
movw 2,x,_.d2
|
|
movw 4,x,_.d3
|
|
movw 6,x,_.d4
|
|
movw 8,x,_.d5
|
|
movw 10,x,_.d6
|
|
movw 12,x,_.d7
|
|
movw 14,x,_.d8
|
|
ldx -4,x
|
|
txs
|
|
std 0,x
|
|
INT32( ldx #0)
|
|
xgdy
|
|
rts
|
|
#endif
|
|
|