2000-02-17 19:39:52 +00:00
|
|
|
/* This is file is a merger of SETJMP.S and LONGJMP.S */
|
|
|
|
/*
|
|
|
|
* This file was modified to use the __USER_LABEL_PREFIX__ and
|
|
|
|
* __REGISTER_PREFIX__ macros defined by later versions of GNU cpp by
|
|
|
|
* Joel Sherrill (joel@OARcorp.com)
|
2000-08-28 17:50:06 +00:00
|
|
|
* Slight change: now includes i386mach.h for this (Werner Almesberger)
|
2000-02-17 19:39:52 +00:00
|
|
|
*
|
2001-02-22 22:12:43 +00:00
|
|
|
* Copyright (C) 1991 DJ Delorie
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
2012-03-09 20:26:39 +00:00
|
|
|
* Redistribution, modification, and use in source and binary forms is permitted
|
2001-02-22 22:12:43 +00:00
|
|
|
* provided that the above copyright notice and following paragraph are
|
|
|
|
* duplicated in all such forms.
|
|
|
|
*
|
|
|
|
* This file is distributed WITHOUT ANY WARRANTY; without even the implied
|
|
|
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
2000-02-17 19:39:52 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
** jmp_buf:
|
|
|
|
** eax ebx ecx edx esi edi ebp esp eip
|
|
|
|
** 0 4 8 12 16 20 24 28 32
|
2016-03-31 12:12:00 +03:00
|
|
|
**
|
|
|
|
** Intel MCU jmp_buf:
|
|
|
|
** ebx esi edi ebp esp eip
|
|
|
|
** 0 4 8 12 16 20
|
2000-02-17 19:39:52 +00:00
|
|
|
*/
|
|
|
|
|
2000-08-28 17:50:06 +00:00
|
|
|
#include "i386mach.h"
|
2000-02-17 19:39:52 +00:00
|
|
|
|
|
|
|
.global SYM (setjmp)
|
|
|
|
.global SYM (longjmp)
|
2000-08-28 17:50:06 +00:00
|
|
|
SOTYPE_FUNCTION(setjmp)
|
|
|
|
SOTYPE_FUNCTION(longjmp)
|
2000-02-17 19:39:52 +00:00
|
|
|
|
|
|
|
SYM (setjmp):
|
|
|
|
|
2016-03-31 12:12:00 +03:00
|
|
|
#ifdef __iamcu__
|
|
|
|
/* Store EIP. */
|
|
|
|
movl 0(esp),ecx
|
|
|
|
movl ecx,20(eax)
|
|
|
|
|
|
|
|
movl ebx,0 (eax)
|
|
|
|
movl esi,4 (eax)
|
|
|
|
movl edi,8 (eax)
|
|
|
|
movl ebp,12(eax)
|
|
|
|
|
|
|
|
/* Skip return address, which will be pushed onto stack in
|
|
|
|
longjmp, and store SP. */
|
|
|
|
leal 4(esp),ecx
|
|
|
|
movl ecx,16(eax)
|
|
|
|
|
|
|
|
xorl eax,eax
|
|
|
|
#else
|
2000-02-17 19:39:52 +00:00
|
|
|
pushl ebp
|
|
|
|
movl esp,ebp
|
|
|
|
|
|
|
|
pushl edi
|
|
|
|
movl 8 (ebp),edi
|
|
|
|
|
|
|
|
movl eax,0 (edi)
|
|
|
|
movl ebx,4 (edi)
|
|
|
|
movl ecx,8 (edi)
|
|
|
|
movl edx,12 (edi)
|
|
|
|
movl esi,16 (edi)
|
|
|
|
|
|
|
|
movl -4 (ebp),eax
|
|
|
|
movl eax,20 (edi)
|
|
|
|
|
|
|
|
movl 0 (ebp),eax
|
|
|
|
movl eax,24 (edi)
|
|
|
|
|
|
|
|
movl esp,eax
|
|
|
|
addl $12,eax
|
|
|
|
movl eax,28 (edi)
|
|
|
|
|
|
|
|
movl 4 (ebp),eax
|
|
|
|
movl eax,32 (edi)
|
|
|
|
|
|
|
|
popl edi
|
|
|
|
movl $0,eax
|
|
|
|
leave
|
2016-03-31 12:12:00 +03:00
|
|
|
#endif
|
2000-02-17 19:39:52 +00:00
|
|
|
ret
|
|
|
|
|
|
|
|
SYM (longjmp):
|
2016-03-31 12:12:00 +03:00
|
|
|
#ifdef __iamcu__
|
|
|
|
/* Check retval. */
|
|
|
|
testl edx,edx
|
|
|
|
jne 0f
|
|
|
|
incl edx
|
|
|
|
0:
|
|
|
|
/* Restore stack first. */
|
|
|
|
movl 16(eax),esp
|
|
|
|
|
|
|
|
/* Put return address on stack. */
|
|
|
|
pushl 20(eax)
|
|
|
|
|
|
|
|
movl 0(eax),ebx
|
|
|
|
movl 4(eax),esi
|
|
|
|
movl 8(eax),edi
|
|
|
|
movl 12(eax),ebp
|
|
|
|
movl edx,eax
|
|
|
|
#else
|
2000-02-17 19:39:52 +00:00
|
|
|
pushl ebp
|
|
|
|
movl esp,ebp
|
|
|
|
|
|
|
|
movl 8(ebp),edi /* get jmp_buf */
|
|
|
|
movl 12(ebp),eax /* store retval in j->eax */
|
2010-11-16 17:52:21 +00:00
|
|
|
testl eax,eax
|
|
|
|
jne 0f
|
|
|
|
incl eax
|
|
|
|
0:
|
2000-02-17 19:39:52 +00:00
|
|
|
movl eax,0(edi)
|
|
|
|
|
|
|
|
movl 24(edi),ebp
|
|
|
|
|
2000-08-28 17:50:06 +00:00
|
|
|
__CLI
|
2000-02-17 19:39:52 +00:00
|
|
|
movl 28(edi),esp
|
|
|
|
|
|
|
|
pushl 32(edi)
|
|
|
|
|
|
|
|
movl 0(edi),eax
|
|
|
|
movl 4(edi),ebx
|
|
|
|
movl 8(edi),ecx
|
|
|
|
movl 12(edi),edx
|
|
|
|
movl 16(edi),esi
|
|
|
|
movl 20(edi),edi
|
2000-08-28 17:50:06 +00:00
|
|
|
__STI
|
2016-03-31 12:12:00 +03:00
|
|
|
#endif
|
2000-02-17 19:39:52 +00:00
|
|
|
|
|
|
|
ret
|