From 883408eab8dc0d36d36acbccc4bb4cde432607ec Mon Sep 17 00:00:00 2001 From: Eric Anholt Date: Fri, 25 Aug 2006 13:38:03 -0700 Subject: Add rules for more registers, and use some for destinations. --- assembler/lex.l | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) (limited to 'assembler/lex.l') diff --git a/assembler/lex.l b/assembler/lex.l index ab418da2..b5b4f725 100644 --- a/assembler/lex.l +++ b/assembler/lex.l @@ -119,6 +119,22 @@ int saved_state = INITIAL; yylval.integer = atoi(yytext + 1); return MSGREG; } +"mask"[0-9]+ { + yylval.integer = atoi(yytext + 1); + return MASKREG; +} +"ms"[0-9]+ { + yylval.integer = atoi(yytext + 1); + return MASKSTACKREG; +} +"msd"[0-9]+ { + yylval.integer = atoi(yytext + 1); + return MASKSTACKDEPTHREG; +} +"n"[0-9]+ { + yylval.integer = atoi(yytext + 1); + return NOTIFYREG; +} "f"[0-9]+ { yylval.integer = atoi(yytext + 1); return FLAGREG; @@ -131,9 +147,45 @@ int saved_state = INITIAL; yylval.integer = atoi(yytext + 1); return CONTROLREG; } +"sr"[0-9]+ { + yylval.integer = atoi(yytext + 1); + return STATEREG; +} "ip" { return IPREG; } +"amask" { + yylval.integer = BRW_AMASK; + return AMASK; +} +"imask" { + yylval.integer = BRW_IMASK; + return IMASK; +} +"lmask" { + yylval.integer = BRW_LMASK; + return LMASK; +} +"cmask" { + yylval.integer = BRW_CMASK; + return CMASK; +} +"imsd" { + yylval.integer = 0; + return IMSD; +} +"lmsd" { + yylval.integer = 1; + return LMSD; +} +"ims" { + yylval.integer = 0; + return IMS; +} +"lms" { + yylval.integer = 16; + return LMS; +} /* * Lexing of register types should probably require the ":" symbol specified -- cgit v1.2.3