⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tm-np1.h

📁 早期freebsd实现
💻 H
📖 第 1 页 / 共 2 页
字号:
/* Parameters for targeting on a Gould NP1, 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_NPL#define TARGET_BYTE_ORDER BIG_ENDIAN/* N_ENTRY appears in libraries on Gould machines.   Don't know what 0xa4 is; it's mentioned in stab.h   but only in the sdb symbol list.  */#define IGNORE_SYMBOL(type) (type == N_ENTRY || type == 0xa4)/* 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 NPL a.out format).  */#define	TEXTINFO						\        text_offset = N_TXTOFF (exec_coffhdr, exec_aouthdr);	\        exec_data_offset = N_TXTOFF (exec_coffhdr, exec_aouthdr)\                + exec_aouthdr.a_text/* Macro for number of symbol table entries */#define NUMBER_OF_SYMBOLS					\	(coffhdr.f_nsyms)/* Macro for file-offset of symbol table (in NPL a.out format).  */#define SYMBOL_TABLE_OFFSET					\	N_SYMOFF (coffhdr)/* Macro for file-offset of string table (in NPL a.out format).  */#define STRING_TABLE_OFFSET					\	(N_STROFF (coffhdr))/* 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 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	GNP1MAGIC#define	NS32SMAGIC	GPNMAGIC/* 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/* Address of blocks in N_LBRAC and N_RBRAC symbols are absolute addresses,   not relative to start of source address.  */#define BLOCK_ADDRESS_ABSOLUTE/* Offset from address of function to start of its code.   Zero on most machines.  */#define FUNCTION_START_OFFSET	8/* Advance PC across any function entry prologue instructions   to reach some "real" code.  One NPL we can have one 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) == 0xFA0B0000) { 				\	    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 NPL! Return address is in R1.   The true return address is REALLY 4 past that location! */#define SAVED_PC_AFTER_CALL(frame) \	(read_register(R1_REGNUM) + 4)/* Address of end of stack space.  */#define STACK_END_ADDR 		0x7fffc000/* Stack grows downward.  */#define INNER_THAN 		</* Sequence of bytes for breakpoint instruction.   This is padded out to the size of a machine word.  When it was just   {0x28, 0x09} it gave problems if hit breakpoint on returning from a   function call.  */#define BREAKPOINT 		{0x28, 0x09, 0x0, 0x0}/* 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) == 0x40100004)/* 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/* Size of bytes of vector register (NP1 only), 32 elements * sizeof(int) */#define VR_SIZE			128/* Number of machine registers */#define NUM_REGS 		27#define NUM_GEN_REGS		16#define NUM_CPU_REGS		4#define NUM_VECTOR_REGS		7/* 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", "ve", \  "v1", "v2", "v3", "v4", "v5", "v6", "v7", \}/* 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   to be actual register numbers as far as the user is concerned   but do serve to get the desired values when passed to read_register.  */#define R1_REGNUM	1	/* Gr1 => return address of caller */#define R2_REGNUM	2	/* Gr2 => return value from function */#define R4_REGNUM	4	/* Gr4 => register save area */#define R5_REGNUM	5	/* Gr5 => register save area */#define R6_REGNUM	6	/* Gr6 => register save area */#define R7_REGNUM	7	/* Gr7 => register save area */#define B1_REGNUM	9	/* Br1 => start of this code routine */#define SP_REGNUM	10	/* Br2 == (sp) */#define AP_REGNUM	11	/* Br3 == (ap) */#define FP_REGNUM 	16	/* A copy of Br2 saved in trap */#define PS_REGNUM 	17	/* Contains processor status */#define PC_REGNUM 	18	/* Contains program counter */#define VE_REGNUM 	19	/* Vector end (user setup) register */#define V1_REGNUM 	20	/* First vector register */#define V7_REGNUM 	26	/* First vector register *//* Total amount of space needed to store our copies of the machine's   register state, the array `registers'.  */#define REGISTER_BYTES \	(NUM_GEN_REGS*4 + NUM_VECTOR_REGS*VR_SIZE + NUM_CPU_REGS*4)/* Index within `registers' of the first byte of the space for   register N.  */#define REGISTER_BYTE(N)  \	(((N) < V1_REGNUM) ? ((N) * 4) : (((N) - V1_REGNUM) * VR_SIZE) + 80)/* Number of bytes of storage in the actual machine representation

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -