diff options
author | John Gilmore <gnu@cygnus> | 1991-08-23 08:56:39 +0000 |
---|---|---|
committer | John Gilmore <gnu@cygnus> | 1991-08-23 08:56:39 +0000 |
commit | d7f8f106b9efaaa99a279070fcdfbac95bad483e (patch) | |
tree | 3e25ae256a4ac818494dfc4f8b9cb7ed9ad225b7 /include | |
parent | 299eb5f15fdf2488fe7f0268bf4f545baeae1d20 (diff) | |
download | gdb-d7f8f106b9efaaa99a279070fcdfbac95bad483e.zip gdb-d7f8f106b9efaaa99a279070fcdfbac95bad483e.tar.gz gdb-d7f8f106b9efaaa99a279070fcdfbac95bad483e.tar.bz2 |
* a.out.gnu.h, a.out.sun4.h: Make SEGMENT_SIZE able to depend
on the particular a.out being examined.
* a.out.sun4.h: Define segment sizes for Sun-3's and Sun-4's.
* FIXME: a.out.gnu.h is almost obsolete.
* FIXME: a.out.sun4.h should be renamed a.out.sun.h now.
Diffstat (limited to 'include')
-rwxr-xr-x | include/a.out.sun4.h | 11 | ||||
-rwxr-xr-x | include/aout64.h | 10 |
2 files changed, 18 insertions, 3 deletions
diff --git a/include/a.out.sun4.h b/include/a.out.sun4.h index 4ce569d..6c456d3 100755 --- a/include/a.out.sun4.h +++ b/include/a.out.sun4.h @@ -2,11 +2,20 @@ #define PAGE_SIZE 0x2000 /* 8K. aka NBPG in <sys/param.h> */ /* Note that some SPARCs have 4K pages, some 8K, some others. */ -#define SEGMENT_SIZE PAGE_SIZE + +#define SEG_SIZE_SPARC PAGE_SIZE +#define SEG_SIZE_SUN3 0x80000 /* Resolution of r/w protection hw */ + #define TEXT_START_ADDR PAGE_SIZE /* Location 0 is not accessible */ /* Non-default definitions of the accessor macros... */ +/* Segment size varies on Sun-3 versus Sun-4. */ + +#define N_SEGSIZE(x) (N_MACHTYPE(x) == M_SPARC? SEG_SIZE_SPARC: \ + N_MACHTYPE(x) == M_68020? SEG_SIZE_SUN3: \ + /* Guess? */ PAGE_SIZE) + /* Offset in a.out file of the text section. For ZMAGIC, the text section actually includes the a.out header. */ diff --git a/include/aout64.h b/include/aout64.h index 16d0b48..88df303 100755 --- a/include/aout64.h +++ b/include/aout64.h @@ -72,7 +72,13 @@ enum machine_type { ((exec).a_info = \ ((exec).a_info&0x00ffffff) | (((flags) & 0xff) << 24)) -#define _N_HDROFF(x) (SEGMENT_SIZE - EXEC_BYTES_SIZE) +/* By default, segment size is constant. But on some machines, it can + be a function of the a.out header (e.g. machine type). */ +#ifndef N_SEGSIZE +#define N_SEGSIZE(x) SEGMENT_SIZE +#endif + +#define _N_HDROFF(x) (N_SEGSIZE(x) - EXEC_BYTES_SIZE) /* address in an a.out of the text section. When demand paged, it's set up a bit to make nothing at 0, when an object file it's 0. There's a special hack case when the entry point is < TEXT_START_ADDR @@ -111,7 +117,7 @@ enum machine_type { #define N_DATADDR(x) \ (N_MAGIC(x)==OMAGIC? (N_TXTADDR(x)+(x).a_text) \ - : (SEGMENT_SIZE + ((N_TXTADDR(x)+(x).a_text-1) & ~(SEGMENT_SIZE-1)))) + : (N_SEGSIZE(x) + ((N_TXTADDR(x)+(x).a_text-1) & ~(N_SEGSIZE(x)-1)))) #define N_BSSADDR(x) (N_DATADDR(x) + (x).a_data) |