Mercurial > hg > CbC > old > device
view mc.h @ 885:1a027275743d
struct returinng function have to be indirect.
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sat, 05 Apr 2014 21:12:43 +0900 |
parents | 5313ed059cee |
children | 8bdd5061cb8f |
line wrap: on
line source
/* Micro-C header file */ /************************************************************************ ** Copyright (C) 2006 Shinji Kono ** 連絡先: 琉球大学情報工学科 河野 真治 ** (E-Mail Address: kono@ie.u-ryukyu.ac.jp) ** ** このソースのいかなる複写,改変,修正も許諾します。ただし、 ** その際には、誰が貢献したを示すこの部分を残すこと。 ** 再配布や雑誌の付録などの問い合わせも必要ありません。 ** 営利利用も上記に反しない範囲で許可します。 ** バイナリの配布の際にはversion messageを保存することを条件とします。 ** このプログラムについては特に何の保証もしない、悪しからず。 ** ** Everyone is permitted to do anything on this program ** including copying, modifying, improving, ** as long as you don't try to pretend that you wrote it. ** i.e., the above copyright notice has to appear in all copies. ** Binary distribution requires original version messages. ** You don't have to ask before copying, redistribution or publishing. ** THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE. ***********************************************************************/ #define FLOAT_CODE 1 #define LONGLONG_CODE 1 #define CASE_CODE 1 #define ASM_CODE 1 #define BIT_FIELD_CODE 1 #define STRUCT_ALIGN 1 /* reserved word start */ /* type ( keyword ) */ #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 SIGNED (-10) #define LONG (-11) #define SHORT (-12) #define USHORT (-13) #define VOID (-14) #define CODE (-15) #define ENUM (-16) #define FLOAT (-17) #define DOUBLE (-18) #define LONGLONG (-19) #define ULONGLONG (-20) /* type qualifier */ #define KONST (-21) #define STATIC (-22) #define EXTRN (-23) #define EXTRN1 (-24) #define VOLATILE (-25) #define RESTRICT (-26) #define INLINE (-27) #define NOINLINE (-28) #define REGISTER (-29) #define FREGISTER (-30) #define DREGISTER (-31) #define LREGISTER (-32) #define POSSIBLE_VALUES (-33) #define DOTS (-34) /* keyword */ #define GOTO (-35) #define RETURN (-36) #define BREAK (-37) #define CONTINUE (-38) #define IF (-39) #define ELSE (-40) #define FOR (-41) #define DO (-42) #define WHILE (-43) #define SWITCH (-44) #define CASE (-45) #define DEFAULT (-46) #define RESERVE (-47) #define TAG (-48) #define FIELD (-49) #define IDENT (-50) #define MACRO (-51) #define BLABEL (-52) #define FLABEL (-53) #define TYPEDEF (-54) #define SIZEOF (-55) #define TYPE (-56) #define DEFINED (-57) #define ENVIRONMENT (-58) #define FMACRO (-59) #define LMACRO (-60) #define TYPEOF (-61) #define ASM (-62) #define C_FILE (-63) #define C_FUNCTION (-64) #define C_LINE (-65) #define ALIGNED (-66) #define GENERATED (-67) #define NORETURN (-68) #define ALWAYS_INLINE (-67) /* 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 #define LLDECL 16 #define SFDINIT 17 /* 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||i==ASM) #define OP(i) (i%SOP) /* tag value without attribute */ #define OP_TAG(i) (((i)/SOP)*SOP) /* attribute of tag */ /* 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 LCALL 10 #define COMMENT 11 #define DECL 12 #define COMP 13 #define IVAR 14 #define RIVAR 15 #define BUILTIN_INF 16 #define BUILTIN_INFF 17 #define BUILTIN_INFL 18 #define LABEL 19 #define STRINGS 20 #define NULLARY_ARGS(i) (i==RETURN||i==ENVIRONMENT||i==LCALL||i==REGISTER||i==DREGISTER||i==FREGISTER||i==LREGISTER||(GVAR<=(i%SOP)&&(i%SOP)<=LABEL)) /* unary argments */ #define ADDRESS 21 #define MINUS 22 #define LNOT 23 #define BNOT 24 #define INC 25 #define PERIOD 26 #define ARROW 27 #define POSTINC 28 #define UPOSTINC 29 #define PREINC 30 #define UPREINC 31 #define POSTDEC 32 #define UPOSTDEC 33 #define PREDEC 34 #define UPREDEC 35 #define DEC 36 #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 37 #define RINDIRECT 38 #define URINDIRECT 39 #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+URINDIRECT) #define RSTRUCT 40 #define ALLOCA 41 #define BUILTINP 42 #define BUILTIN_EXPECT 43 #define BUILTIN_FABS 44 #define BUILTIN_FABSF 45 #define BUILTIN_FABSL 46 #define ATTRIBUTE 47 #define BIT_FIELD 48 #define RBIT_FIELD 49 #define BPREINC 50 #define BPOSTINC 51 #define CAST 52 #define DECL_DATA 53 #define CONV 54 #define UNARY_ARGS(i) (ADDRESS<=(i%SOP)&&(i%SOP)<=CONV) /* binary argments */ #define MUL 55 #define UMUL 56 #define DIV 57 #define UDIV 58 #define MOD 59 #define UMOD 60 #define ADD 61 #define SUB 62 #define CMP 63 #define RSHIFT 64 #define URSHIFT 65 #define LSHIFT 66 #define ULSHIFT 67 #define GT 68 #define UGT 69 #define GE 70 #define UGE 71 #define LT 72 #define ULT 73 #define LE 74 #define ULE 75 #define EQ 76 #define NEQ 77 #define BAND 78 #define EOR 79 #define BOR 80 #define LAND 81 #define LOR 82 #define ASS 83 #define UCMP 84 #define UCMPGE 85 #define CMPGE 86 #define CMPEQ 87 #define CMPNEQ 88 #define ASSOP 89 #define UASSOP 90 #define COMMA 91 #define CASS (COP+ASS) #define CASSOP (COP+ASSOP) #define CUASSOP (COP+UASSOP) #define SASS (SOP+ASS) #define SASSOP (SOP+ASSOP) #define SUASSOP (SOP+UASSOP) #define DASS (DOP+ASS) #define DCMPGE (DOP+CMPGE) #define DCMPEQ (DOP+CMPEQ) #define DCMPNEQ (DOP+CMPNEQ) #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 FCMPEQ (FOP+CMPEQ) #define FCMPNEQ (FOP+CMPNEQ) #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 LCMPEQ (LOP+CMPEQ) #define LCMPNEQ (LOP+CMPNEQ) #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 BASS 92 #define BASSOP 93 #define BFD_REPL 94 #define JUMP 95 #define DECL_DATA_ARRAY 96 #define DECL_DATA_LIST 97 #define DECL_DATA_FIELD 98 #define STASS 99 #define BINARY_ARGS(i) ((MUL<=(i%SOP)&&(i%SOP)<=STASS)||i==ARRAY) /* ternary argments */ #define COND 100 #define UCOND 101 #define SCOND (SOP+COND) #define SUCOND (SOP+UCOND) #define DCOND (DOP+COND) #define FCOND (FOP+COND) #define LCOND (LOP+COND) #define LUCOND (LOP+UCOND) #define TERNARY_ARGS(i) (COND==(i%SOP)||UCOND==(i%SOP)) /* not appeared as tags */ #define LPAR 102 #define RPAR 103 #define LBRA 104 #define RBRA 105 #define LC 106 #define RC 107 #define COLON 108 #define SM 109 #define CNAME 110 #define I2C 111 #define I2S 112 #define I2I 113 #define I2U 114 #define I2D 115 #define I2F 116 #define I2LL 117 #define I2ULL 118 #define U2UC 119 #define U2US 120 #define U2I 121 #define U2U 122 #define U2D 123 #define U2F 124 #define U2LL 125 #define U2ULL 126 #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 BUILTIN_TYPES_COMPATIBLE_P 127 /* tree node tags end */ /* statement start */ #define ST_DECL 128 #define ST_IF 129 #define ST_DO 130 #define ST_WHILE 131 #define ST_FOR 132 #define ST_SWITCH 133 #define ST_COMP 134 #define ST_BREAK 135 #define ST_CONTINUE 136 #define ST_CASE 137 #define ST_DEFAULT 138 #define ST_RETURN 139 #define ST_GOTO 140 #define ST_ASM 141 #define ST_LABEL 142 #define ST_OP 143 #define ST_COMMENT 144 #define IS_STATEMENT(i) (i==INLINE||(ST_DECL<=i&&i<=ST_COMMENT)) #define HAS_ADDRESS 145 /* statement end */ /* error number start */ #define FILERR 1 #define DCERR 2 #define RDERR 3 #define STERR 4 #define EXERR 5 #define CNERR 6 #define CHERR 7 #define GSERR 8 #define LSERR 9 #define STRERR 10 #define LNERR 11 #define EOFERR 12 #define MCERR 13 #define INCERR 14 #define HPERR 15 #define TYERR 16 #define LVERR 17 #define UDERR 18 #define OPTION 19 #define REG_ERR 20 #define RGERR 21 #define CODE_ERR 22 #define MSERR 23 #define BTERR 24 #define HSERR 25 #define NMERR 26 #define MMERR 27 #define INERR 28 #define AGERR 29 #define ILERR 30 #define CSERR 31 #define GTERR 32 #define FNERR 33 #define UCERR 34 #define UFERR 35 #define ENERR 36 #define RETERR 37 #define UFLDERR 38 #define SIERR 39 /* error number end */ /* ctmode bit */ #define KONST_BIT 1 #define VOLATILE_BIT 2 #define RESTRICT_BIT 4 #define FILES 10 #define MAX_INCLUDE_PATH_COUNT 10 /* For this comiler 8192*2 is Ok. Linux kernel requires 8192*4. we need automatic increment of gsyms? */ #define GSYMS (8192*32) #define HEAPSIZE 150000 #define CHEAPSIZE (sizeof(NMTBL)*8192) #define LBUFSIZE 4096 #define STRSIZE 4096 typedef struct nametable { char *nm; struct nametable *next; int sc,attr; int ty,dsp; union { struct nametable *nptr; char *nm; } u; } NMTBL; extern int *heap; /* heap area (in cheap ) */ extern NMTBL *global_list; /* list of all global NMTBL */ extern NMTBL *local_static_list; /* list of local static variable */ #if FLOAT_CODE extern int dlist2(int e1, double e2); #endif #if LONGLONG_CODE 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 list3n(int e1, int e2, NMTBL *e3); extern int glist3n(int e1, int e2, NMTBL *e3); extern int list4(int e1, int e2, int e3,int e4); extern int list4n(int e1, int e2, int e3,NMTBL *e4); extern int list4s(int e1, int e2, int e3,char *e4); extern int glist4n(int e1, int e2, int e3,NMTBL *e4); extern int list5(int e1, int e2, int e3,int e4,int e5); extern int list5n(int e1, int e2, int e3,int e4,NMTBL * e5); extern int length(int e1); extern int getfree(int size); extern int nth(int n,int e1); extern int reverse0(int t1); extern int append4(int p,int a1,int a2,int a3); extern int append5(int p,int a1,int a2,int a3,int a4); extern int insert_ascend(int p,int e,int eq()); extern void free_nptr(NMTBL *n); extern NMTBL *get_nptr(); #define align(x,alig) ((x+(alig-1))&~(alig-1)) // mc-tree.c extern void print_expr(int e, FILE *vout); // #if 1 //extern int heapsize; // #define CHECK_HEAP1(b) ({int _k=(int)(b);if(_k>heapsize||_k<=0)error(-1);_k;}) //#else #define CHECK_HEAP(b) (b) //#endif #define car(e) (heap[(int)(CHECK_HEAP(e))]) #define cadr(e) (heap[((int)(CHECK_HEAP(e)))+1]) #define caddr(e) (heap[((int)(CHECK_HEAP(e)))+2]) #define cadddr(e) (heap[((int)(CHECK_HEAP(e)))+3]) #define caddddr(e) (heap[((int)(CHECK_HEAP(e)))+4]) #define ncaddr(e) (*(NMTBL**)&heap[((int)(e))+2]) #define ncadddr(e) (*(NMTBL**)&heap[((int)(e))+3]) #define ncaddddr(e) (*(NMTBL**)&heap[((int)(e))+4]) #define vcaddr(e) (*(void**)&heap[((int)(e))+2]) #define vcadddr(e) (*(void**)&heap[((int)(e))+3]) #define pcaddr(e) (*(int**)&heap[((int)(e))+2]) #define pcadddr(e) (*(int**)&heap[((int)(e))+3]) #define scaddr(e) (*(char**)&heap[((int)(e))+2]) #ifdef NOTHREAD my_spe_run_thread(t_args); #endif #define scadddr(e) (*(char**)&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 /* end */