1987-03-09 19:15:41 +00:00
|
|
|
/*
|
|
|
|
* (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
|
|
|
|
* See the copyright notice in the ACK home directory, in the file "Copyright".
|
|
|
|
*/
|
1984-07-02 15:35:56 +00:00
|
|
|
#include "ass00.h"
|
|
|
|
#include "assex.h"
|
1984-11-08 12:08:31 +00:00
|
|
|
|
|
|
|
#ifndef NORCSID
|
|
|
|
static char rcs_id[] = "$Header$" ;
|
|
|
|
static char rcs_ass[]= RCS_ASS ;
|
|
|
|
static char rcs_ex[] = RCS_EX ;
|
|
|
|
#endif
|
|
|
|
|
1984-07-02 15:35:56 +00:00
|
|
|
/*
|
|
|
|
* global data
|
|
|
|
*/
|
|
|
|
|
|
|
|
int wordsize ;
|
|
|
|
int ptrsize ;
|
|
|
|
cons_t maxadr ;
|
|
|
|
cons_t maxint;
|
|
|
|
cons_t maxdint;
|
|
|
|
cons_t maxunsig;
|
|
|
|
cons_t maxdunsig;
|
|
|
|
|
|
|
|
/*
|
|
|
|
The structure containing used for procedure environment stacking
|
|
|
|
*/
|
|
|
|
stat_t pstate ;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* pointers to not yet allocated storage
|
|
|
|
*/
|
|
|
|
glob_t *mglobs; /* pointer to module symbols */
|
|
|
|
glob_t *xglobs; /* pointer to extern symbols */
|
|
|
|
proc_t *mprocs; /* pointer to local procs */
|
|
|
|
proc_t *xprocs; /* pointer to external procs */
|
|
|
|
ptab_t *proctab; /* pointer to proctab[] */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* some array and structures of known size
|
|
|
|
*/
|
|
|
|
FILE *ifile; /* input file buffer */
|
|
|
|
FILE *tfile; /* code file buffer */
|
|
|
|
FILE *dfile; /* data file buffer */
|
|
|
|
FILE *rtfile; /* code file buffer */
|
|
|
|
FILE *rdfile; /* data file buffer */
|
|
|
|
char string[MAXSTRING];
|
|
|
|
|
|
|
|
/*
|
|
|
|
* some other pointers
|
|
|
|
*/
|
|
|
|
glob_t *lastglosym; /* last global symbol */
|
|
|
|
glob_t *curglosym; /* current global symbol */
|
|
|
|
relc_t *f_data = (relc_t *)0 ; /* first data reloc pointer */
|
|
|
|
relc_t *l_data = (relc_t *)0 ; /* last data reloc pointer */
|
|
|
|
relc_t *f_text = (relc_t *)0 ; /* first text reloc pointer */
|
|
|
|
relc_t *l_text = (relc_t *)0 ; /* last text reloc pointer */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* some indices
|
|
|
|
*/
|
|
|
|
int strlngth; /* index in string[] */
|
|
|
|
FOFFSET inpoff; /* offset in current input file */
|
|
|
|
FOFFSET libeof; /* ceiling for above number */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* some other counters
|
|
|
|
*/
|
|
|
|
int procnum; /* generic for unique proc-descr. */
|
|
|
|
cons_t prog_size; /* length of current proc */
|
|
|
|
int max_bytes;
|
|
|
|
int pass;
|
|
|
|
int line_num; /* line number for error messages */
|
|
|
|
int nerrors; /* number of nonfatal errors */
|
|
|
|
cons_t consiz; /* size of U,I or F value */
|
|
|
|
cons_t textbytes; /* size of code file */
|
|
|
|
cons_t databytes; /* highwater mark in data */
|
|
|
|
FOFFSET dataoff; /* size of data file */
|
|
|
|
FOFFSET textoff; /* size of text file */
|
|
|
|
FOFFSET lastoff; /* previous size before last block */
|
|
|
|
int datamode; /* what kind of data */
|
|
|
|
int datablocks; /* number of datablocks written out */
|
|
|
|
relc_t *lastheader; /* pointer into datareloc */
|
|
|
|
cons_t holbase;
|
|
|
|
cons_t holsize;
|
|
|
|
int unresolved; /* # of unresolved references */
|
|
|
|
int sourcelines; /* number of lines in source program*/
|
|
|
|
int intflags = 1; /* flags for interpreter */
|
|
|
|
/*
|
|
|
|
* some flags
|
|
|
|
*/
|
|
|
|
int archmode; /* reading library ? */
|
|
|
|
int procflag; /* print "namelist" of procedures */
|
|
|
|
#ifdef DUMP
|
|
|
|
int c_flag; /* print unused opcodes */
|
|
|
|
char opcnt1[256]; /* count primary opcodes */
|
|
|
|
char opcnt2[256]; /* count secondary opcodes */
|
|
|
|
char opcnt3[256]; /* count long opcodes */
|
|
|
|
#endif
|
|
|
|
int d_flag = 0; /* don't dump */
|
|
|
|
int r_flag = 0; /* don't dump relocation tables */
|
|
|
|
#ifdef JOHAN
|
|
|
|
int jflag;
|
|
|
|
#endif
|
|
|
|
int wflag = 0; /* don't issue warning messages */
|
|
|
|
int eof_seen;
|
|
|
|
int mod_sizes; /* Size info in current module ok? */
|
|
|
|
|
|
|
|
#define BASE (sizeof (struct lines) - sizeof (addr_u))
|
|
|
|
|
|
|
|
char linesize[VALLOW+1] = {
|
|
|
|
BASE, /* MISSING */
|
|
|
|
BASE + sizeof (cons_t), /* CONST */
|
|
|
|
BASE + sizeof prp_cast, /* PROCNAME */
|
|
|
|
BASE + sizeof gbp_cast, /* GLOSYM */
|
|
|
|
BASE + sizeof lbp_cast, /* LOCSYM */
|
|
|
|
BASE + sizeof (struct sad_df), /* GLOOFF */
|
|
|
|
BASE + sizeof (struct sad_ln), /* LINES */
|
|
|
|
BASE /* VALLOW */
|
|
|
|
} ;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* miscellaneous
|
|
|
|
*/
|
|
|
|
char *progname; /* argv[0] */
|
|
|
|
char *curfile = 0; /* name of current file */
|
|
|
|
char *eout = "e.out";
|
|
|
|
arch_t archhdr;
|
1989-08-21 10:17:49 +00:00
|
|
|
siz_t sizes[NDEFAULT] = {
|
1984-07-02 15:35:56 +00:00
|
|
|
/* mlab, glab,mproc,xproc, proc */
|
|
|
|
{ 151, 29, 31, 73, 130 },
|
|
|
|
{ 307, 127, 151, 401, 460 },
|
1987-05-12 09:16:15 +00:00
|
|
|
{ 601, 251, 151, 401, 600 },
|
1987-11-11 15:05:41 +00:00
|
|
|
{1601, 1601, 1601, 1601, 2000 }
|
1984-07-02 15:35:56 +00:00
|
|
|
};
|
1989-08-21 10:17:49 +00:00
|
|
|
siz_t *oursize = &sizes[1] ; /* point to selected sizes */
|