Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/gpl2/grep/dist/src Prevent Undefined Behavior in sh...
details: https://anonhg.NetBSD.org/src/rev/33bb4b10680d
branches: trunk
changeset: 362479:33bb4b10680d
user: kamil <kamil%NetBSD.org@localhost>
date: Tue Jun 12 21:22:47 2018 +0000
description:
Prevent Undefined Behavior in shift of signed integer in grep(1)
There is an interface in grep: dfa.c with functions to test bit, set bit,
clear bit etc. They operate over the INT-wide mask (INTBITS). Use unsigned
shift in these interfaces to prevent UB.
Detected with MKSANITIZER with the undefined behavior sanitizer option.
Sponsored by <The NetBSD Foundation>
diffstat:
external/gpl2/grep/dist/src/dfa.c | 10 +++++-----
1 files changed, 5 insertions(+), 5 deletions(-)
diffs (41 lines):
diff -r df132ae9d21f -r 33bb4b10680d external/gpl2/grep/dist/src/dfa.c
--- a/external/gpl2/grep/dist/src/dfa.c Tue Jun 12 20:27:54 2018 +0000
+++ b/external/gpl2/grep/dist/src/dfa.c Tue Jun 12 21:22:47 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: dfa.c,v 1.2 2016/01/10 22:16:40 christos Exp $ */
+/* $NetBSD: dfa.c,v 1.3 2018/06/12 21:22:47 kamil Exp $ */
/* dfa.c - deterministic extended regexp routines for GNU
Copyright 1988, 1998, 2000 Free Software Foundation, Inc.
@@ -223,19 +223,19 @@
static int
tstbit (unsigned b, charclass c)
{
- return c[b / INTBITS] & 1 << b % INTBITS;
+ return c[b / INTBITS] & 1U << b % INTBITS;
}
static void
setbit (unsigned b, charclass c)
{
- c[b / INTBITS] |= 1 << b % INTBITS;
+ c[b / INTBITS] |= 1U << b % INTBITS;
}
static void
clrbit (unsigned b, charclass c)
{
- c[b / INTBITS] &= ~(1 << b % INTBITS);
+ c[b / INTBITS] &= ~(1U << b % INTBITS);
}
static void
@@ -2203,7 +2203,7 @@
/* Set the transitions for each character in the current label. */
for (j = 0; j < CHARCLASS_INTS; ++j)
for (k = 0; k < INTBITS; ++k)
- if (labels[i][j] & 1 << k)
+ if (labels[i][j] & 1U << k)
{
int c = j * INTBITS + k;
Home |
Main Index |
Thread Index |
Old Index