aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDavid Gibson <david@gibson.dropbear.id.au>2016-01-03 22:54:37 +1100
committerDavid Gibson <david@gibson.dropbear.id.au>2016-01-03 22:54:37 +1100
commit1ab2205a6f0f9e826a623e639da02787d372de37 (patch)
tree2ee7499f55e19cf77fa57e2a13ac42847f5dbd2d
parent19370955884ff0c49328956227c302225f4a014b (diff)
downloaddtc-1ab2205a6f0f9e826a623e639da02787d372de37.zip
dtc-1ab2205a6f0f9e826a623e639da02787d372de37.tar.gz
dtc-1ab2205a6f0f9e826a623e639da02787d372de37.tar.bz2
Gracefully handle bad octal literals
The code handling integer literals in dtc-lexer.l assumes that the flex regexp means that strtoull() can't fail to interpret the string as a valid integer (either decimal, octal, or hexadecimal). This is not true for octals. For example '09' is accepted as a literal by the regexp, strtoull() attempts to handle it as octal, but it has a bad digit. This changes the code to give a more useful error in this case. Reported-by: Anton Blanchard <anton@samba.org> Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
-rw-r--r--dtc-lexer.l5
-rw-r--r--tests/bad-octal-literal.dts5
-rwxr-xr-xtests/run_tests.sh1
3 files changed, 10 insertions, 1 deletions
diff --git a/dtc-lexer.l b/dtc-lexer.l
index 0ee1caf..22dda7d 100644
--- a/dtc-lexer.l
+++ b/dtc-lexer.l
@@ -153,7 +153,10 @@ static void lexical_error(const char *fmt, ...);
errno = 0;
yylval.integer = strtoull(yytext, &e, 0);
- assert(!(*e) || !e[strspn(e, "UL")]);
+ if (*e && e[strspn(e, "UL")]) {
+ lexical_error("Bad integer literal '%s'",
+ yytext);
+ }
if (errno == ERANGE)
lexical_error("Integer literal '%s' out of range",
diff --git a/tests/bad-octal-literal.dts b/tests/bad-octal-literal.dts
new file mode 100644
index 0000000..26558a2
--- /dev/null
+++ b/tests/bad-octal-literal.dts
@@ -0,0 +1,5 @@
+/dts-v1/;
+
+/ {
+ x = <09>;
+};
diff --git a/tests/run_tests.sh b/tests/run_tests.sh
index 3d6a230..7bdf8e0 100755
--- a/tests/run_tests.sh
+++ b/tests/run_tests.sh
@@ -291,6 +291,7 @@ libfdt_tests () {
run_dtc_test -I dts -O dtb bad-size-cells.dts
run_wrap_error_test $DTC division-by-zero.dts
+ run_wrap_error_test $DTC bad-octal-literal.dts
}
dtc_tests () {