⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 a.y

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 Y
字号:
%{#include "a.h"%}%union{	Sym	*sym;	long	lval;	double	dval;	char	sval[8];	Gen	gen;}%left	'|'%left	'^'%left	'&'%left	'<' '>'%left	'+' '-'%left	'*' '/' '%'%token	<lval>	LTYPE1 LTYPE2 LTYPE3 LTYPE4 LTYPE5%token	<lval>	LTYPE6 LTYPE7 LTYPE8 LTYPE9 LTYPEA%token	<lval>	LTYPEB LTYPEC LTYPED LTYPEE LTYPEF%token	<lval>	LTYPEG LTYPEH LTYPEI LTYPEJ LTYPEK%token	<lval>	LCONST LSP LSB LFP LPC LHI LLO LMREG %token	<lval>	LTYPEX LREG LFREG LFCREG LR LM LF%token	<lval>	LFCR LSCHED%token	<dval>	LFCONST%token	<sval>	LSCONST%token	<sym>	LNAME LLAB LVAR%type	<lval>	con expr pointer offset sreg%type	<gen>	gen vgen lgen vlgen rel reg freg mreg fcreg%type	<gen>	imm ximm ireg name oreg imr nireg fgen%%prog:|	prog lineline:	LLAB ':'	{		if($1->value != pc)			yyerror("redeclaration of %s", $1->name);		$1->value = pc;	}	line|	LNAME ':'	{		$1->type = LLAB;		$1->value = pc;	}	line|	LNAME '=' expr ';'	{		$1->type = LVAR;		$1->value = $3;	}|	LVAR '=' expr ';'	{		if($1->value != $3)			yyerror("redeclaration of %s", $1->name);		$1->value = $3;	}|	LSCHED ';'	{		nosched = $1;	}|	';'|	inst ';'|	error ';'inst:/* * Immed-type */	LTYPE1 imr ',' sreg ',' reg	{		outcode($1, &$2, $4, &$6);	}|	LTYPE1 imr ',' reg	{		outcode($1, &$2, NREG, &$4);	}/* * NOR */|	LTYPE2 imr ',' sreg ',' imr	{		outcode($1, &$2, $4, &$6);	}|	LTYPE2 imr ',' imr	{		outcode($1, &$2, NREG, &$4);	}/* * LOAD/STORE, but not MOVW */|	LTYPE3 lgen ',' gen	{		if(!isreg(&$2) && !isreg(&$4))			print("one side must be register\n");		outcode($1, &$2, NREG, &$4);	}/* * SPECIAL */|	LTYPE4 comma	{		outcode($1, &nullgen, NREG, &nullgen);	}/* * MOVW */|	LTYPE5 vlgen ',' vgen	{		if(!isreg(&$2) && !isreg(&$4))			print("one side must be register\n");		outcode($1, &$2, NREG, &$4);	}/* * MUL/DIV */|	LTYPE6 reg ',' sreg comma	{		outcode($1, &$2, $4, &nullgen);	}|	LTYPE6 reg ',' sreg ',' reg	{		outcode($1, &$2, $4, &$6);	}/* * JMP/JAL */|	LTYPE7 comma rel	{		outcode($1, &nullgen, NREG, &$3);	}|	LTYPE7 comma nireg	{		outcode($1, &nullgen, NREG, &$3);	}|	LTYPE8 comma rel	{		outcode($1, &nullgen, NREG, &$3);	}|	LTYPE8 comma nireg	{		outcode($1, &nullgen, NREG, &$3);	}|	LTYPE8 sreg ',' nireg	{		outcode($1, &nullgen, $2, &$4);	}/* * BEQ/BNE */|	LTYPE9 gen ',' rel	{		if(!isreg(&$2))			print("left side must be register\n");		outcode($1, &$2, NREG, &$4);	}|	LTYPE9 gen ',' sreg ',' rel	{		if(!isreg(&$2))			print("left side must be register\n");		outcode($1, &$2, $4, &$6);	}/* * B-other */|	LTYPEA gen ',' rel	{		if(!isreg(&$2))			print("left side must be register\n");		outcode($1, &$2, NREG, &$4);	}/* * TEXT/GLOBL */|	LTYPEB name ',' imm	{		outcode($1, &$2, NREG, &$4);	}|	LTYPEB name ',' con ',' imm	{		outcode($1, &$2, $4, &$6);	}/* * DATA */|	LTYPEC name '/' con ',' ximm	{		outcode($1, &$2, $4, &$6);	}/* * floating-type */|	LTYPED freg ',' freg	{		outcode($1, &$2, NREG, &$4);	}|	LTYPEE freg ',' freg	{		outcode($1, &$2, NREG, &$4);	}|	LTYPEE freg ',' LFREG ',' freg	{		outcode($1, &$2, $4, &$6);	}|	LTYPEF freg ',' LFREG comma	{		outcode($1, &$2, $4, &nullgen);	}/* * coprocessor branch */|	LTYPEG comma rel	{		outcode($1, &nullgen, NREG, &$3);	}/* * word */|	LTYPEH comma ximm	{		outcode($1, &nullgen, NREG, &$3);	}/* * NOP */|	LTYPEI comma	{		outcode($1, &nullgen, NREG, &nullgen);	}|	LTYPEI ',' vgen	{		outcode($1, &nullgen, NREG, &$3);	}|	LTYPEI vgen comma	{		outcode($1, &$2, NREG, &nullgen);	}/* * BREAK -- overloaded with CACHE opcode */|	LTYPEJ comma	{		outcode($1, &nullgen, NREG, &nullgen);	}|	LTYPEJ vgen ',' vgen	{		outcode($1, &$2, NREG, &$4);	}comma:|	','rel:	con '(' LPC ')'	{		$$ = nullgen;		$$.type = D_BRANCH;		$$.offset = $1 + pc;	}|	LNAME offset	{		$$ = nullgen;		if(pass == 2)			yyerror("undefined label: %s", $1->name);		$$.type = D_BRANCH;		$$.sym = $1;		$$.offset = $2;	}|	LLAB offset	{		$$ = nullgen;		$$.type = D_BRANCH;		$$.sym = $1;		$$.offset = $1->value + $2;	}vlgen:	lgen|	fgen|	mreg|	fcreg|	LHI	{		$$ = nullgen;		$$.type = D_HI;	}|	LLO	{		$$ = nullgen;		$$.type = D_LO;	}vgen:	gen|	fgen|	mreg|	fcreg|	LHI	{		$$ = nullgen;		$$.type = D_HI;	}|	LLO	{		$$ = nullgen;		$$.type = D_LO;	}lgen:	gen|	ximmfgen:	fregmreg:	LMREG	{		$$ = nullgen;		$$.type = D_MREG;		$$.reg = $1;	}|	LM '(' con ')'	{		$$ = nullgen;		$$.type = D_MREG;		$$.reg = $3;	}fcreg:	LFCREG	{		$$ = nullgen;		$$.type = D_FCREG;		$$.reg = $1;	}|	LFCR '(' con ')'	{		$$ = nullgen;		$$.type = D_FCREG;		$$.reg = $3;	}freg:	LFREG	{		$$ = nullgen;		$$.type = D_FREG;		$$.reg = $1;	}|	LF '(' con ')'	{		$$ = nullgen;		$$.type = D_FREG;		$$.reg = $3;	}ximm:	'$' con	{		$$ = nullgen;		$$.type = D_CONST;		$$.offset = $2;	}|	'$' oreg	{		$$ = $2;		$$.type = D_CONST;	}|	'$' '*' '$' oreg	{		$$ = $4;		$$.type = D_OCONST;	}|	'$' LSCONST	{		$$ = nullgen;		$$.type = D_SCONST;		memcpy($$.sval, $2, sizeof($$.sval));	}|	'$' LFCONST	{		$$ = nullgen;		$$.type = D_FCONST;		$$.dval = $2;	}|	'$' '-' LFCONST	{		$$ = nullgen;		$$.type = D_FCONST;		$$.dval = -$3;	}nireg:	ireg|	con ireg	{		if($1 != 0)			yyerror("offset must be zero");		$$ = $2;	}|	name	{		$$ = $1;		if($1.name != D_EXTERN && $1.name != D_STATIC) {		}	}ireg:	'(' sreg ')'	{		$$ = nullgen;		$$.type = D_OREG;		$$.reg = $2;		$$.offset = 0;	}gen:	reg|	con	{		$$ = nullgen;		$$.type = D_OREG;		$$.offset = $1;	}|	oregoreg:	name|	name '(' sreg ')'	{		$$ = $1;		$$.type = D_OREG;		$$.reg = $3;	}|	'(' sreg ')'	{		$$ = nullgen;		$$.type = D_OREG;		$$.reg = $2;		$$.offset = 0;	}|	con '(' sreg ')'	{		$$ = nullgen;		$$.type = D_OREG;		$$.reg = $3;		$$.offset = $1;	}imr:	reg|	immimm:	'$' con	{		$$ = nullgen;		$$.type = D_CONST;		$$.offset = $2;	}reg:	sreg	{		$$ = nullgen;		$$.type = D_REG;		$$.reg = $1;	}sreg:	LREG|	LR '(' con ')'	{		if($$ < 0 || $$ >= NREG)			print("register value out of range\n");		$$ = $3;	}name:	con '(' pointer ')'	{		$$ = nullgen;		$$.type = D_OREG;		$$.name = $3;		$$.sym = S;		$$.offset = $1;	}|	LNAME offset '(' pointer ')'	{		$$ = nullgen;		$$.type = D_OREG;		$$.name = $4;		$$.sym = $1;		$$.offset = $2;	}|	LNAME '<' '>' offset '(' LSB ')'	{		$$ = nullgen;		$$.type = D_OREG;		$$.name = D_STATIC;		$$.sym = $1;		$$.offset = $4;	}offset:	{		$$ = 0;	}|	'+' con	{		$$ = $2;	}|	'-' con	{		$$ = -$2;	}pointer:	LSB|	LSP|	LFPcon:	LCONST|	LVAR	{		$$ = $1->value;	}|	'-' con	{		$$ = -$2;	}|	'+' con	{		$$ = $2;	}|	'~' con	{		$$ = ~$2;	}|	'(' expr ')'	{		$$ = $2;	}expr:	con|	expr '+' expr	{		$$ = $1 + $3;	}|	expr '-' expr	{		$$ = $1 - $3;	}|	expr '*' expr	{		$$ = $1 * $3;	}|	expr '/' expr	{		$$ = $1 / $3;	}|	expr '%' expr	{		$$ = $1 % $3;	}|	expr '<' '<' expr	{		$$ = $1 << $4;	}|	expr '>' '>' expr	{		$$ = $1 >> $4;	}|	expr '&' expr	{		$$ = $1 & $3;	}|	expr '^' expr	{		$$ = $1 ^ $3;	}|	expr '|' expr	{		$$ = $1 | $3;	}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -