📄 tm-pn.h
字号:
/* Parameters for targe of a Gould Powernode, for GDB, the GNU debugger. Copyright (C) 1986, 1987, 1989, 1991 Free Software Foundation, Inc.This file is part of GDB.This program is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 2 of the License, or(at your option) any later version.This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with this program; if not, write to the Free SoftwareFoundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */#define GOULD_PN#define TARGET_BYTE_ORDER BIG_ENDIAN/* This code appears in libraries on Gould machines. Ignore it. */#define IGNORE_SYMBOL(type) (type == N_ENTRY)/* We don't want the extra gnu symbols on the machine; they will interfere with the shared segment symbols. */#define NO_GNU_STABS/* Macro for text-offset and data info (in PN a.out format). */#define TEXTINFO \ text_offset = N_TXTOFF (exec_coffhdr); \ exec_data_offset = N_TXTOFF (exec_coffhdr) \ + exec_aouthdr.a_text/* Macro for number of symbol table entries */#define END_OF_TEXT_DEFAULT \ (0xffffff)/* Macro for number of symbol table entries */#define NUMBER_OF_SYMBOLS \ (coffhdr.f_nsyms)/* Macro for file-offset of symbol table (in usual a.out format). */#define SYMBOL_TABLE_OFFSET \ N_SYMOFF (coffhdr)/* Macro for file-offset of string table (in usual a.out format). */#define STRING_TABLE_OFFSET \ (N_STROFF (coffhdr) + sizeof(int))/* Macro to store the length of the string table data in INTO. */#define READ_STRING_TABLE_SIZE(INTO) \ { INTO = hdr.a_stsize; }/* Macro to declare variables to hold the file's header data. */#define DECLARE_FILE_HEADERS struct old_exec hdr; \ FILHDR coffhdr/* Macro to read the header data from descriptor DESC and validate it. NAME is the file name, for error messages. */#define READ_FILE_HEADERS(DESC, NAME) \{ val = myread (DESC, &coffhdr, sizeof coffhdr); \ if (val < 0) \ perror_with_name (NAME); \ val = myread (DESC, &hdr, sizeof hdr); \ if (val < 0) \ perror_with_name (NAME); \ if (coffhdr.f_magic != GNP1MAGIC) \ error ("File \"%s\" not in coff executable format.", NAME); \ if (N_BADMAG (hdr)) \ error ("File \"%s\" not in executable format.", NAME); }/* Define COFF and other symbolic names needed on NP1 */#define NS32GMAGIC GDPMAGIC#define NS32SMAGIC PN_MAGIC/* Define this if the C compiler puts an underscore at the front of external names before giving them to the linker. */#define NAMES_HAVE_UNDERSCORE/* Offset from address of function to start of its code. Zero on most machines. */#define FUNCTION_START_OFFSET 4/* Advance PC across any function entry prologue instructions to reach some "real" code. One PN we can have one or two startup sequences depending on the size of the local stack: Either: "suabr b2, #" of "lil r4, #", "suabr b2, #(r4)" "lwbr b6, #", "stw r1, 8(b2)" Optional "stwbr b3, c(b2)" Optional "trr r2,r7" (Gould first argument register passing) or Optional "stw r2,8(b3)" (Gould first argument register passing) */#define SKIP_PROLOGUE(pc) { \ register int op = read_memory_integer ((pc), 4); \ if ((op & 0xffff0000) == 0x580B0000) { \ pc += 4; \ op = read_memory_integer ((pc), 4); \ if ((op & 0xffff0000) == 0x59400000) { \ pc += 4; \ op = read_memory_integer ((pc), 4); \ if ((op & 0xffff0000) == 0x5F000000) { \ pc += 4; \ op = read_memory_integer ((pc), 4); \ if (op == 0xD4820008) { \ pc += 4; \ op = read_memory_integer ((pc), 4); \ if (op == 0x5582000C) { \ pc += 4; \ op = read_memory_integer ((pc), 2); \ if (op == 0x2fa0) { \ pc += 2; \ } else { \ op = read_memory_integer ((pc), 4); \ if (op == 0xd5030008) { \ pc += 4; \ } \ } \ } else { \ op = read_memory_integer ((pc), 2); \ if (op == 0x2fa0) { \ pc += 2; \ } \ } \ } \ } \ } \ } \ if ((op & 0xffff0000) == 0x59000000) { \ pc += 4; \ op = read_memory_integer ((pc), 4); \ if ((op & 0xffff0000) == 0x5F000000) { \ pc += 4; \ op = read_memory_integer ((pc), 4); \ if (op == 0xD4820008) { \ pc += 4; \ op = read_memory_integer ((pc), 4); \ if (op == 0x5582000C) { \ pc += 4; \ op = read_memory_integer ((pc), 2); \ if (op == 0x2fa0) { \ pc += 2; \ } else { \ op = read_memory_integer ((pc), 4); \ if (op == 0xd5030008) { \ pc += 4; \ } \ } \ } else { \ op = read_memory_integer ((pc), 2); \ if (op == 0x2fa0) { \ pc += 2; \ } \ } \ } \ } \ } \}/* Immediately after a function call, return the saved pc. Can't go through the frames for this because on some machines the new frame is not set up until the new function executes some instructions. True on PN! Return address is in R1. Note: true return location is 4 bytes past R1! */#define SAVED_PC_AFTER_CALL(frame) \ (read_register(R1_REGNUM) + 4)/* Address of end of stack space. */#define STACK_END_ADDR 0x480000/* Stack grows downward. */#define INNER_THAN </* Sequence of bytes for breakpoint instruction. */#define BREAKPOINT {0x28, 0x09}/* Amount PC must be decremented by after a breakpoint. This is often the number of bytes in BREAKPOINT but not always. */#define DECR_PC_AFTER_BREAK 2/* Nonzero if instruction at PC is a return instruction. "bu 4(r1)" */#define ABOUT_TO_RETURN(pc) (read_memory_integer (pc, 4) == 0xEC100004)/* Return 1 if P points to an invalid floating point value. */#define INVALID_FLOAT(p, len) ((*(short *)p & 0xff80) == 0x8000)/* Say how long (ordinary) registers are. */#define REGISTER_TYPE long/* Number of machine registers */#define NUM_REGS 19#define NUM_GEN_REGS 16#define NUM_CPU_REGS 3/* Initializer for an array of names of registers. There should be NUM_REGS strings in this initializer. */#define REGISTER_NAMES { \ "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7", \ "b0", "b1", "b2", "b3", "b4", "b5", "b6", "b7", \ "sp", "ps", "pc", \}/* Register numbers of various important registers. Note that some of these values are "real" register numbers, and correspond to the general registers of the machine, and some are "phony" register numbers which are too large
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -