7e9348169c
The new feature "reglap" allows two sizes of floating-point register
variables (reg_float), if each register overlaps a single register of
the other size. PowerPC ncg uses reglap to define 4-byte instances
of f14 to f31 that overlap the 8-byte instances.
When ncgg sees the definition of fs14("f14")=f14, it removes the
8-byte f14 from its rvnumbers array, and adds the 4-byte fs14 in its
place. Later, when ncg puts a variable in fs14, if it is an 8-byte
variable, then ncg switches to the 8-byte f14. The code has
/* reglap */ comments in util/ncgg or #ifdef REGLAP in mach/proto/ncg
reglap became necessary because my commit a20b87c
caused PowerPC ego
to allocate reg_float in both 4-byte and 8-byte sizes.
55 lines
1.2 KiB
C
55 lines
1.2 KiB
C
/*
|
|
* (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands.
|
|
* See the copyright notice in the ACK home directory, in the file "Copyright".
|
|
*/
|
|
#ifndef NORCSID
|
|
static char rcsid[]= "$Id$";
|
|
#endif
|
|
|
|
#include "param.h"
|
|
#include "reg.h"
|
|
#include "property.h"
|
|
#include "token.h"
|
|
#include "set.h"
|
|
#include "instruct.h"
|
|
#include "lookup.h"
|
|
#include "extern.h"
|
|
#include <cgg_cg.h>
|
|
|
|
int wordsize;
|
|
int pointersize;
|
|
int nregs=1;
|
|
int nprops;
|
|
int ntokens=1;
|
|
int nsets;
|
|
int ninstr;
|
|
int codeindex;
|
|
int empatlen,emrepllen,emmnem[EMPATMAX];
|
|
int maxempatlen, maxemrepllen;
|
|
int empatexpr;
|
|
int tokpatlen,tokrepllen,tokpatset[TOKPATMAX],tokpatro[TOKPATMAX];
|
|
int maxtokpatlen, maxtokrepllen;
|
|
int nallreg,allreg[MAXALLREG];
|
|
int cursetno = -1;
|
|
int allsetno;
|
|
int inproc=0; /* scanning "procedure" */
|
|
int callproc=0;
|
|
int fc1=1,fc2=1,fc3=1,fc4=1;
|
|
int maxmembers=0;
|
|
int regclass=1;
|
|
int maxtokensize=0;
|
|
int rvused=0;
|
|
int reglap=0;
|
|
int nregvar[4];
|
|
int rvsize[4];
|
|
int rvnumbers[4][MAXREGVAR];
|
|
int procarg[MAXPROCARG];
|
|
int maxprocargs, nprocargs;
|
|
|
|
reginfo l_regs[MAXREGS];
|
|
propinfo l_props[MAXPROPS];
|
|
token_p l_tokens[MAXTOKENS];
|
|
set_t l_sets[MAXSETS];
|
|
instr_t l_instr[MAXINSTR];
|
|
symbol *symhash[NSYMHASH];
|