Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/make/unit-tests make(1): add test for intentional ha...
details: https://anonhg.NetBSD.org/src/rev/2ee7dfb91f65
branches: trunk
changeset: 975724:2ee7dfb91f65
user: rillig <rillig%NetBSD.org@localhost>
date: Sat Sep 05 12:59:07 2020 +0000
description:
make(1): add test for intentional hash collision for variable names
Hash collisions may slow down make in certain special situations. There
is no point though in maliciously triggering such a situation since
anyone who can inject values into makefiles can easily run shell
commands using the :!cmd! modifier or similar mechanisms. Crafting
variable names just to slow down make is thus not an attack vector.
diffstat:
usr.bin/make/unit-tests/Makefile | 3 +-
usr.bin/make/unit-tests/varname.mk | 41 +++++++++++++++++++++++++++++++++++--
2 files changed, 40 insertions(+), 4 deletions(-)
diffs (67 lines):
diff -r 98903ae18295 -r 2ee7dfb91f65 usr.bin/make/unit-tests/Makefile
--- a/usr.bin/make/unit-tests/Makefile Sat Sep 05 12:19:25 2020 +0000
+++ b/usr.bin/make/unit-tests/Makefile Sat Sep 05 12:59:07 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.135 2020/09/05 06:36:40 rillig Exp $
+# $NetBSD: Makefile,v 1.136 2020/09/05 12:59:07 rillig Exp $
#
# Unit tests for make(1)
#
@@ -393,6 +393,7 @@
${TOOL_SED} -n -e '/^\#\*\*\* Suffixes/,/^\#\*/p'
POSTPROC.vardebug= ${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p'
POSTPROC.varmod-match-escape= ${TOOL_SED} -n -e '/^Pattern/p'
+POSTPROC.varname= ${TOOL_SED} -n -e '/^MAGIC/p' -e '/^ORDER_/p'
POSTPROC.varname-dot-shell= \
awk '/\.SHELL/ || /^ParseReadLine/'
POSTPROC.varname-empty= ${TOOL_SED} -n -e '/^Var_Set/p' -e '/^out:/p'
diff -r 98903ae18295 -r 2ee7dfb91f65 usr.bin/make/unit-tests/varname.mk
--- a/usr.bin/make/unit-tests/varname.mk Sat Sep 05 12:19:25 2020 +0000
+++ b/usr.bin/make/unit-tests/varname.mk Sat Sep 05 12:59:07 2020 +0000
@@ -1,8 +1,43 @@
-# $NetBSD: varname.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: varname.mk,v 1.3 2020/09/05 12:59:07 rillig Exp $
#
# Tests for special variables, such as .MAKE or .PARSEDIR.
-# TODO: Implementation
+# These following MAGIC variables have the same hash code, at least with
+# the default hashing algorithm, which is the same as in Java. The order
+# in which these variables are defined determines the order in which they
+# appear in the Hash_Table. New entries are prepended to the bucket lists,
+# therefore this test numbers the values in descending order.
+
+.if defined(ORDER_01)
+
+MAGIC0a0a0a= 8
+MAGIC0a0a1B= 7
+MAGIC0a1B0a= 6
+MAGIC0a1B1B= 5
+MAGIC1B0a0a= 4
+MAGIC1B0a1B= 3
+MAGIC1B1B0a= 2
+MAGIC1B1B1B= 1
+
+all: # nothing
+
+.elif defined(ORDER_10)
+
+MAGIC1B1B1B= 8
+MAGIC1B1B0a= 7
+MAGIC1B0a1B= 6
+MAGIC1B0a0a= 5
+MAGIC0a1B1B= 4
+MAGIC0a1B0a= 3
+MAGIC0a0a1B= 2
+MAGIC0a0a0a= 1
+
+all: # nothing
+
+.else
all:
- @:;
+ @${.MAKE} -f ${MAKEFILE} -dg1 ORDER_01=yes
+ @${.MAKE} -f ${MAKEFILE} -dg1 ORDER_10=yes
+
+.endif
Home |
Main Index |
Thread Index |
Old Index