Home | History | Annotate | Line # | Download | only in include
      1  1.2       snj /*	$NetBSD: som.h,v 1.2 2009/11/03 05:07:26 snj Exp $	*/
      2  1.1  fredette 
      3  1.1  fredette /*	$OpenBSD: som.h,v 1.3 1999/12/23 04:09:44 mickey Exp $	*/
      4  1.1  fredette 
      5  1.1  fredette /*
      6  1.1  fredette  * Copyright (c) 1998 Michael Shalayeff
      7  1.1  fredette  * All rights reserved.
      8  1.1  fredette  *
      9  1.1  fredette  * Redistribution and use in source and binary forms, with or without
     10  1.1  fredette  * modification, are permitted provided that the following conditions
     11  1.1  fredette  * are met:
     12  1.1  fredette  * 1. Redistributions of source code must retain the above copyright
     13  1.1  fredette  *    notice, this list of conditions and the following disclaimer.
     14  1.1  fredette  * 2. Redistributions in binary form must reproduce the above copyright
     15  1.1  fredette  *    notice, this list of conditions and the following disclaimer in the
     16  1.1  fredette  *    documentation and/or other materials provided with the distribution.
     17  1.1  fredette  *
     18  1.1  fredette  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     19  1.1  fredette  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     20  1.1  fredette  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     21  1.2       snj  * IN NO EVENT SHALL THE AUTHOR OR HIS RELATIVES BE LIABLE FOR ANY DIRECT,
     22  1.2       snj  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
     23  1.2       snj  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
     24  1.2       snj  * SERVICES; LOSS OF MIND, USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     25  1.2       snj  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     26  1.2       snj  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
     27  1.2       snj  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
     28  1.2       snj  * THE POSSIBILITY OF SUCH DAMAGE.
     29  1.1  fredette  */
     30  1.1  fredette 
     31  1.1  fredette #ifndef	_HPPA_SOM_H_
     32  1.1  fredette #define	_HPPA_SOM_H_
     33  1.1  fredette 
     34  1.1  fredette /* system_id */
     35  1.1  fredette #define	SOM_BSD		800
     36  1.1  fredette #define	SOM_PA10	0x20b
     37  1.1  fredette #define	SOM_PA11	0x210
     38  1.1  fredette #define	SOM_PA12	0x211
     39  1.1  fredette #define	SOM_PA20	0x214
     40  1.1  fredette 
     41  1.1  fredette /* a_magic */
     42  1.1  fredette #define	SOM_MAGIC	0x107
     43  1.1  fredette #define	SOM_SHARED	0x108
     44  1.1  fredette #define	SOM_DEMAND	0x10B
     45  1.1  fredette 
     46  1.1  fredette #define	SOM_BADMAGIC(fh) \
     47  1.1  fredette 	((fh)->system_id != SOM_PA10 && \
     48  1.1  fredette 	 (fh)->system_id != SOM_PA11 && \
     49  1.1  fredette 	 (fh)->system_id != SOM_PA12 && \
     50  1.1  fredette 	 (fh)->system_id != SOM_PA20)
     51  1.1  fredette 
     52  1.1  fredette struct som_filehdr {
     53  1.1  fredette 	u_short system_id;
     54  1.1  fredette 	u_short a_magic;
     55  1.1  fredette 	u_int   version_id;
     56  1.1  fredette 	u_int	time_secs;		/* sys time (zero if unused) */
     57  1.1  fredette 	u_int	time_nsecs;
     58  1.1  fredette 	u_int	ep_space;		/* ep space */
     59  1.1  fredette 	u_int	ep_subspace;
     60  1.1  fredette 	u_int	entry;			/* how is it different from a_entry? */
     61  1.1  fredette 	u_int	aux_loc;		/* aux header location */
     62  1.1  fredette 	u_int	aux_size;
     63  1.1  fredette 	u_int	som_length;		/* entire image length */
     64  1.1  fredette 	u_int	dp;			/* dp presumed at compilation time */
     65  1.1  fredette 	u_int	space_loc;		/* space dictionary location */
     66  1.1  fredette 	u_int	space_total;		/* N of entries in the space dict */
     67  1.1  fredette 	u_int	subspace_loc;		/* subspace dict location */
     68  1.1  fredette 	u_int	subspace_total;		/* N of entries in the subspace dict */
     69  1.1  fredette 	u_int	ld_fixup_loc;		/* space ref array (relocs?) */
     70  1.1  fredette 	u_int	ld_fixup_total;		/* N of space ref records */
     71  1.1  fredette 	u_int	space_str_loc;		/* {,sub}space string table location */
     72  1.1  fredette 	u_int	space_str_size;		/* size of the above */
     73  1.1  fredette 	u_int	init_loc;		/* init ptrs location */
     74  1.1  fredette 	u_int	init_total;		/* N of entries in the above */
     75  1.1  fredette 	u_int	dict_loc;		/* module dictionary location */
     76  1.1  fredette 	u_int	dict_total;		/* number of modules */
     77  1.1  fredette 	u_int	sym_loc;		/* symbol table location */
     78  1.1  fredette 	u_int	sym_total;		/* N of symbols */
     79  1.1  fredette 	u_int	fixup_loc;		/* fixpup reqs location */
     80  1.1  fredette 	u_int	fixup_total;		/* N of the fixup reqs */
     81  1.1  fredette 	u_int	strings_loc;		/* string table location */
     82  1.1  fredette 	u_int	strings_size;		/* size of the strings table */
     83  1.1  fredette 	u_int	unloadable_loc;		/* unloadable spaces location */
     84  1.1  fredette 	u_int	unloadable_size;	/* size of the unloadable spaces */
     85  1.1  fredette 	u_int	checksum;		/* header checksum? */
     86  1.1  fredette };
     87  1.1  fredette 
     88  1.1  fredette struct som_exec_aux {
     89  1.1  fredette 	u_int	mandatory : 1;
     90  1.1  fredette 	u_int	copy : 1;
     91  1.1  fredette 	u_int	append : 1;
     92  1.1  fredette 	u_int	ignore : 1;
     93  1.1  fredette 	u_int	reserved : 12;
     94  1.1  fredette 	u_int	type : 16;
     95  1.1  fredette 	u_int	length;
     96  1.1  fredette 	long	a_tsize;
     97  1.1  fredette 	long	a_tmem;
     98  1.1  fredette 	long	a_tfile;
     99  1.1  fredette 	long	a_dsize;
    100  1.1  fredette 	long	a_dmem;
    101  1.1  fredette 	long	a_dfile;
    102  1.1  fredette 	long	a_bsize;
    103  1.1  fredette 	long	a_entry;
    104  1.1  fredette 	long	a_flags;
    105  1.1  fredette 	long	a_bfill;
    106  1.1  fredette };
    107  1.1  fredette 
    108  1.1  fredette struct som_sym {
    109  1.1  fredette 	u_int	sym_type : 8;
    110  1.1  fredette 	u_int	sym_scope : 4;
    111  1.1  fredette 	u_int	sym_chklevel : 3;
    112  1.1  fredette 	u_int	sym_qualify : 1;
    113  1.1  fredette 	u_int	sym_ifrozen : 1;
    114  1.1  fredette 	u_int	sym_resident : 1;
    115  1.1  fredette 	u_int	sym_is_common : 1;
    116  1.1  fredette 	u_int	sym_dup_common : 1;
    117  1.1  fredette 	u_int	sym_xleast : 2;
    118  1.1  fredette 	u_int	sym_arg_reloc : 10;
    119  1.1  fredette 	union {
    120  1.1  fredette 		char *n_name;
    121  1.1  fredette 		u_int n_strx;
    122  1.1  fredette 	} sym_name, sym_qualifier_name;
    123  1.1  fredette 	u_int	sym_info;
    124  1.1  fredette 	u_int	sym_value;
    125  1.1  fredette 
    126  1.1  fredette };
    127  1.1  fredette 
    128  1.1  fredette /* sym_type */
    129  1.1  fredette #define	SOM_ST_NULL		0
    130  1.1  fredette #define	SOM_ST_ABS		1
    131  1.1  fredette #define	SOM_ST_DATA		2
    132  1.1  fredette #define	SOM_ST_CODE		3
    133  1.1  fredette #define	SOM_ST_PRI_PROG		4
    134  1.1  fredette #define	SOM_ST_SEC_PROG		5
    135  1.1  fredette #define	SOM_ST_ENTRY		6
    136  1.1  fredette #define	SOM_ST_STORAGE		7
    137  1.1  fredette #define	SOM_ST_STUB		8
    138  1.1  fredette #define	SOM_ST_MODULE		9
    139  1.1  fredette #define	SOM_ST_SYM_EXT		10
    140  1.1  fredette #define	SOM_ST_ARG_EXT		11
    141  1.1  fredette #define	SOM_ST_MILLICODE	12
    142  1.1  fredette #define	SOM_ST_PLABEL		13
    143  1.1  fredette 
    144  1.1  fredette /* sym_scope */
    145  1.1  fredette #define	SOM_SS_UNSAT		0
    146  1.1  fredette #define	SOM_SS_EXTERNAL		1
    147  1.1  fredette #define	SOM_SS_GLOBAL		2
    148  1.1  fredette #define	SOM_SS_UNIVERSAL	3
    149  1.1  fredette 
    150  1.1  fredette #endif /* _HPPA_SOM_H_ */
    151