Ondrej Oprala 3e4b07
			     BASH PATCH REPORT
Ondrej Oprala 3e4b07
			     =================
Ondrej Oprala 3e4b07
Ondrej Oprala 3e4b07
Bash-Release:	4.3
Ondrej Oprala 3e4b07
Patch-ID:	bash43-009
Ondrej Oprala 3e4b07
Ondrej Oprala 3e4b07
Bug-Reported-by:	Matthias Klose <doko@debian.org>
Ondrej Oprala 3e4b07
Bug-Reference-ID:	<53346FC8.6090005@debian.org>
Ondrej Oprala 3e4b07
Bug-Reference-URL:	http://lists.gnu.org/archive/html/bug-bash/2014-03/msg00171.html
Ondrej Oprala 3e4b07
Ondrej Oprala 3e4b07
Bug-Description:
Ondrej Oprala 3e4b07
Ondrej Oprala 3e4b07
There is a problem with unsigned sign extension when attempting to reallocate
Ondrej Oprala 3e4b07
the input line when it is fewer than 3 characters long and there has been a
Ondrej Oprala 3e4b07
history expansion.  The sign extension causes the shell to not reallocate the
Ondrej Oprala 3e4b07
line, which results in a segmentation fault when it writes past the end.
Ondrej Oprala 3e4b07
Ondrej Oprala 3e4b07
Patch (apply with `patch -p0'):
Ondrej Oprala 3e4b07
Ondrej Oprala 3e4b07
*** ../bash-4.3-patched/parse.y	2014-02-11 09:42:10.000000000 -0500
Ondrej Oprala 3e4b07
--- parse.y	2014-03-27 16:33:29.000000000 -0400
Ondrej Oprala 3e4b07
***************
Ondrej Oprala 3e4b07
*** 2425,2429 ****
Ondrej Oprala 3e4b07
        if (shell_input_line_terminator != EOF)
Ondrej Oprala 3e4b07
  	{
Ondrej Oprala 3e4b07
! 	  if (shell_input_line_size < SIZE_MAX && shell_input_line_len > shell_input_line_size - 3)
Ondrej Oprala 3e4b07
  	    shell_input_line = (char *)xrealloc (shell_input_line,
Ondrej Oprala 3e4b07
  					1 + (shell_input_line_size += 2));
Ondrej Oprala 3e4b07
--- 2425,2429 ----
Ondrej Oprala 3e4b07
        if (shell_input_line_terminator != EOF)
Ondrej Oprala 3e4b07
  	{
Ondrej Oprala 3e4b07
! 	  if (shell_input_line_size < SIZE_MAX-3 && (shell_input_line_len+3 > shell_input_line_size))
Ondrej Oprala 3e4b07
  	    shell_input_line = (char *)xrealloc (shell_input_line,
Ondrej Oprala 3e4b07
  					1 + (shell_input_line_size += 2));
Ondrej Oprala 3e4b07
*** ../bash-4.3-patched/y.tab.c	2014-03-28 11:17:06.000000000 -0400
Ondrej Oprala 3e4b07
--- y.tab.c	2014-04-07 11:48:31.000000000 -0400
Ondrej Oprala 3e4b07
***************
Ondrej Oprala 3e4b07
*** 4737,4741 ****
Ondrej Oprala 3e4b07
        if (shell_input_line_terminator != EOF)
Ondrej Oprala 3e4b07
  	{
Ondrej Oprala 3e4b07
! 	  if (shell_input_line_size < SIZE_MAX && shell_input_line_len > shell_input_line_size - 3)
Ondrej Oprala 3e4b07
  	    shell_input_line = (char *)xrealloc (shell_input_line,
Ondrej Oprala 3e4b07
  					1 + (shell_input_line_size += 2));
Ondrej Oprala 3e4b07
--- 4737,4741 ----
Ondrej Oprala 3e4b07
        if (shell_input_line_terminator != EOF)
Ondrej Oprala 3e4b07
  	{
Ondrej Oprala 3e4b07
! 	  if (shell_input_line_size < SIZE_MAX-3 && (shell_input_line_len+3 > shell_input_line_size))
Ondrej Oprala 3e4b07
  	    shell_input_line = (char *)xrealloc (shell_input_line,
Ondrej Oprala 3e4b07
  					1 + (shell_input_line_size += 2));
Ondrej Oprala 3e4b07
*** ../bash-4.3/patchlevel.h	2012-12-29 10:47:57.000000000 -0500
Ondrej Oprala 3e4b07
--- patchlevel.h	2014-03-20 20:01:28.000000000 -0400
Ondrej Oprala 3e4b07
***************
Ondrej Oprala 3e4b07
*** 26,30 ****
Ondrej Oprala 3e4b07
     looks for to find the patch level (for the sccs version string). */
Ondrej Oprala 3e4b07
  
Ondrej Oprala 3e4b07
! #define PATCHLEVEL 8
Ondrej Oprala 3e4b07
  
Ondrej Oprala 3e4b07
  #endif /* _PATCHLEVEL_H_ */
Ondrej Oprala 3e4b07
--- 26,30 ----
Ondrej Oprala 3e4b07
     looks for to find the patch level (for the sccs version string). */
Ondrej Oprala 3e4b07
  
Ondrej Oprala 3e4b07
! #define PATCHLEVEL 9
Ondrej Oprala 3e4b07
  
Ondrej Oprala 3e4b07
  #endif /* _PATCHLEVEL_H_ */