view mc.h @ 196:5f70abd9453d

*** empty log message ***
author kono
date Wed, 07 Apr 2004 21:14:19 +0900
parents c193120ee2a6
children 3ae7e188416f
line wrap: on
line source

/* Micro-C header file */

#define DEBUG	error(-1)

/*#include "CCLIB.TXT" */
#ifdef __micro_c__
#include "stdio.h"
#else
#include <stdio.h> 
#include <stdlib.h> 
#endif

#define FLOAT_CODE 1
#define LONGLONG_CODE 0

#define SIZE_INT   4

/* reserved word start */

#define INT	(-1)
#define UNSIGNED	(-2)
#define CHAR	(-3)
#define UCHAR	(-4)
#define POINTER (-5)
#define ARRAY	(-6)
#define STRUCT	(-7)
#define UNION	(-8)
#define FUNCTION	(-9)

#define STATIC	(-10)
#define GOTO	(-11)
#define RETURN	(-12)
#define BREAK	(-13)
#define CONTINUE	(-14)
#define IF	(-15)
#define ELSE	(-16)
#define FOR	(-17)
#define DO	(-18)
#define WHILE	(-19)
#define SWITCH	(-20)
#define CASE	(-21)
#define DEFAULT (-22)
#define RESERVE (-23)
#define TAG	(-24)
#define FIELD	(-25)
#define IDENT	(-26)
#define MACRO	(-27)
#define BLABEL	(-28)
#define FLABEL	(-29)
#define TYPEDEF (-30)
#define SIZEOF	(-31)
#define TYPE	(-32)
#define LONG	(-33)
#define SHORT	(-34)
#define USHORT	(-35)
#define EXTRN	(-36)
#define EXTRN1	(-37)
#define VOID	(-38)
#define INLINE	(-39)
#define REGISTER	(-40)
#define FREGISTER      	(-41)
#define DREGISTER      	(-42)
#define LREGISTER      	(-43)
#define CODE	(-44)
#define ENVIRONMENT	(-45)
#define DEFINED	(-46)
#define ENUM	(-47)
#define KONST	(-48)
#define FMACRO	(-49)
#define LMACRO	(-50)
#define SIGNED	(-51)
#define DOTS	(-52)

#define FLOAT	(-53)
#define DOUBLE	(-54)
#define LONGLONG	(-55)
#define ULONGLONG	(-56)
#define VOLATILE	(-57)

/* reserved word end */

#define EMPTY	(-99)

/* mode start */
#define TOP	0
#define GDECL	1
#define GSDECL	2
#define GUDECL	3
#define ADECL	4
#define LDECL	5
#define LSDECL	6
#define LUDECL	7
#define STADECL 8
#define STAT	9
#define GTDECL	10
#define LTDECL	11
#define IFDEF	12
#define MDECL	13
#define GEDECL  14
#define LEDECL  15
/* mode end */

#define US	1
#define AS	10000
#define SOP	200
#define COP	400
#define DOP	600
#define FOP	800
#define LOP	1000

/* tree node tags start */

#define LIST_ARGS(i) (i==FUNCTION||i==CODE)

/* nullary  argments */

#define GVAR	1
#define RGVAR	2
#define URGVAR	3
#define LVAR	4
#define RLVAR	5
#define URLVAR	6
#define CRGVAR	(COP+RGVAR)
#define CURGVAR	(COP+URGVAR)
#define CRLVAR	(COP+RLVAR)
#define CURLVAR	(COP+URLVAR)
#define FRGVAR	(FOP+RGVAR)
#define FRLVAR	(FOP+RLVAR)
#define DRGVAR	(DOP+RGVAR)
#define DRLVAR	(DOP+RLVAR)
#define SRGVAR	(SOP+RGVAR)
#define SURGVAR	(SOP+URGVAR)
#define SRLVAR	(SOP+RLVAR)
#define SURLVAR	(SOP+URLVAR)
#define LRGVAR	(LOP+RGVAR)
#define LURGVAR	(LOP+URGVAR)
#define LRLVAR	(LOP+RLVAR)
#define LURLVAR	(LOP+URLVAR)

#define CONST	7
#define DCONST	(DOP+CONST)
#define FCONST	(FOP+CONST)
#define LCONST	(LOP+CONST)
#define STRING	8
#define FNAME	9

#define NULLARY_ARGS(i) (i==REGISTER||i==DREGISTER||i==FREGISTER||(GVAR<=(i%SOP)&&(i%SOP)<=FNAME))

/* unary  argments */

#define ADDRESS	10
#define MINUS	11
#define LNOT	12
#define BNOT	13
#define INC	14
#define POSTINC	15
#define UPOSTINC	16
#define PREINC	17
#define UPREINC	18
#define POSTDEC	19
#define UPOSTDEC	20
#define PREDEC	21
#define UPREDEC	22
#define DEC	23
#define CPOSTINC (COP+POSTINC)
#define CUPOSTINC (COP+UPOSTINC)
#define CPREINC (COP+PREINC)
#define CUPREINC (COP+UPREINC)
#define CPOSTDEC (COP+POSTDEC)
#define CUPOSTDEC (COP+UPOSTDEC)
#define CPREDEC (COP+CPREDEC)
#define CUPREDEC (COP+UPREDEC)
#define SPOSTINC (SOP+POSTINC)
#define SUPOSTINC (SOP+UPOSTINC)
#define SPREINC (SOP+PREINC)
#define SUPREINC (SOP+UPREINC)
#define SPOSTDEC (SOP+POSTDEC)
#define SUPOSTDEC (SOP+UPOSTDEC)
#define SPREDEC (SOP+PREDEC)
#define SUPREDEC (SOP+UPREDEC)
#define FPOSTINC	(FOP+POSTINC)
#define FPREINC	(FOP+PREINC)
#define DPOSTINC	(DOP+POSTINC)
#define DPREINC	(DOP+PREINC)
#define LPOSTINC	(LOP+POSTINC)
#define LPREINC	(LOP+PREINC)
#define LUPOSTINC	(LOP+UPOSTINC)
#define LUPREINC	(LOP+UPREINC)
#define INDIRECT	24
#define RINDIRECT	25
#define URINDIRECT	26
#define CRINDIRECT	(COP+RINDIRECT)
#define CURINDIRECT	(COP+URINDIRECT)
#define SRINDIRECT	(SOP+RINDIRECT)
#define SURINDIRECT	(SOP+URINDIRECT)
#define FRINDIRECT	(FOP+RINDIRECT)
#define DRINDIRECT	(DOP+RINDIRECT)
#define LRINDIRECT	(LOP+RINDIRECT)
#define LURINDIRECT	(LOP+CURINDIRECT)
#define RSTRUCT	27
#define CONV	28

#define UNARY_ARGS(i) (ADDRESS<=(i%SOP)&&(i%SOP)<=CONV)

/* binary  argments */

#define MUL	29
#define UMUL	30
#define DIV	31
#define UDIV	32
#define MOD	33
#define UMOD	34
#define ADD	35
#define SUB	36
#define CMP    	37	
#define RSHIFT	38
#define URSHIFT	39
#define LSHIFT	40
#define ULSHIFT	41
#define GT	42
#define UGT	43
#define GE	44
#define UGE	45
#define LT	46
#define ULT	47
#define LE	48
#define ULE	49
#define EQ	50
#define NEQ	51
#define BAND	52
#define EOR	53
#define BOR	54
#define LAND	55
#define LOR	56
#define ASS	57
#define CMPGE	58
#define ASSOP	59
#define COMMA	60

#define CASS	61
#define CASSOP	62
#define CUASSOP	63

#define SASS	(SOP+CASS)
#define SASSOP (SOP+CASSOP)
#define SUASSOP (SOP+CUASSOP)

#define DASS	(DOP+ASS)
#define DCMPGE	(DOP+CMPGE)
#define DASSOP	(DOP+ASSOP)
#define DCMP	(DOP+CMP)
#define DMINUS	(DOP+MINUS)
#define DMUL	(DOP+MUL)
#define DDIV	(DOP+DIV)
#define DADD	(DOP+ADD)
#define DSUB	(DOP+SUB)

#define FASS	(FOP+ASS)
#define FCMPGE	(FOP+CMPGE)
#define FASSOP	(FOP+ASSOP)
#define FCMP	(FOP+CMP)
#define FMINUS	(FOP+MINUS)
#define FMUL	(FOP+MUL)
#define FDIV	(FOP+DIV)
#define FADD	(FOP+ADD)
#define FSUB	(FOP+SUB)

#define LASS	(LOP+CASS)
#define LCMPGE	(LOP+CMPGE)
#define LASSOP  (LOP+CASSOP)
#define LUASSOP (LOP+CUASSOP)
#define LCMP	(LOP+CMP)
#define LMINUS	(LOP+MINUS)
#define LMUL	(LOP+MUL)
#define LDIV	(LOP+DIV)
#define LUMUL	(LOP+UMUL)
#define LUDIV	(LOP+UDIV)
#define LADD	(LOP+ADD)
#define LSUB	(LOP+SUB)


#define LMOD	(LOP+MOD)
#define LUMOD	(LOP+UMOD)
#define LLSHIFT	(LOP+LSHIFT)
#define LULSHIFT	(LOP+ULSHIFT)
#define LRSHIFT	(LOP+RSHIFT)
#define LURSHIFT	(LOP+URSHIFT)
#define LBAND	(LOP+BAND)
#define LEOR	(LOP+EOR)
#define LBOR	(LOP+BOR)


#define STASS	64

#define BINARY_ARGS(i) (MUL<=(i%SOP)&&(i%SOP)<=STASS)

/* tarnary  argments */

#define COND	65
#define SCOND	(SOP+COND)
#define DCOND	(DOP+COND)
#define FCOND	(FOP+COND)
#define LCOND	(LOP+COND)

#define TARNARY_ARGS(i) (COND==(i%SOP))

/* not appeared as tags */

#define I2I	66
#define I2U	67
#define I2D	68
#define I2F	69
#define I2LL	70
#define I2ULL	71

#define U2I	72
#define U2U	73
#define U2D	74
#define U2F	75
#define U2LL	76
#define U2ULL	77

#define D2I	(DOP+I2I)
#define D2U	(DOP+I2U)
#define D2D	(DOP+I2D)
#define D2F	(DOP+I2F)
#define D2LL	(DOP+I2LL)
#define D2ULL	(DOP+I2ULL)

#define F2I	(FOP+I2I)
#define F2U	(FOP+I2U)
#define F2D	(FOP+I2D)
#define F2F	(FOP+I2F)
#define F2LL	(FOP+I2LL)
#define F2ULL	(FOP+I2ULL)

#define LL2I	(LOP+I2I)
#define LL2U	(LOP+I2U)
#define LL2D	(LOP+I2D)
#define LL2F	(LOP+I2F)
#define LL2LL	(LOP+I2LL)
#define LL2ULL	(LOP+I2ULL)

#define ULL2I	(LOP+U2I)
#define ULL2U	(LOP+U2U)
#define ULL2D	(LOP+U2D)
#define ULL2F	(LOP+U2F)
#define ULL2LL	(LOP+U2LL)
#define ULL2ULL	(LOP+U2ULL)

#define LPAR	78
#define RPAR	79
#define LBRA	80
#define RBRA	81
#define LC	82
#define RC	83
#define COLON	84
#define SM	85
#define PERIOD	86
#define ARROW	87
#define CNAME	88

/* tree node tags end */

/* error number start */

#define FILERR	1
#define DCERR	2
#define STERR	3
#define EXERR	4
#define CNERR	5
#define CHERR	6
#define GSERR	7
#define LSERR	8
#define STRERR	9
#define LNERR	10
#define EOFERR	11
#define MCERR	12
#define INCERR	13
#define HPERR	14
#define TYERR	15
#define LVERR	16
#define UDERR	17
#define OPTION	18
#define REG_ERR	19
#define CODE_ERR	20
#define MSERR   21
/* error number end */

#define GSYMS	9000
#define LSYMS	500
#define MSYMS	3000

#define HEAPSIZE	30000
/* #define CHEAPSIZE	3000 */
#define CHEAPSIZE	356000
#define LBUFSIZE	4096
#define MACROSIZE	16000

#define FILES 10
#define OUTPUT_FILE_NAME "mcout.s"

EXTERN int sym,ch,type,mode,stmode,gfree,lfree,mflag,lineno,glineno;
EXTERN int labelno,gpc,disp,reg_var,debug;
EXTERN int symval,args,init_vars,heap[HEAPSIZE];
EXTERN int blabel,clabel,dlabel,cslabel,ilabel,control,ac,ac2,lsrc,chk,asmf;
EXTERN int MAX_REGISTER_VAR;

EXTERN unsigned hash;

EXTERN int chsave;
EXTERN int chptrsave;
EXTERN char linebuf[LBUFSIZE],namebuf[LBUFSIZE],*chptr;
EXTERN char *name,*cheapp,**av,/*obuf[320],*/*sptr,escape(void);
EXTERN int arg_offset,stat_no,size_of_int,size_of_short,disp_offset,endian,csvalue1;
EXTERN int code_arg_offset;
EXTERN int size_of_double,size_of_float,size_of_longlong;
EXTERN int retlabel,retpending,retcont;
EXTERN int arglist;

EXTERN FILE *obuf;

#if 1
typedef struct nametable {
	char *nm;
	int sc,ty,dsp; } NMTBL;
#else
typedef struct nametable {
	char *nm;
	int sc; int ty; int dsp; } NMTBL;
#endif

EXTERN NMTBL mtable[MSYMS];
EXTERN NMTBL ntable[GSYMS+LSYMS];
EXTERN NMTBL *nptr,*gnptr;
EXTERN NMTBL *fnptr;
EXTERN NMTBL null_nptr;
EXTERN int typedefed,gtypedefed;

EXTERN struct {int fd,ln;char *name0;int inc;FILE *fcb;} *filep,filestack[FILES];
EXTERN char cheap[CHEAPSIZE];
EXTERN char *macropp,macro_buf[MACROSIZE];

extern void macro_define(char *n);
extern void error(int n);
extern int size(int t);
extern int scalar(int t);
#if FLOAT_CODE
EXTERN double dsymval;
extern int dlist2(int e1, double e2);
#endif
#if LONGLONG_CODE
EXTERN long long lsymval;
extern int llist2(int e1, long long e2);
#endif
extern int list2(int e1, int e2);
extern int list3(int e1, int e2, int e3);
extern int list4(int e1, int e2, int e3,int e4);
extern int reverse0(int t1);
extern int assign_data(int e, int t, NMTBL *n,int offset);
extern int assign_expr0(int e1,int e2,int t,int type) ;
extern int assign_expr(int e1,int e2,int t,int type) ;
extern int append4(int p,int a1,int a2,int a3);



#define car(e) (heap[(int)(e)])

#define cadr(e) (heap[((int)(e))+1])

#define caddr(e) (heap[((int)(e))+2])

#define cadddr(e) (heap[((int)(e))+3])

#if FLOAT_CODE
#define dcadr(e) (*(double*)&heap[((int)(e))+1])
#define dcaddr(e) (*(double*)&heap[((int)(e))+2])
#endif

#if LONGLONG_CODE
#define lcadr(e) (*(long long*)&heap[((int)(e))+1])
#define lcaddr(e) (*(long long*)&heap[((int)(e))+2])
#endif

#include "conv/conv.h"
/*
#include "conv/c2cbc.h"
#include "conv/cbc2c.h"
 */

extern Converter *conv;

EXTERN void extern_define(char *s,int dsp,int type,int use);
EXTERN void error(int n);
EXTERN int append4(int p,int a1,int a2,int a3);
EXTERN int assign_expr(int e1,int e2,int t,int type);
EXTERN int assign_expr0(int e1,int e2,int t,int type);
EXTERN int backdef(void);
EXTERN int fwdlabel(void);
EXTERN int glist2(int e1,int e2);
EXTERN int glist3(int e1,int e2,int e3);
EXTERN void free_glist2(int e1);
EXTERN void free_glist3(int e1);
EXTERN int integral(int t);
EXTERN int integral(int t);
EXTERN int list2(int e1, int e2);
EXTERN int list3(int e1, int e2, int e3);
EXTERN int list4(int e1, int e2, int e3, int e4);
EXTERN int reverse0(int t1);
/*
EXTERN int rplacad(int e, int n);
EXTERN int rplacadd(int e, int n);
 */
EXTERN int rvalue_t(int e,int type);
EXTERN int scalar(int t);
EXTERN void bexpr(int e1, char cond, int l1);
EXTERN void def_label(int cslabel, int dlabel);
EXTERN void display_ntable(NMTBL *n, char *s);
EXTERN void exit(int l);
EXTERN void fwddef(int l);
EXTERN int new_lvar(int size);

EXTERN void free_lvar(int lvar);
EXTERN void init_free_lvar_list();

/* end */