]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/i386ly-tdep.c
Update FSF address.
[thirdparty/binutils-gdb.git] / gdb / i386ly-tdep.c
CommitLineData
9bebe500
SS
1/* Target-dependent code for Intel 386 running LynxOS.
2 Copyright 1993 Free Software Foundation, Inc.
b1eaba9a
SG
3
4This file is part of GDB.
5
6This program is free software; you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
8the Free Software Foundation; either version 2 of the License, or
9(at your option) any later version.
10
11This program is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with this program; if not, write to the Free Software
6c9638b4 18Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
b1eaba9a
SG
19
20#include "defs.h"
21#include "inferior.h"
22#include "target.h"
23
24/* Return the PC of the caller from the call frame. Assumes the subr prologue
25 has already been executed, and the frame pointer setup. If this is the
26 outermost frame, we check to see if we are in a system call by examining the
27 previous instruction. If so, then the return PC is actually at SP+4 because
28 system calls use a different calling sequence. */
29
30CORE_ADDR
31i386lynx_saved_pc_after_call (frame)
32 struct frame_info *frame;
33{
34 char opcode[7];
d9542046 35 static const unsigned char call_inst[] = {0x9a, 0, 0, 0, 0, 8, 0}; /* lcall 0x8,0x0 */
b1eaba9a
SG
36
37 read_memory (frame->pc - 7, opcode, 7);
38 if (memcmp (opcode, call_inst, 7) == 0)
39 return read_memory_integer (read_register (SP_REGNUM) + 4, 4);
40
41 return read_memory_integer (read_register (SP_REGNUM), 4);
42}