fix access-after-free crash spotted by Enjolras via IRC, thanks!
This commit is contained in:
6
check.t
6
check.t
@ -1,4 +1,4 @@
|
|||||||
# $MirOS: src/bin/mksh/check.t,v 1.653 2014/06/24 20:47:42 tg Exp $
|
# $MirOS: src/bin/mksh/check.t,v 1.654 2014/06/29 11:28:26 tg Exp $
|
||||||
# OpenBSD src/regress/bin/ksh updated: 2013/12/02 20:39:44
|
# OpenBSD src/regress/bin/ksh updated: 2013/12/02 20:39:44
|
||||||
#-
|
#-
|
||||||
# Copyright © 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010,
|
# Copyright © 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010,
|
||||||
@ -27,7 +27,7 @@
|
|||||||
# http://www.freebsd.org/cgi/cvsweb.cgi/src/tools/regression/bin/test/regress.sh?rev=HEAD
|
# http://www.freebsd.org/cgi/cvsweb.cgi/src/tools/regression/bin/test/regress.sh?rev=HEAD
|
||||||
|
|
||||||
expected-stdout:
|
expected-stdout:
|
||||||
@(#)MIRBSD KSH R50 2014/06/24
|
@(#)MIRBSD KSH R50 2014/06/29
|
||||||
description:
|
description:
|
||||||
Check version of shell.
|
Check version of shell.
|
||||||
stdin:
|
stdin:
|
||||||
@ -36,7 +36,7 @@ name: KSH_VERSION
|
|||||||
category: shell:legacy-no
|
category: shell:legacy-no
|
||||||
---
|
---
|
||||||
expected-stdout:
|
expected-stdout:
|
||||||
@(#)LEGACY KSH R50 2014/06/24
|
@(#)LEGACY KSH R50 2014/06/29
|
||||||
description:
|
description:
|
||||||
Check version of legacy shell.
|
Check version of legacy shell.
|
||||||
stdin:
|
stdin:
|
||||||
|
13
lex.c
13
lex.c
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
#include "sh.h"
|
#include "sh.h"
|
||||||
|
|
||||||
__RCSID("$MirOS: src/bin/mksh/lex.c,v 1.192 2014/01/11 18:09:40 tg Exp $");
|
__RCSID("$MirOS: src/bin/mksh/lex.c,v 1.193 2014/06/29 11:28:28 tg Exp $");
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* states while lexing word
|
* states while lexing word
|
||||||
@ -159,9 +159,10 @@ getsc_r(int c)
|
|||||||
state = statep->type; \
|
state = statep->type; \
|
||||||
} while (/* CONSTCOND */ 0)
|
} while (/* CONSTCOND */ 0)
|
||||||
|
|
||||||
#define PUSH_SRETRACE() do { \
|
#define PUSH_SRETRACE(s) do { \
|
||||||
struct sretrace_info *ri; \
|
struct sretrace_info *ri; \
|
||||||
\
|
\
|
||||||
|
PUSH_STATE(s); \
|
||||||
statep->ls_start = Xsavepos(ws, wp); \
|
statep->ls_start = Xsavepos(ws, wp); \
|
||||||
ri = alloc(sizeof(struct sretrace_info), ATEMP); \
|
ri = alloc(sizeof(struct sretrace_info), ATEMP); \
|
||||||
Xinit(ri->xs, ri->xp, 64, ATEMP); \
|
Xinit(ri->xs, ri->xp, 64, ATEMP); \
|
||||||
@ -176,6 +177,7 @@ getsc_r(int c)
|
|||||||
dp = (void *)retrace_info; \
|
dp = (void *)retrace_info; \
|
||||||
retrace_info = retrace_info->next; \
|
retrace_info = retrace_info->next; \
|
||||||
afree(dp, ATEMP); \
|
afree(dp, ATEMP); \
|
||||||
|
POP_STATE(); \
|
||||||
} while (/* CONSTCOND */ 0)
|
} while (/* CONSTCOND */ 0)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -404,9 +406,8 @@ yylex(int cf)
|
|||||||
c = getsc();
|
c = getsc();
|
||||||
if (c == '(') /*)*/ {
|
if (c == '(') /*)*/ {
|
||||||
*wp++ = EXPRSUB;
|
*wp++ = EXPRSUB;
|
||||||
PUSH_STATE(SASPAREN);
|
PUSH_SRETRACE(SASPAREN);
|
||||||
statep->nparen = 2;
|
statep->nparen = 2;
|
||||||
PUSH_SRETRACE();
|
|
||||||
*retrace_info->xp++ = '(';
|
*retrace_info->xp++ = '(';
|
||||||
} else {
|
} else {
|
||||||
ungetsc(c);
|
ungetsc(c);
|
||||||
@ -650,7 +651,6 @@ yylex(int cf)
|
|||||||
if (statep->nparen == 1) {
|
if (statep->nparen == 1) {
|
||||||
/* end of EXPRSUB */
|
/* end of EXPRSUB */
|
||||||
POP_SRETRACE();
|
POP_SRETRACE();
|
||||||
POP_STATE();
|
|
||||||
|
|
||||||
if ((c2 = getsc()) == /*(*/ ')') {
|
if ((c2 = getsc()) == /*(*/ ')') {
|
||||||
cz = strlen(sp) - 2;
|
cz = strlen(sp) - 2;
|
||||||
@ -833,8 +833,7 @@ yylex(int cf)
|
|||||||
} else if (c2 == '"') {
|
} else if (c2 == '"') {
|
||||||
/* FALLTHROUGH */
|
/* FALLTHROUGH */
|
||||||
case '"':
|
case '"':
|
||||||
state = statep->type = SHEREDQUOTE;
|
PUSH_SRETRACE(SHEREDQUOTE);
|
||||||
PUSH_SRETRACE();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
ungetsc(c2);
|
ungetsc(c2);
|
||||||
|
4
sh.h
4
sh.h
@ -169,9 +169,9 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef EXTERN
|
#ifdef EXTERN
|
||||||
__RCSID("$MirOS: src/bin/mksh/sh.h,v 1.690 2014/06/24 20:47:47 tg Exp $");
|
__RCSID("$MirOS: src/bin/mksh/sh.h,v 1.691 2014/06/29 11:28:28 tg Exp $");
|
||||||
#endif
|
#endif
|
||||||
#define MKSH_VERSION "R50 2014/06/24"
|
#define MKSH_VERSION "R50 2014/06/29"
|
||||||
|
|
||||||
/* arithmetic types: C implementation */
|
/* arithmetic types: C implementation */
|
||||||
#if !HAVE_CAN_INTTYPES
|
#if !HAVE_CAN_INTTYPES
|
||||||
|
Reference in New Issue
Block a user