mirror of https://github.com/YosysHQ/yosys.git
Merge pull request #1875 from whitequark/read_ilang-int_overflow
Improve handling of integer literals in RTLIL frontend
This commit is contained in:
commit
f1d9ca1563
|
@ -29,6 +29,7 @@
|
||||||
#pragma clang diagnostic ignored "-Wdeprecated-register"
|
#pragma clang diagnostic ignored "-Wdeprecated-register"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include <cstdlib>
|
||||||
#include "frontends/ilang/ilang_frontend.h"
|
#include "frontends/ilang/ilang_frontend.h"
|
||||||
#include "ilang_parser.tab.hh"
|
#include "ilang_parser.tab.hh"
|
||||||
|
|
||||||
|
@ -88,7 +89,16 @@ USING_YOSYS_NAMESPACE
|
||||||
"."[0-9]+ { rtlil_frontend_ilang_yylval.string = strdup(yytext); return TOK_ID; }
|
"."[0-9]+ { rtlil_frontend_ilang_yylval.string = strdup(yytext); return TOK_ID; }
|
||||||
|
|
||||||
[0-9]+'[01xzm-]* { rtlil_frontend_ilang_yylval.string = strdup(yytext); return TOK_VALUE; }
|
[0-9]+'[01xzm-]* { rtlil_frontend_ilang_yylval.string = strdup(yytext); return TOK_VALUE; }
|
||||||
-?[0-9]+ { rtlil_frontend_ilang_yylval.integer = atoi(yytext); return TOK_INT; }
|
-?[0-9]+ {
|
||||||
|
char *end = nullptr;
|
||||||
|
long value = strtol(yytext, &end, 10);
|
||||||
|
if (end != yytext + strlen(yytext))
|
||||||
|
return TOK_INVALID; // literal out of range of long
|
||||||
|
if (value < INT_MIN || value > INT_MAX)
|
||||||
|
return TOK_INVALID; // literal out of range of int (relevant mostly for LP64 platforms)
|
||||||
|
rtlil_frontend_ilang_yylval.integer = value;
|
||||||
|
return TOK_INT;
|
||||||
|
}
|
||||||
|
|
||||||
\" { BEGIN(STRING); }
|
\" { BEGIN(STRING); }
|
||||||
<STRING>\\. { yymore(); }
|
<STRING>\\. { yymore(); }
|
||||||
|
@ -136,4 +146,3 @@ USING_YOSYS_NAMESPACE
|
||||||
void *rtlil_frontend_ilang_avoid_input_warnings() {
|
void *rtlil_frontend_ilang_avoid_input_warnings() {
|
||||||
return (void*)&yyinput;
|
return (void*)&yyinput;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -179,6 +179,9 @@ wire_options:
|
||||||
wire_options TOK_WIDTH TOK_INT {
|
wire_options TOK_WIDTH TOK_INT {
|
||||||
current_wire->width = $3;
|
current_wire->width = $3;
|
||||||
} |
|
} |
|
||||||
|
wire_options TOK_WIDTH TOK_INVALID {
|
||||||
|
rtlil_frontend_ilang_yyerror("ilang error: invalid wire width");
|
||||||
|
} |
|
||||||
wire_options TOK_UPTO {
|
wire_options TOK_UPTO {
|
||||||
current_wire->upto = true;
|
current_wire->upto = true;
|
||||||
} |
|
} |
|
||||||
|
|
Loading…
Reference in New Issue