xref: /OK3568_Linux_fs/kernel/arch/powerpc/boot/rs6000.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun /* IBM RS/6000 "XCOFF" file definitions for BFD.
3*4882a593Smuzhiyun    Copyright (C) 1990, 1991 Free Software Foundation, Inc.
4*4882a593Smuzhiyun    FIXME: Can someone provide a transliteration of this name into ASCII?
5*4882a593Smuzhiyun    Using the following chars caused a compiler warning on HIUX (so I replaced
6*4882a593Smuzhiyun    them with octal escapes), and isn't useful without an understanding of what
7*4882a593Smuzhiyun    character set it is.
8*4882a593Smuzhiyun    Written by Mimi Ph\373\364ng-Th\345o V\365 of IBM
9*4882a593Smuzhiyun    and John Gilmore of Cygnus Support.  */
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun /********************** FILE HEADER **********************/
12*4882a593Smuzhiyun 
13*4882a593Smuzhiyun struct external_filehdr {
14*4882a593Smuzhiyun 	char f_magic[2];	/* magic number			*/
15*4882a593Smuzhiyun 	char f_nscns[2];	/* number of sections		*/
16*4882a593Smuzhiyun 	char f_timdat[4];	/* time & date stamp		*/
17*4882a593Smuzhiyun 	char f_symptr[4];	/* file pointer to symtab	*/
18*4882a593Smuzhiyun 	char f_nsyms[4];	/* number of symtab entries	*/
19*4882a593Smuzhiyun 	char f_opthdr[2];	/* sizeof(optional hdr)		*/
20*4882a593Smuzhiyun 	char f_flags[2];	/* flags			*/
21*4882a593Smuzhiyun };
22*4882a593Smuzhiyun 
23*4882a593Smuzhiyun         /* IBM RS/6000 */
24*4882a593Smuzhiyun #define U802WRMAGIC     0730    /* writeable text segments **chh**      */
25*4882a593Smuzhiyun #define U802ROMAGIC     0735    /* readonly sharable text segments      */
26*4882a593Smuzhiyun #define U802TOCMAGIC    0737    /* readonly text segments and TOC       */
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun #define BADMAG(x)	\
29*4882a593Smuzhiyun 	((x).f_magic != U802ROMAGIC && (x).f_magic != U802WRMAGIC && \
30*4882a593Smuzhiyun 	 (x).f_magic != U802TOCMAGIC)
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #define	FILHDR	struct external_filehdr
33*4882a593Smuzhiyun #define	FILHSZ	20
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun 
36*4882a593Smuzhiyun /********************** AOUT "OPTIONAL HEADER" **********************/
37*4882a593Smuzhiyun 
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun typedef struct
40*4882a593Smuzhiyun {
41*4882a593Smuzhiyun   unsigned char	magic[2];	/* type of file			*/
42*4882a593Smuzhiyun   unsigned char	vstamp[2];	/* version stamp		*/
43*4882a593Smuzhiyun   unsigned char	tsize[4];	/* text size in bytes, padded to FW bdry */
44*4882a593Smuzhiyun   unsigned char	dsize[4];	/* initialized data "  "	*/
45*4882a593Smuzhiyun   unsigned char	bsize[4];	/* uninitialized data "   "	*/
46*4882a593Smuzhiyun   unsigned char	entry[4];	/* entry pt.			*/
47*4882a593Smuzhiyun   unsigned char	text_start[4];	/* base of text used for this file */
48*4882a593Smuzhiyun   unsigned char	data_start[4];	/* base of data used for this file */
49*4882a593Smuzhiyun   unsigned char	o_toc[4];	/* address of TOC */
50*4882a593Smuzhiyun   unsigned char	o_snentry[2];	/* section number of entry point */
51*4882a593Smuzhiyun   unsigned char	o_sntext[2];	/* section number of .text section */
52*4882a593Smuzhiyun   unsigned char	o_sndata[2];	/* section number of .data section */
53*4882a593Smuzhiyun   unsigned char	o_sntoc[2];	/* section number of TOC */
54*4882a593Smuzhiyun   unsigned char	o_snloader[2];	/* section number of .loader section */
55*4882a593Smuzhiyun   unsigned char	o_snbss[2];	/* section number of .bss section */
56*4882a593Smuzhiyun   unsigned char	o_algntext[2];	/* .text alignment */
57*4882a593Smuzhiyun   unsigned char	o_algndata[2];	/* .data alignment */
58*4882a593Smuzhiyun   unsigned char	o_modtype[2];	/* module type (??) */
59*4882a593Smuzhiyun   unsigned char o_cputype[2];	/* cpu type */
60*4882a593Smuzhiyun   unsigned char	o_maxstack[4];	/* max stack size (??) */
61*4882a593Smuzhiyun   unsigned char o_maxdata[4];	/* max data size (??) */
62*4882a593Smuzhiyun   unsigned char	o_resv2[12];	/* reserved */
63*4882a593Smuzhiyun }
64*4882a593Smuzhiyun AOUTHDR;
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun #define AOUTSZ 72
67*4882a593Smuzhiyun #define SMALL_AOUTSZ (28)
68*4882a593Smuzhiyun #define AOUTHDRSZ 72
69*4882a593Smuzhiyun 
70*4882a593Smuzhiyun #define	RS6K_AOUTHDR_OMAGIC	0x0107	/* old: text & data writeable */
71*4882a593Smuzhiyun #define	RS6K_AOUTHDR_NMAGIC	0x0108	/* new: text r/o, data r/w */
72*4882a593Smuzhiyun #define	RS6K_AOUTHDR_ZMAGIC	0x010B	/* paged: text r/o, both page-aligned */
73*4882a593Smuzhiyun 
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun /********************** SECTION HEADER **********************/
76*4882a593Smuzhiyun 
77*4882a593Smuzhiyun 
78*4882a593Smuzhiyun struct external_scnhdr {
79*4882a593Smuzhiyun 	char		s_name[8];	/* section name			*/
80*4882a593Smuzhiyun 	char		s_paddr[4];	/* physical address, aliased s_nlib */
81*4882a593Smuzhiyun 	char		s_vaddr[4];	/* virtual address		*/
82*4882a593Smuzhiyun 	char		s_size[4];	/* section size			*/
83*4882a593Smuzhiyun 	char		s_scnptr[4];	/* file ptr to raw data for section */
84*4882a593Smuzhiyun 	char		s_relptr[4];	/* file ptr to relocation	*/
85*4882a593Smuzhiyun 	char		s_lnnoptr[4];	/* file ptr to line numbers	*/
86*4882a593Smuzhiyun 	char		s_nreloc[2];	/* number of relocation entries	*/
87*4882a593Smuzhiyun 	char		s_nlnno[2];	/* number of line number entries*/
88*4882a593Smuzhiyun 	char		s_flags[4];	/* flags			*/
89*4882a593Smuzhiyun };
90*4882a593Smuzhiyun 
91*4882a593Smuzhiyun /*
92*4882a593Smuzhiyun  * names of "special" sections
93*4882a593Smuzhiyun  */
94*4882a593Smuzhiyun #define _TEXT	".text"
95*4882a593Smuzhiyun #define _DATA	".data"
96*4882a593Smuzhiyun #define _BSS	".bss"
97*4882a593Smuzhiyun #define _PAD	".pad"
98*4882a593Smuzhiyun #define _LOADER	".loader"
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun #define	SCNHDR	struct external_scnhdr
101*4882a593Smuzhiyun #define	SCNHSZ	40
102*4882a593Smuzhiyun 
103*4882a593Smuzhiyun /* XCOFF uses a special .loader section with type STYP_LOADER.  */
104*4882a593Smuzhiyun #define STYP_LOADER 0x1000
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun /* XCOFF uses a special .debug section with type STYP_DEBUG.  */
107*4882a593Smuzhiyun #define STYP_DEBUG 0x2000
108*4882a593Smuzhiyun 
109*4882a593Smuzhiyun /* XCOFF handles line number or relocation overflow by creating
110*4882a593Smuzhiyun    another section header with STYP_OVRFLO set.  */
111*4882a593Smuzhiyun #define STYP_OVRFLO 0x8000
112*4882a593Smuzhiyun 
113*4882a593Smuzhiyun /********************** LINE NUMBERS **********************/
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun /* 1 line number entry for every "breakpointable" source line in a section.
116*4882a593Smuzhiyun  * Line numbers are grouped on a per function basis; first entry in a function
117*4882a593Smuzhiyun  * grouping will have l_lnno = 0 and in place of physical address will be the
118*4882a593Smuzhiyun  * symbol table index of the function name.
119*4882a593Smuzhiyun  */
120*4882a593Smuzhiyun struct external_lineno {
121*4882a593Smuzhiyun 	union {
122*4882a593Smuzhiyun 		char l_symndx[4];	/* function name symbol index, iff l_lnno == 0*/
123*4882a593Smuzhiyun 		char l_paddr[4];	/* (physical) address of line number	*/
124*4882a593Smuzhiyun 	} l_addr;
125*4882a593Smuzhiyun 	char l_lnno[2];	/* line number		*/
126*4882a593Smuzhiyun };
127*4882a593Smuzhiyun 
128*4882a593Smuzhiyun 
129*4882a593Smuzhiyun #define	LINENO	struct external_lineno
130*4882a593Smuzhiyun #define	LINESZ	6
131*4882a593Smuzhiyun 
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun /********************** SYMBOLS **********************/
134*4882a593Smuzhiyun 
135*4882a593Smuzhiyun #define E_SYMNMLEN	8	/* # characters in a symbol name	*/
136*4882a593Smuzhiyun #define E_FILNMLEN	14	/* # characters in a file name		*/
137*4882a593Smuzhiyun #define E_DIMNUM	4	/* # array dimensions in auxiliary entry */
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun struct external_syment
140*4882a593Smuzhiyun {
141*4882a593Smuzhiyun   union {
142*4882a593Smuzhiyun     char e_name[E_SYMNMLEN];
143*4882a593Smuzhiyun     struct {
144*4882a593Smuzhiyun       char e_zeroes[4];
145*4882a593Smuzhiyun       char e_offset[4];
146*4882a593Smuzhiyun     } e;
147*4882a593Smuzhiyun   } e;
148*4882a593Smuzhiyun   char e_value[4];
149*4882a593Smuzhiyun   char e_scnum[2];
150*4882a593Smuzhiyun   char e_type[2];
151*4882a593Smuzhiyun   char e_sclass[1];
152*4882a593Smuzhiyun   char e_numaux[1];
153*4882a593Smuzhiyun };
154*4882a593Smuzhiyun 
155*4882a593Smuzhiyun 
156*4882a593Smuzhiyun 
157*4882a593Smuzhiyun #define N_BTMASK	(017)
158*4882a593Smuzhiyun #define N_TMASK		(060)
159*4882a593Smuzhiyun #define N_BTSHFT	(4)
160*4882a593Smuzhiyun #define N_TSHIFT	(2)
161*4882a593Smuzhiyun 
162*4882a593Smuzhiyun 
163*4882a593Smuzhiyun union external_auxent {
164*4882a593Smuzhiyun 	struct {
165*4882a593Smuzhiyun 		char x_tagndx[4];	/* str, un, or enum tag indx */
166*4882a593Smuzhiyun 		union {
167*4882a593Smuzhiyun 			struct {
168*4882a593Smuzhiyun 			    char  x_lnno[2]; /* declaration line number */
169*4882a593Smuzhiyun 			    char  x_size[2]; /* str/union/array size */
170*4882a593Smuzhiyun 			} x_lnsz;
171*4882a593Smuzhiyun 			char x_fsize[4];	/* size of function */
172*4882a593Smuzhiyun 		} x_misc;
173*4882a593Smuzhiyun 		union {
174*4882a593Smuzhiyun 			struct {		/* if ISFCN, tag, or .bb */
175*4882a593Smuzhiyun 			    char x_lnnoptr[4];	/* ptr to fcn line # */
176*4882a593Smuzhiyun 			    char x_endndx[4];	/* entry ndx past block end */
177*4882a593Smuzhiyun 			} x_fcn;
178*4882a593Smuzhiyun 			struct {		/* if ISARY, up to 4 dimen. */
179*4882a593Smuzhiyun 			    char x_dimen[E_DIMNUM][2];
180*4882a593Smuzhiyun 			} x_ary;
181*4882a593Smuzhiyun 		} x_fcnary;
182*4882a593Smuzhiyun 		char x_tvndx[2];		/* tv index */
183*4882a593Smuzhiyun 	} x_sym;
184*4882a593Smuzhiyun 
185*4882a593Smuzhiyun 	union {
186*4882a593Smuzhiyun 		char x_fname[E_FILNMLEN];
187*4882a593Smuzhiyun 		struct {
188*4882a593Smuzhiyun 			char x_zeroes[4];
189*4882a593Smuzhiyun 			char x_offset[4];
190*4882a593Smuzhiyun 		} x_n;
191*4882a593Smuzhiyun 	} x_file;
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun 	struct {
194*4882a593Smuzhiyun 		char x_scnlen[4];			/* section length */
195*4882a593Smuzhiyun 		char x_nreloc[2];	/* # relocation entries */
196*4882a593Smuzhiyun 		char x_nlinno[2];	/* # line numbers */
197*4882a593Smuzhiyun 	} x_scn;
198*4882a593Smuzhiyun 
199*4882a593Smuzhiyun         struct {
200*4882a593Smuzhiyun 		char x_tvfill[4];	/* tv fill value */
201*4882a593Smuzhiyun 		char x_tvlen[2];	/* length of .tv */
202*4882a593Smuzhiyun 		char x_tvran[2][2];	/* tv range */
203*4882a593Smuzhiyun 	} x_tv;		/* info about .tv section (in auxent of symbol .tv)) */
204*4882a593Smuzhiyun 
205*4882a593Smuzhiyun 	struct {
206*4882a593Smuzhiyun 		unsigned char x_scnlen[4];
207*4882a593Smuzhiyun 		unsigned char x_parmhash[4];
208*4882a593Smuzhiyun 		unsigned char x_snhash[2];
209*4882a593Smuzhiyun 		unsigned char x_smtyp[1];
210*4882a593Smuzhiyun 		unsigned char x_smclas[1];
211*4882a593Smuzhiyun 		unsigned char x_stab[4];
212*4882a593Smuzhiyun 		unsigned char x_snstab[2];
213*4882a593Smuzhiyun 	} x_csect;
214*4882a593Smuzhiyun 
215*4882a593Smuzhiyun };
216*4882a593Smuzhiyun 
217*4882a593Smuzhiyun #define	SYMENT	struct external_syment
218*4882a593Smuzhiyun #define	SYMESZ	18
219*4882a593Smuzhiyun #define	AUXENT	union external_auxent
220*4882a593Smuzhiyun #define	AUXESZ	18
221*4882a593Smuzhiyun #define DBXMASK 0x80		/* for dbx storage mask */
222*4882a593Smuzhiyun #define SYMNAME_IN_DEBUG(symptr) ((symptr)->n_sclass & DBXMASK)
223*4882a593Smuzhiyun 
224*4882a593Smuzhiyun 
225*4882a593Smuzhiyun 
226*4882a593Smuzhiyun /********************** RELOCATION DIRECTIVES **********************/
227*4882a593Smuzhiyun 
228*4882a593Smuzhiyun 
229*4882a593Smuzhiyun struct external_reloc {
230*4882a593Smuzhiyun   char r_vaddr[4];
231*4882a593Smuzhiyun   char r_symndx[4];
232*4882a593Smuzhiyun   char r_size[1];
233*4882a593Smuzhiyun   char r_type[1];
234*4882a593Smuzhiyun };
235*4882a593Smuzhiyun 
236*4882a593Smuzhiyun 
237*4882a593Smuzhiyun #define RELOC struct external_reloc
238*4882a593Smuzhiyun #define RELSZ 10
239*4882a593Smuzhiyun 
240*4882a593Smuzhiyun #define DEFAULT_DATA_SECTION_ALIGNMENT 4
241*4882a593Smuzhiyun #define DEFAULT_BSS_SECTION_ALIGNMENT 4
242*4882a593Smuzhiyun #define DEFAULT_TEXT_SECTION_ALIGNMENT 4
243*4882a593Smuzhiyun /* For new sections we haven't heard of before */
244*4882a593Smuzhiyun #define DEFAULT_SECTION_ALIGNMENT 4
245