public inbox for libc-alpha@sourceware.org
 help / color / mirror / Atom feed
* [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
@ 2022-02-22 20:55 jobol
  2022-03-04 19:39 ` Adhemerval Zanella
                   ` (2 more replies)
  0 siblings, 3 replies; 18+ messages in thread
From: jobol @ 2022-02-22 20:55 UTC (permalink / raw)
  To: libc-alpha; +Cc: jobol

From: "jobol@nonadev.net" <jobol@nonadev.net>

When fileops.c checks for nullity of the write pointer,
in order to ensure its allocation, before that patch,
wfileops didn't. This was leading to crashes on some cases,
as described by bug 28828.

The minimal sequence to produce the crash was:

    #include <stdio.h>
    #include <wchar.h>
    int main(int ac, char **av)
    {
            setvbuf(stdout, NULL, _IOLBF, 0);
            fgetwc(stdin);
            fputwc(10, stdout); /*CRASH HERE!*/
            return 0;
    }

The line "fgetwc(stdin);" is necessary. It introduces the
bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).

Signed-off-by: Jose Bollo <jobol@nonadev.net>
---
 libio/Makefile          |  2 +-
 libio/tst-bz28828.c     | 10 ++++++++++
 libio/tst-bz28828.input |  1 +
 libio/wfileops.c        |  3 ++-
 4 files changed, 14 insertions(+), 2 deletions(-)
 create mode 100644 libio/tst-bz28828.c
 create mode 100644 libio/tst-bz28828.input

diff --git a/libio/Makefile b/libio/Makefile
index 0e5f348bea..e97387743f 100644
--- a/libio/Makefile
+++ b/libio/Makefile
@@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc   \
 	tst-fwrite-error tst-ftell-partial-wide tst-ftell-active-handler \
 	tst-ftell-append tst-fputws tst-bz22415 tst-fgetc-after-eof \
 	tst-sprintf-ub tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
-	tst-wfile-sync
+	tst-wfile-sync tst-bz28828
 
 tests-internal = tst-vtables tst-vtables-interposed
 
diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
new file mode 100644
index 0000000000..f5849d2ca6
--- /dev/null
+++ b/libio/tst-bz28828.c
@@ -0,0 +1,10 @@
+#include <stdio.h>
+#include <wchar.h>
+int main(int ac, char **av)
+{
+	setvbuf(stdout, NULL, _IOLBF, 0);
+	fgetwc(stdin);
+	fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/
+	return 0;
+}
+
diff --git a/libio/tst-bz28828.input b/libio/tst-bz28828.input
new file mode 100644
index 0000000000..ce01362503
--- /dev/null
+++ b/libio/tst-bz28828.input
@@ -0,0 +1 @@
+hello
diff --git a/libio/wfileops.c b/libio/wfileops.c
index fb9d45b677..b59a98881f 100644
--- a/libio/wfileops.c
+++ b/libio/wfileops.c
@@ -412,7 +412,8 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
       return WEOF;
     }
   /* If currently reading or no buffer allocated. */
-  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
+  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
+      || f->_wide_data->_IO_write_base == NULL)
     {
       /* Allocate a buffer if needed. */
       if (f->_wide_data->_IO_write_base == 0)
-- 
2.34.1


^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
  2022-02-22 20:55 [PATCH v3] libio: Ensure output buffer for wchars (bug 28828) jobol
@ 2022-03-04 19:39 ` Adhemerval Zanella
  2022-03-04 19:53   ` Andreas Schwab
  2022-03-08  8:44   ` José Bollo
  2022-03-08  8:54 ` [PATCH] " jobol
  2022-03-08  8:58 ` [PATCH v4] " jobol
  2 siblings, 2 replies; 18+ messages in thread
From: Adhemerval Zanella @ 2022-03-04 19:39 UTC (permalink / raw)
  To: jobol, libc-alpha



On 22/02/2022 17:55, jobol@nonadev.net wrote:
> From: "jobol@nonadev.net" <jobol@nonadev.net>
> 
> When fileops.c checks for nullity of the write pointer,
> in order to ensure its allocation, before that patch,
> wfileops didn't. This was leading to crashes on some cases,
> as described by bug 28828.
> 
> The minimal sequence to produce the crash was:
> 
>     #include <stdio.h>
>     #include <wchar.h>
>     int main(int ac, char **av)
>     {
>             setvbuf(stdout, NULL, _IOLBF, 0);
>             fgetwc(stdin);
>             fputwc(10, stdout); /*CRASH HERE!*/
>             return 0;
>     }
> 
> The line "fgetwc(stdin);" is necessary. It introduces the
> bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
> indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).
> 
> Signed-off-by: Jose Bollo <jobol@nonadev.net>
> ---
>  libio/Makefile          |  2 +-
>  libio/tst-bz28828.c     | 10 ++++++++++
>  libio/tst-bz28828.input |  1 +
>  libio/wfileops.c        |  3 ++-
>  4 files changed, 14 insertions(+), 2 deletions(-)
>  create mode 100644 libio/tst-bz28828.c
>  create mode 100644 libio/tst-bz28828.input
> 
> diff --git a/libio/Makefile b/libio/Makefile
> index 0e5f348bea..e97387743f 100644
> --- a/libio/Makefile
> +++ b/libio/Makefile
> @@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc   \
>  	tst-fwrite-error tst-ftell-partial-wide tst-ftell-active-handler \
>  	tst-ftell-append tst-fputws tst-bz22415 tst-fgetc-after-eof \
>  	tst-sprintf-ub tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
> -	tst-wfile-sync
> +	tst-wfile-sync tst-bz28828
>  
>  tests-internal = tst-vtables tst-vtables-interposed
>  
> diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
> new file mode 100644
> index 0000000000..f5849d2ca6
> --- /dev/null
> +++ b/libio/tst-bz28828.c
> @@ -0,0 +1,10 @@
> +#include <stdio.h>
> +#include <wchar.h>
> +int main(int ac, char **av)
> +{
> +	setvbuf(stdout, NULL, _IOLBF, 0);
> +	fgetwc(stdin);
> +	fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/
> +	return 0;
> +}
> +

The tests requires a proper Copyright header and to use libsupport (so it handles
test timeout, segfault, or any other error in test itself).  Also, use the proper
indentation.  A skeleton will be something like below:

---
/* Unit test for BZ#28828.
   Copyright (C) 2022 Free Software Foundation, Inc.
   This file is part of the GNU C Library.

   The GNU C Library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) any later version.

   The GNU C Library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library; if not, see
   <https://www.gnu.org/licenses/>.  */

#include <support/xstdio.h>
#include <support/check.h>
#include <wchar.h>

static int
do_test (void)
{ 
  /* Add the test here.  */

  return 0;
}

#include <support/test-driver.c>
---

Keep in mind that using fgetwc without a method to actually input some data
will make the test timeout and fail.


> diff --git a/libio/tst-bz28828.input b/libio/tst-bz28828.input
> new file mode 100644
> index 0000000000..ce01362503
> --- /dev/null
> +++ b/libio/tst-bz28828.input
> @@ -0,0 +1 @@
> +hello
> diff --git a/libio/wfileops.c b/libio/wfileops.c
> index fb9d45b677..b59a98881f 100644
> --- a/libio/wfileops.c
> +++ b/libio/wfileops.c
> @@ -412,7 +412,8 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
>        return WEOF;
>      }
>    /* If currently reading or no buffer allocated. */
> -  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
> +  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
> +      || f->_wide_data->_IO_write_base == NULL)
>      {
>        /* Allocate a buffer if needed. */
>        if (f->_wide_data->_IO_write_base == 0)

Based on your test I was intrigued on why you need a fgetwc(stdio) to actually
trigger the issue.  The fgetwc(stdio) in fact changed the stdout internal flags
somewhat, which then triggered the issue.

Digging a little bit deeper it seems this snippet is triggering it:

libio/wfileops.c

 201   /* FIXME This can/should be moved to genops ?? */                                     
 202   if (fp->_flags & (_IO_LINE_BUF | _IO_UNBUFFERED))                                     
 203     {
 204       /* We used to flush all line-buffered stream.  This really isn't                  
 205          required by any standard.  My recollection is that                             
 206          traditional Unix systems did this for stdout.  stderr better
 207          not be line buffered.  So we do just that here                                 
 208          explicitly.  --drepper */                                                      
 209       _IO_acquire_lock (stdout);                                                        
 210  
 211       if ((stdout->_flags & (_IO_LINKED | _IO_NO_WRITES | _IO_LINE_BUF))                
 212           == (_IO_LINKED | _IO_LINE_BUF))
 213         _IO_OVERFLOW (stdout, EOF);                                                     
 214  
 215       _IO_release_lock (stdout);                                                        
 216     }

And the FIXME really makes me wonder if this is really ok, the libio/fileops.c
does not contain such snippet.  Removing this code does not trigger any regression
and also fixes the issue.

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-04 19:39 ` Adhemerval Zanella
@ 2022-03-04 19:53   ` Andreas Schwab
  2022-03-07 11:03     ` Adhemerval Zanella
  2022-03-08  8:44   ` José Bollo
  1 sibling, 1 reply; 18+ messages in thread
From: Andreas Schwab @ 2022-03-04 19:53 UTC (permalink / raw)
  To: Adhemerval Zanella via Libc-alpha; +Cc: jobol, Adhemerval Zanella

On Mär 04 2022, Adhemerval Zanella via Libc-alpha wrote:

> the libio/fileops.c does not contain such snippet.

See line 488.

-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510  2552 DF73 E780 A9DA AEC1
"And now for something completely different."

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-04 19:53   ` Andreas Schwab
@ 2022-03-07 11:03     ` Adhemerval Zanella
  2022-03-07 11:29       ` Andreas Schwab
  0 siblings, 1 reply; 18+ messages in thread
From: Adhemerval Zanella @ 2022-03-07 11:03 UTC (permalink / raw)
  To: Andreas Schwab, Adhemerval Zanella via Libc-alpha; +Cc: jobol



On 04/03/2022 16:53, Andreas Schwab wrote:
> On Mär 04 2022, Adhemerval Zanella via Libc-alpha wrote:
> 
>> the libio/fileops.c does not contain such snippet.
> 
> See line 488.
> 

Should we evaluate to remove it as well then?

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-07 11:03     ` Adhemerval Zanella
@ 2022-03-07 11:29       ` Andreas Schwab
  2022-03-07 11:33         ` Adhemerval Zanella
  0 siblings, 1 reply; 18+ messages in thread
From: Andreas Schwab @ 2022-03-07 11:29 UTC (permalink / raw)
  To: Adhemerval Zanella; +Cc: Adhemerval Zanella via Libc-alpha, jobol

On Mär 07 2022, Adhemerval Zanella wrote:

> On 04/03/2022 16:53, Andreas Schwab wrote:
>> On Mär 04 2022, Adhemerval Zanella via Libc-alpha wrote:
>> 
>>> the libio/fileops.c does not contain such snippet.
>> 
>> See line 488.
>> 
>
> Should we evaluate to remove it as well then?

Why would we?  It's specified by POSIX.

-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510  2552 DF73 E780 A9DA AEC1
"And now for something completely different."

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-07 11:29       ` Andreas Schwab
@ 2022-03-07 11:33         ` Adhemerval Zanella
  2022-03-07 11:37           ` Andreas Schwab
  0 siblings, 1 reply; 18+ messages in thread
From: Adhemerval Zanella @ 2022-03-07 11:33 UTC (permalink / raw)
  To: Andreas Schwab; +Cc: Adhemerval Zanella via Libc-alpha, jobol



On 07/03/2022 08:29, Andreas Schwab wrote:
> On Mär 07 2022, Adhemerval Zanella wrote:
> 
>> On 04/03/2022 16:53, Andreas Schwab wrote:
>>> On Mär 04 2022, Adhemerval Zanella via Libc-alpha wrote:
>>>
>>>> the libio/fileops.c does not contain such snippet.
>>>
>>> See line 488.
>>>
>>
>> Should we evaluate to remove it as well then?
> 
> Why would we?  It's specified by POSIX.
> 

That's no what comment specifies ("This really isn't required by any
standard").  Do you have any link that describes this behavior?

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-07 11:33         ` Adhemerval Zanella
@ 2022-03-07 11:37           ` Andreas Schwab
  0 siblings, 0 replies; 18+ messages in thread
From: Andreas Schwab @ 2022-03-07 11:37 UTC (permalink / raw)
  To: Adhemerval Zanella; +Cc: Adhemerval Zanella via Libc-alpha, jobol

On Mär 07 2022, Adhemerval Zanella wrote:

> That's no what comment specifies ("This really isn't required by any
> standard").

This refers to the preceding sentence.

> Do you have any link that describes this behavior?

https://pubs.opengroup.org/onlinepubs/9699919799/functions/V2_chap02.html#tag_15_05

-- 
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 7578 EB47 D4E5 4D69 2510  2552 DF73 E780 A9DA AEC1
"And now for something completely different."

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v3] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-04 19:39 ` Adhemerval Zanella
  2022-03-04 19:53   ` Andreas Schwab
@ 2022-03-08  8:44   ` José Bollo
  1 sibling, 0 replies; 18+ messages in thread
From: José Bollo @ 2022-03-08  8:44 UTC (permalink / raw)
  To: Adhemerval Zanella; +Cc: libc-alpha

On Fri, 4 Mar 2022 16:39:36 -0300
Adhemerval Zanella <adhemerval.zanella@linaro.org> wrote:

Hi Adhemerval, Hi Andreas, Hi all,

I'm going to submit a new version taking your skeleton as a basis.

I added the file named libio/tst-bz28828.input with the understanding
that given its name, the test framework will automatically use it as
input. Can you tell me if it is correct or if I have to add something
some where.

My though about the interaction between stdin and stdout is that it is
sometime needed to get an input to flush the output.

Best regards
José

> On 22/02/2022 17:55, jobol@nonadev.net wrote:
> > From: "jobol@nonadev.net" <jobol@nonadev.net>
> > 
> > When fileops.c checks for nullity of the write pointer,
> > in order to ensure its allocation, before that patch,
> > wfileops didn't. This was leading to crashes on some cases,
> > as described by bug 28828.
> > 
> > The minimal sequence to produce the crash was:
> > 
> >     #include <stdio.h>
> >     #include <wchar.h>
> >     int main(int ac, char **av)
> >     {
> >             setvbuf(stdout, NULL, _IOLBF, 0);
> >             fgetwc(stdin);
> >             fputwc(10, stdout); /*CRASH HERE!*/
> >             return 0;
> >     }
> > 
> > The line "fgetwc(stdin);" is necessary. It introduces the
> > bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
> > indirectly (file wfileops.c, function _IO_wfile_underflow, line
> > 213).
> > 
> > Signed-off-by: Jose Bollo <jobol@nonadev.net>
> > ---
> >  libio/Makefile          |  2 +-
> >  libio/tst-bz28828.c     | 10 ++++++++++
> >  libio/tst-bz28828.input |  1 +
> >  libio/wfileops.c        |  3 ++-
> >  4 files changed, 14 insertions(+), 2 deletions(-)
> >  create mode 100644 libio/tst-bz28828.c
> >  create mode 100644 libio/tst-bz28828.input
> > 
> > diff --git a/libio/Makefile b/libio/Makefile
> > index 0e5f348bea..e97387743f 100644
> > --- a/libio/Makefile
> > +++ b/libio/Makefile
> > @@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf
> > tst_wscanf tst_getwc tst_putwc   \ tst-fwrite-error
> > tst-ftell-partial-wide tst-ftell-active-handler \ tst-ftell-append
> > tst-fputws tst-bz22415 tst-fgetc-after-eof \ tst-sprintf-ub
> > tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
> > -	tst-wfile-sync
> > +	tst-wfile-sync tst-bz28828
> >  
> >  tests-internal = tst-vtables tst-vtables-interposed
> >  
> > diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
> > new file mode 100644
> > index 0000000000..f5849d2ca6
> > --- /dev/null
> > +++ b/libio/tst-bz28828.c
> > @@ -0,0 +1,10 @@
> > +#include <stdio.h>
> > +#include <wchar.h>
> > +int main(int ac, char **av)
> > +{
> > +	setvbuf(stdout, NULL, _IOLBF, 0);
> > +	fgetwc(stdin);
> > +	fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/
> > +	return 0;
> > +}
> > +  
> 
> The tests requires a proper Copyright header and to use libsupport
> (so it handles test timeout, segfault, or any other error in test
> itself).  Also, use the proper indentation.  A skeleton will be
> something like below:
> 
> ---
> /* Unit test for BZ#28828.
>    Copyright (C) 2022 Free Software Foundation, Inc.
>    This file is part of the GNU C Library.
> 
>    The GNU C Library is free software; you can redistribute it and/or
>    modify it under the terms of the GNU Lesser General Public
>    License as published by the Free Software Foundation; either
>    version 2.1 of the License, or (at your option) any later version.
> 
>    The GNU C Library is distributed in the hope that it will be
> useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
>    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
>    Lesser General Public License for more details.
> 
>    You should have received a copy of the GNU Lesser General Public
>    License along with the GNU C Library; if not, see
>    <https://www.gnu.org/licenses/>.  */
> 
> #include <support/xstdio.h>
> #include <support/check.h>
> #include <wchar.h>
> 
> static int
> do_test (void)
> { 
>   /* Add the test here.  */
> 
>   return 0;
> }
> 
> #include <support/test-driver.c>
> ---
> 
> Keep in mind that using fgetwc without a method to actually input
> some data will make the test timeout and fail.
> 
> 
> > diff --git a/libio/tst-bz28828.input b/libio/tst-bz28828.input
> > new file mode 100644
> > index 0000000000..ce01362503
> > --- /dev/null
> > +++ b/libio/tst-bz28828.input
> > @@ -0,0 +1 @@
> > +hello
> > diff --git a/libio/wfileops.c b/libio/wfileops.c
> > index fb9d45b677..b59a98881f 100644
> > --- a/libio/wfileops.c
> > +++ b/libio/wfileops.c
> > @@ -412,7 +412,8 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
> >        return WEOF;
> >      }
> >    /* If currently reading or no buffer allocated. */
> > -  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
> > +  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
> > +      || f->_wide_data->_IO_write_base == NULL)
> >      {
> >        /* Allocate a buffer if needed. */
> >        if (f->_wide_data->_IO_write_base == 0)  
> 
> Based on your test I was intrigued on why you need a fgetwc(stdio) to
> actually trigger the issue.  The fgetwc(stdio) in fact changed the
> stdout internal flags somewhat, which then triggered the issue.
> 
> Digging a little bit deeper it seems this snippet is triggering it:
> 
> libio/wfileops.c
> 
>  201   /* FIXME This can/should be moved to genops ?? */
> 202   if (fp->_flags & (_IO_LINE_BUF | _IO_UNBUFFERED))
> 203     {
>  204       /* We used to flush all line-buffered stream.  This really
> isn't 205          required by any standard.  My recollection is that
> 206          traditional Unix systems did this for stdout.  stderr
> better 207          not be line buffered.  So we do just that here
> 208          explicitly.  --drepper */
> 209       _IO_acquire_lock (stdout);
> 210  
>  211       if ((stdout->_flags & (_IO_LINKED | _IO_NO_WRITES |
> _IO_LINE_BUF)) 212           == (_IO_LINKED | _IO_LINE_BUF))
>  213         _IO_OVERFLOW (stdout, EOF);
> 214  
>  215       _IO_release_lock (stdout);
> 216     }
> 
> And the FIXME really makes me wonder if this is really ok, the
> libio/fileops.c does not contain such snippet.  Removing this code
> does not trigger any regression and also fixes the issue.


^ permalink raw reply	[flat|nested] 18+ messages in thread

* [PATCH] libio: Ensure output buffer for wchars (bug 28828)
  2022-02-22 20:55 [PATCH v3] libio: Ensure output buffer for wchars (bug 28828) jobol
  2022-03-04 19:39 ` Adhemerval Zanella
@ 2022-03-08  8:54 ` jobol
  2022-03-08  8:58 ` [PATCH v4] " jobol
  2 siblings, 0 replies; 18+ messages in thread
From: jobol @ 2022-03-08  8:54 UTC (permalink / raw)
  To: libc-alpha; +Cc: José Bollo

From: José Bollo <jobol@nonadev.net>

When fileops.c checks for nullity of the write pointer,
in order to ensure its allocation, before that patch,
wfileops didn't. This was leading to crashes on some cases,
as described by bug 28828.

The minimal sequence to produce the crash was:

    #include <stdio.h>
    #include <wchar.h>
    int main(int ac, char **av)
    {
            setvbuf(stdout, NULL, _IOLBF, 0);
            fgetwc(stdin);
            fputwc(10, stdout); /*CRASH HERE!*/
            return 0;
    }

The line "fgetwc(stdin);" is necessary. It introduces the
bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).

Signed-off-by: Jose Bollo <jobol@nonadev.net>
---
 libio/Makefile          |  2 +-
 libio/tst-bz28828.c     | 33 +++++++++++++++++++++++++++++++++
 libio/tst-bz28828.input |  1 +
 libio/wfileops.c        |  3 ++-
 4 files changed, 37 insertions(+), 2 deletions(-)
 create mode 100644 libio/tst-bz28828.c
 create mode 100644 libio/tst-bz28828.input

diff --git a/libio/Makefile b/libio/Makefile
index 0e5f348bea..e97387743f 100644
--- a/libio/Makefile
+++ b/libio/Makefile
@@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc   \
 	tst-fwrite-error tst-ftell-partial-wide tst-ftell-active-handler \
 	tst-ftell-append tst-fputws tst-bz22415 tst-fgetc-after-eof \
 	tst-sprintf-ub tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
-	tst-wfile-sync
+	tst-wfile-sync tst-bz28828
 
 tests-internal = tst-vtables tst-vtables-interposed
 
diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
new file mode 100644
index 0000000000..22a70dd954
--- /dev/null
+++ b/libio/tst-bz28828.c
@@ -0,0 +1,33 @@
+/* Unit test for BZ#28828.
+   Copyright (C) 2022 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <https://www.gnu.org/licenses/>.  */
+
+#include <support/xstdio.h>
+#include <support/check.h>
+#include <wchar.h>
+
+static int
+do_test (void)
+{ 
+  setvbuf(stdout, NULL, _IOLBF, 0);
+  fgetwc(stdin);
+  fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/
+  return 0;
+}
+
+#include <support/test-driver.c>
+
diff --git a/libio/tst-bz28828.input b/libio/tst-bz28828.input
new file mode 100644
index 0000000000..ce01362503
--- /dev/null
+++ b/libio/tst-bz28828.input
@@ -0,0 +1 @@
+hello
diff --git a/libio/wfileops.c b/libio/wfileops.c
index fb9d45b677..b59a98881f 100644
--- a/libio/wfileops.c
+++ b/libio/wfileops.c
@@ -412,7 +412,8 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
       return WEOF;
     }
   /* If currently reading or no buffer allocated. */
-  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
+  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
+      || f->_wide_data->_IO_write_base == NULL)
     {
       /* Allocate a buffer if needed. */
       if (f->_wide_data->_IO_write_base == 0)
-- 
2.34.1


^ permalink raw reply	[flat|nested] 18+ messages in thread

* [PATCH v4] libio: Ensure output buffer for wchars (bug 28828)
  2022-02-22 20:55 [PATCH v3] libio: Ensure output buffer for wchars (bug 28828) jobol
  2022-03-04 19:39 ` Adhemerval Zanella
  2022-03-08  8:54 ` [PATCH] " jobol
@ 2022-03-08  8:58 ` jobol
  2022-03-08 17:12   ` Adhemerval Zanella
  2 siblings, 1 reply; 18+ messages in thread
From: jobol @ 2022-03-08  8:58 UTC (permalink / raw)
  To: libc-alpha; +Cc: José Bollo

From: José Bollo <jobol@nonadev.net>

When fileops.c checks for nullity of the write pointer,
in order to ensure its allocation, before that patch,
wfileops didn't. This was leading to crashes on some cases,
as described by bug 28828.

The minimal sequence to produce the crash was:

    #include <stdio.h>
    #include <wchar.h>
    int main(int ac, char **av)
    {
            setvbuf(stdout, NULL, _IOLBF, 0);
            fgetwc(stdin);
            fputwc(10, stdout); /*CRASH HERE!*/
            return 0;
    }

The line "fgetwc(stdin);" is necessary. It introduces the
bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).

Signed-off-by: Jose Bollo <jobol@nonadev.net>
---
 libio/Makefile          |  2 +-
 libio/tst-bz28828.c     | 33 +++++++++++++++++++++++++++++++++
 libio/tst-bz28828.input |  1 +
 libio/wfileops.c        |  3 ++-
 4 files changed, 37 insertions(+), 2 deletions(-)
 create mode 100644 libio/tst-bz28828.c
 create mode 100644 libio/tst-bz28828.input

diff --git a/libio/Makefile b/libio/Makefile
index 0e5f348bea..e97387743f 100644
--- a/libio/Makefile
+++ b/libio/Makefile
@@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc   \
 	tst-fwrite-error tst-ftell-partial-wide tst-ftell-active-handler \
 	tst-ftell-append tst-fputws tst-bz22415 tst-fgetc-after-eof \
 	tst-sprintf-ub tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
-	tst-wfile-sync
+	tst-wfile-sync tst-bz28828
 
 tests-internal = tst-vtables tst-vtables-interposed
 
diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
new file mode 100644
index 0000000000..22a70dd954
--- /dev/null
+++ b/libio/tst-bz28828.c
@@ -0,0 +1,33 @@
+/* Unit test for BZ#28828.
+   Copyright (C) 2022 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <https://www.gnu.org/licenses/>.  */
+
+#include <support/xstdio.h>
+#include <support/check.h>
+#include <wchar.h>
+
+static int
+do_test (void)
+{ 
+  setvbuf(stdout, NULL, _IOLBF, 0);
+  fgetwc(stdin);
+  fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/
+  return 0;
+}
+
+#include <support/test-driver.c>
+
diff --git a/libio/tst-bz28828.input b/libio/tst-bz28828.input
new file mode 100644
index 0000000000..ce01362503
--- /dev/null
+++ b/libio/tst-bz28828.input
@@ -0,0 +1 @@
+hello
diff --git a/libio/wfileops.c b/libio/wfileops.c
index fb9d45b677..b59a98881f 100644
--- a/libio/wfileops.c
+++ b/libio/wfileops.c
@@ -412,7 +412,8 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
       return WEOF;
     }
   /* If currently reading or no buffer allocated. */
-  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
+  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
+      || f->_wide_data->_IO_write_base == NULL)
     {
       /* Allocate a buffer if needed. */
       if (f->_wide_data->_IO_write_base == 0)
-- 
2.34.1


^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v4] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-08  8:58 ` [PATCH v4] " jobol
@ 2022-03-08 17:12   ` Adhemerval Zanella
  2022-03-08 17:27     ` José Bollo
  0 siblings, 1 reply; 18+ messages in thread
From: Adhemerval Zanella @ 2022-03-08 17:12 UTC (permalink / raw)
  To: jobol, libc-alpha



On 08/03/2022 05:58, jobol@nonadev.net wrote:
> From: José Bollo <jobol@nonadev.net>
> 
> When fileops.c checks for nullity of the write pointer,
> in order to ensure its allocation, before that patch,
> wfileops didn't. This was leading to crashes on some cases,
> as described by bug 28828.
> 
> The minimal sequence to produce the crash was:
> 
>     #include <stdio.h>
>     #include <wchar.h>
>     int main(int ac, char **av)
>     {
>             setvbuf(stdout, NULL, _IOLBF, 0);
>             fgetwc(stdin);
>             fputwc(10, stdout); /*CRASH HERE!*/
>             return 0;
>     }
> 
> The line "fgetwc(stdin);" is necessary. It introduces the
> bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
> indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).
> 
> Signed-off-by: Jose Bollo <jobol@nonadev.net>

This patch looks ok, I will fix the style issues below and install it.

Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>

> ---
>  libio/Makefile          |  2 +-
>  libio/tst-bz28828.c     | 33 +++++++++++++++++++++++++++++++++
>  libio/tst-bz28828.input |  1 +
>  libio/wfileops.c        |  3 ++-
>  4 files changed, 37 insertions(+), 2 deletions(-)
>  create mode 100644 libio/tst-bz28828.c
>  create mode 100644 libio/tst-bz28828.input
> 
> diff --git a/libio/Makefile b/libio/Makefile
> index 0e5f348bea..e97387743f 100644
> --- a/libio/Makefile
> +++ b/libio/Makefile
> @@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc   \
>  	tst-fwrite-error tst-ftell-partial-wide tst-ftell-active-handler \
>  	tst-ftell-append tst-fputws tst-bz22415 tst-fgetc-after-eof \
>  	tst-sprintf-ub tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
> -	tst-wfile-sync
> +	tst-wfile-sync tst-bz28828
>  
>  tests-internal = tst-vtables tst-vtables-interposed
>  
> diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
> new file mode 100644
> index 0000000000..22a70dd954
> --- /dev/null
> +++ b/libio/tst-bz28828.c
> @@ -0,0 +1,33 @@
> +/* Unit test for BZ#28828.
> +   Copyright (C) 2022 Free Software Foundation, Inc.
> +   This file is part of the GNU C Library.
> +
> +   The GNU C Library is free software; you can redistribute it and/or
> +   modify it under the terms of the GNU Lesser General Public
> +   License as published by the Free Software Foundation; either
> +   version 2.1 of the License, or (at your option) any later version.
> +
> +   The GNU C Library is distributed in the hope that it will be useful,
> +   but WITHOUT ANY WARRANTY; without even the implied warranty of
> +   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
> +   Lesser General Public License for more details.
> +
> +   You should have received a copy of the GNU Lesser General Public
> +   License along with the GNU C Library; if not, see
> +   <https://www.gnu.org/licenses/>.  */
> +
> +#include <support/xstdio.h>
> +#include <support/check.h>
> +#include <wchar.h>
> +
> +static int
> +do_test (void)
> +{ 

Extra space after '{'.

> +  setvbuf(stdout, NULL, _IOLBF, 0);

Space after before '(', also for the rest on function calls.

> +  fgetwc(stdin);
> +  fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/

We usually do not add comments in upper cases, I will replace with.

  /* It should not crash here.  */

> +  return 0;
> +}
> +
> +#include <support/test-driver.c>
> +

Extra newline.

> diff --git a/libio/tst-bz28828.input b/libio/tst-bz28828.input
> new file mode 100644
> index 0000000000..ce01362503
> --- /dev/null
> +++ b/libio/tst-bz28828.input
> @@ -0,0 +1 @@
> +hello
> diff --git a/libio/wfileops.c b/libio/wfileops.c
> index fb9d45b677..b59a98881f 100644
> --- a/libio/wfileops.c
> +++ b/libio/wfileops.c
> @@ -412,7 +412,8 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
>        return WEOF;
>      }
>    /* If currently reading or no buffer allocated. */
> -  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
> +  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
> +      || f->_wide_data->_IO_write_base == NULL)
>      {
>        /* Allocate a buffer if needed. */
>        if (f->_wide_data->_IO_write_base == 0)

Ok.

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH v4] libio: Ensure output buffer for wchars (bug 28828)
  2022-03-08 17:12   ` Adhemerval Zanella
@ 2022-03-08 17:27     ` José Bollo
  0 siblings, 0 replies; 18+ messages in thread
From: José Bollo @ 2022-03-08 17:27 UTC (permalink / raw)
  To: Adhemerval Zanella; +Cc: libc-alpha

On Tue, 8 Mar 2022 14:12:48 -0300
Adhemerval Zanella <adhemerval.zanella@linaro.org> wrote:


> ... I will fix the style issues below and install it.

thank you for fixing it -_-

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH] libio: Ensure output buffer for wchars (bug 28828)
  2022-02-14 20:23 [PATCH] " José Bollo
@ 2022-02-21 19:14 ` Adhemerval Zanella
  0 siblings, 0 replies; 18+ messages in thread
From: Adhemerval Zanella @ 2022-02-21 19:14 UTC (permalink / raw)
  To: José Bollo, libc-alpha



On 14/02/2022 17:23, José Bollo wrote:
> From: "jobol@nonadev.net" <jobol@nonadev.net>
> 
> When fileops.c checks for nullity of the write pointer,
> in order to ensure its allocation, before that patch,
> wfileops didn't. This was leading to crashes on some cases,
> as described by bug 28828.
> 
> The minimal sequence to produce the crash was:
> 
>     #include <stdio.h>
>     #include <wchar.h>
>     int main(int ac, char **av)
>     {
>             setvbuf(stdout, NULL, _IOLBF, 0);
>             fgetwc(stdin);
>             fputwc(10, stdout); /*CRASH HERE!*/
>             return 0;
>     }
> 
> The line "fgetwc(stdin);" is necessary. It introduces the
> bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
> indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).
> 
> Signed-off-by: Jose Bollo <jobol@nonadev.net>
> ---
>  libio/Makefile      |  2 +-
>  libio/tst-bz28828.c | 10 ++++++++++
>  libio/wfileops.c    |  5 +++--
>  3 files changed, 14 insertions(+), 3 deletions(-)
>  create mode 100644 libio/tst-bz28828.c
> 
> diff --git a/libio/Makefile b/libio/Makefile
> index 0e5f348bea..e97387743f 100644
> --- a/libio/Makefile
> +++ b/libio/Makefile
> @@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc   \
>  	tst-fwrite-error tst-ftell-partial-wide tst-ftell-active-handler \
>  	tst-ftell-append tst-fputws tst-bz22415 tst-fgetc-after-eof \
>  	tst-sprintf-ub tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
> -	tst-wfile-sync
> +	tst-wfile-sync tst-bz28828
>  
>  tests-internal = tst-vtables tst-vtables-interposed
>  
> diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
> new file mode 100644
> index 0000000000..f5849d2ca6
> --- /dev/null
> +++ b/libio/tst-bz28828.c
> @@ -0,0 +1,10 @@
> +#include <stdio.h>
> +#include <wchar.h>
> +int main(int ac, char **av)
> +{
> +	setvbuf(stdout, NULL, _IOLBF, 0);
> +	fgetwc(stdin);
> +	fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/
> +	return 0;
> +}
> +

Sorry but this test is unacceptable, it blocks the make check indefinitely
(triggering a failure) and does not use libsupport.  This fix requires a
proper testcase, there multiple ways to do, so please check an already
test on libio.  

> diff --git a/libio/wfileops.c b/libio/wfileops.c
> index fb9d45b677..aa94a22983 100644
> --- a/libio/wfileops.c
> +++ b/libio/wfileops.c
> @@ -412,10 +412,11 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
>        return WEOF;
>      }
>    /* If currently reading or no buffer allocated. */
> -  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
> +  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
> +      || f->_wide_data->_IO_write_base == NULL)
>      {

It seems ok, the _IOFBF buffer type has a specific case for buf being
null where it ended up calling _IO_DOALLOCATE (which _IOLBF does not).

>        /* Allocate a buffer if needed. */
> -      if (f->_wide_data->_IO_write_base == 0)
> +      if (f->_wide_data->_IO_write_base == NULL)

I would prefer to avoid make style change on a bug fix. 

>  	{
>  	  _IO_wdoallocbuf (f);
>  	  _IO_free_wbackup_area (f);

^ permalink raw reply	[flat|nested] 18+ messages in thread

* [PATCH] libio: Ensure output buffer for wchars (bug 28828)
@ 2022-02-14 20:23 José Bollo
  2022-02-21 19:14 ` Adhemerval Zanella
  0 siblings, 1 reply; 18+ messages in thread
From: José Bollo @ 2022-02-14 20:23 UTC (permalink / raw)
  To: libc-alpha; +Cc: jobol, Adhemerval Zanella

From: "jobol@nonadev.net" <jobol@nonadev.net>

When fileops.c checks for nullity of the write pointer,
in order to ensure its allocation, before that patch,
wfileops didn't. This was leading to crashes on some cases,
as described by bug 28828.

The minimal sequence to produce the crash was:

    #include <stdio.h>
    #include <wchar.h>
    int main(int ac, char **av)
    {
            setvbuf(stdout, NULL, _IOLBF, 0);
            fgetwc(stdin);
            fputwc(10, stdout); /*CRASH HERE!*/
            return 0;
    }

The line "fgetwc(stdin);" is necessary. It introduces the
bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).

Signed-off-by: Jose Bollo <jobol@nonadev.net>
---
 libio/Makefile      |  2 +-
 libio/tst-bz28828.c | 10 ++++++++++
 libio/wfileops.c    |  5 +++--
 3 files changed, 14 insertions(+), 3 deletions(-)
 create mode 100644 libio/tst-bz28828.c

diff --git a/libio/Makefile b/libio/Makefile
index 0e5f348bea..e97387743f 100644
--- a/libio/Makefile
+++ b/libio/Makefile
@@ -66,7 +66,7 @@ tests = tst_swprintf tst_wprintf tst_swscanf tst_wscanf tst_getwc tst_putwc   \
 	tst-fwrite-error tst-ftell-partial-wide tst-ftell-active-handler \
 	tst-ftell-append tst-fputws tst-bz22415 tst-fgetc-after-eof \
 	tst-sprintf-ub tst-sprintf-chk-ub tst-bz24051 tst-bz24153 \
-	tst-wfile-sync
+	tst-wfile-sync tst-bz28828
 
 tests-internal = tst-vtables tst-vtables-interposed
 
diff --git a/libio/tst-bz28828.c b/libio/tst-bz28828.c
new file mode 100644
index 0000000000..f5849d2ca6
--- /dev/null
+++ b/libio/tst-bz28828.c
@@ -0,0 +1,10 @@
+#include <stdio.h>
+#include <wchar.h>
+int main(int ac, char **av)
+{
+	setvbuf(stdout, NULL, _IOLBF, 0);
+	fgetwc(stdin);
+	fputwc(10, stdout); /*SHOUDN'T CRASH HERE!*/
+	return 0;
+}
+
diff --git a/libio/wfileops.c b/libio/wfileops.c
index fb9d45b677..aa94a22983 100644
--- a/libio/wfileops.c
+++ b/libio/wfileops.c
@@ -412,10 +412,11 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
       return WEOF;
     }
   /* If currently reading or no buffer allocated. */
-  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
+  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
+      || f->_wide_data->_IO_write_base == NULL)
     {
       /* Allocate a buffer if needed. */
-      if (f->_wide_data->_IO_write_base == 0)
+      if (f->_wide_data->_IO_write_base == NULL)
 	{
 	  _IO_wdoallocbuf (f);
 	  _IO_free_wbackup_area (f);
-- 
2.34.1


^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH] libio: Ensure output buffer for wchars (bug 28828)
  2022-02-14 18:10   ` José Bollo
@ 2022-02-14 18:37     ` Adhemerval Zanella
  0 siblings, 0 replies; 18+ messages in thread
From: Adhemerval Zanella @ 2022-02-14 18:37 UTC (permalink / raw)
  To: José Bollo; +Cc: libc-alpha



On 14/02/2022 15:10, José Bollo wrote:
> On Mon, 14 Feb 2022 11:15:46 -0300
> Adhemerval Zanella <adhemerval.zanella@linaro.org> wrote:
> 
>> On 13/02/2022 16:52, jobol@nonadev.net wrote:
>>> When fileops.c checks for nullity of the write pointer,
>>> in order to ensure its allocation, before that patch,
>>> wfileops didn't. This was leading to crashes on some cases,
>>> as described by bug 28828.
>>>
>>> The minimal sequence to produce the crash was:
>>>
>>>     #include <stdio.h>
>>>     #include <wchar.h>
>>>     int main(int ac, char **av)
>>>     {
>>>             setvbuf(stdout, NULL, _IOLBF, 0);
>>>             fgetwc(stdin);
>>>             fputwc(10, stdout); /*CRASH HERE!*/
>>>             return 0;
>>>     }
>>>
>>> The line "fgetwc(stdin);" is necessary. It introduces the
>>> bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
>>> indirectly (file wfileops.c, function _IO_wfile_underflow, line
>>> 213).
>>>
>>> Signed-off-by: Jose Bollo <jobol@nonadev.net>  
>>
>> Patch looks ok, but git-pw fails to apply it:
>>
>> $ git-pw patch apply 51088
>> Applying: libio: Ensure output buffer for wchars (bug 28828)
>> error: patch failed: libio/wfileops.c:412
>> error: libio/wfileops.c: patch does not apply
>> error: Did you hand edit your patch?
> 
> I copied the ouput of [git format-patch], following as much as possible
> https://sourceware.org/glibc/wiki/Contribution%20checklist but didn't
> used [git send-email]. I don't have the command [git pw] that you are
> using. I can see that [git apply] produce the same issue but [git am]
> perfectly works.

The main problem is even without using git-pw it does fail (the buildbot
has throw an issue as well).  From the weekly call it seems that your
email client (or the way you have sent the patch) replaces the already
existing tab with whitesapce.

> 
>> Could you resend it? 
> 
> I can try but maybe you have a hint avoiding me to do the same...
> 
>> Also, could you also provide a regression testcase for this fix?
> 
> Why not. Where? a libio/bug-XXX.c ?

I think it preferable to follow current trend, so libio/tst-bz28828.c.

> 
>>> ---
>>>  libio/wfileops.c | 5 +++--
>>>  1 file changed, 3 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/libio/wfileops.c b/libio/wfileops.c
>>> index fb9d45b677..aa94a22983 100644
>>> --- a/libio/wfileops.c
>>> +++ b/libio/wfileops.c
>>> @@ -412,10 +412,11 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
>>>        return WEOF;
>>>      }
>>>    /* If currently reading or no buffer allocated. */
>>> -  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
>>> +  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
>>> +      || f->_wide_data->_IO_write_base == NULL)
>>>      {
>>>        /* Allocate a buffer if needed. */
>>> -      if (f->_wide_data->_IO_write_base == 0)
>>> +      if (f->_wide_data->_IO_write_base == NULL)
>>>      {
>>>        _IO_wdoallocbuf (f);
>>>        _IO_free_wbackup_area (f);  
> 

^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH] libio: Ensure output buffer for wchars (bug 28828)
  2022-02-14 14:15 ` Adhemerval Zanella
@ 2022-02-14 18:10   ` José Bollo
  2022-02-14 18:37     ` Adhemerval Zanella
  0 siblings, 1 reply; 18+ messages in thread
From: José Bollo @ 2022-02-14 18:10 UTC (permalink / raw)
  To: Adhemerval Zanella; +Cc: libc-alpha

On Mon, 14 Feb 2022 11:15:46 -0300
Adhemerval Zanella <adhemerval.zanella@linaro.org> wrote:

> On 13/02/2022 16:52, jobol@nonadev.net wrote:
> > When fileops.c checks for nullity of the write pointer,
> > in order to ensure its allocation, before that patch,
> > wfileops didn't. This was leading to crashes on some cases,
> > as described by bug 28828.
> > 
> > The minimal sequence to produce the crash was:
> > 
> >     #include <stdio.h>
> >     #include <wchar.h>
> >     int main(int ac, char **av)
> >     {
> >             setvbuf(stdout, NULL, _IOLBF, 0);
> >             fgetwc(stdin);
> >             fputwc(10, stdout); /*CRASH HERE!*/
> >             return 0;
> >     }
> > 
> > The line "fgetwc(stdin);" is necessary. It introduces the
> > bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
> > indirectly (file wfileops.c, function _IO_wfile_underflow, line
> > 213).
> > 
> > Signed-off-by: Jose Bollo <jobol@nonadev.net>  
> 
> Patch looks ok, but git-pw fails to apply it:
> 
> $ git-pw patch apply 51088
> Applying: libio: Ensure output buffer for wchars (bug 28828)
> error: patch failed: libio/wfileops.c:412
> error: libio/wfileops.c: patch does not apply
> error: Did you hand edit your patch?

I copied the ouput of [git format-patch], following as much as possible
https://sourceware.org/glibc/wiki/Contribution%20checklist but didn't
used [git send-email]. I don't have the command [git pw] that you are
using. I can see that [git apply] produce the same issue but [git am]
perfectly works.

> Could you resend it? 

I can try but maybe you have a hint avoiding me to do the same...

> Also, could you also provide a regression testcase for this fix?

Why not. Where? a libio/bug-XXX.c ?

> > ---
> >  libio/wfileops.c | 5 +++--
> >  1 file changed, 3 insertions(+), 2 deletions(-)
> > 
> > diff --git a/libio/wfileops.c b/libio/wfileops.c
> > index fb9d45b677..aa94a22983 100644
> > --- a/libio/wfileops.c
> > +++ b/libio/wfileops.c
> > @@ -412,10 +412,11 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
> >        return WEOF;
> >      }
> >    /* If currently reading or no buffer allocated. */
> > -  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
> > +  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
> > +      || f->_wide_data->_IO_write_base == NULL)
> >      {
> >        /* Allocate a buffer if needed. */
> > -      if (f->_wide_data->_IO_write_base == 0)
> > +      if (f->_wide_data->_IO_write_base == NULL)
> >      {
> >        _IO_wdoallocbuf (f);
> >        _IO_free_wbackup_area (f);  


^ permalink raw reply	[flat|nested] 18+ messages in thread

* Re: [PATCH] libio: Ensure output buffer for wchars (bug 28828)
  2022-02-13 19:52 jobol
@ 2022-02-14 14:15 ` Adhemerval Zanella
  2022-02-14 18:10   ` José Bollo
  0 siblings, 1 reply; 18+ messages in thread
From: Adhemerval Zanella @ 2022-02-14 14:15 UTC (permalink / raw)
  To: jobol, libc-alpha



On 13/02/2022 16:52, jobol@nonadev.net wrote:
> When fileops.c checks for nullity of the write pointer,
> in order to ensure its allocation, before that patch,
> wfileops didn't. This was leading to crashes on some cases,
> as described by bug 28828.
> 
> The minimal sequence to produce the crash was:
> 
>     #include <stdio.h>
>     #include <wchar.h>
>     int main(int ac, char **av)
>     {
>             setvbuf(stdout, NULL, _IOLBF, 0);
>             fgetwc(stdin);
>             fputwc(10, stdout); /*CRASH HERE!*/
>             return 0;
>     }
> 
> The line "fgetwc(stdin);" is necessary. It introduces the
> bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
> indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).
> 
> Signed-off-by: Jose Bollo <jobol@nonadev.net>

Patch looks ok, but git-pw fails to apply it:

$ git-pw patch apply 51088
Applying: libio: Ensure output buffer for wchars (bug 28828)
error: patch failed: libio/wfileops.c:412
error: libio/wfileops.c: patch does not apply
error: Did you hand edit your patch?

Could you resend it? 

Also, could you also provide a regression testcase for this fix?

> ---
>  libio/wfileops.c | 5 +++--
>  1 file changed, 3 insertions(+), 2 deletions(-)
> 
> diff --git a/libio/wfileops.c b/libio/wfileops.c
> index fb9d45b677..aa94a22983 100644
> --- a/libio/wfileops.c
> +++ b/libio/wfileops.c
> @@ -412,10 +412,11 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
>        return WEOF;
>      }
>    /* If currently reading or no buffer allocated. */
> -  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
> +  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
> +      || f->_wide_data->_IO_write_base == NULL)
>      {
>        /* Allocate a buffer if needed. */
> -      if (f->_wide_data->_IO_write_base == 0)
> +      if (f->_wide_data->_IO_write_base == NULL)
>      {
>        _IO_wdoallocbuf (f);
>        _IO_free_wbackup_area (f);

^ permalink raw reply	[flat|nested] 18+ messages in thread

* [PATCH] libio: Ensure output buffer for wchars (bug 28828)
@ 2022-02-13 19:52 jobol
  2022-02-14 14:15 ` Adhemerval Zanella
  0 siblings, 1 reply; 18+ messages in thread
From: jobol @ 2022-02-13 19:52 UTC (permalink / raw)
  To: libc-alpha; +Cc: jobol

When fileops.c checks for nullity of the write pointer,
in order to ensure its allocation, before that patch,
wfileops didn't. This was leading to crashes on some cases,
as described by bug 28828.

The minimal sequence to produce the crash was:

     #include <stdio.h>
     #include <wchar.h>
     int main(int ac, char **av)
     {
             setvbuf(stdout, NULL, _IOLBF, 0);
             fgetwc(stdin);
             fputwc(10, stdout); /*CRASH HERE!*/
             return 0;
     }

The line "fgetwc(stdin);" is necessary. It introduces the
bug by setting the flag _IO_CURRENTLY_PUTTING of stdout
indirectly (file wfileops.c, function _IO_wfile_underflow, line 213).

Signed-off-by: Jose Bollo <jobol@nonadev.net>
---
  libio/wfileops.c | 5 +++--
  1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/libio/wfileops.c b/libio/wfileops.c
index fb9d45b677..aa94a22983 100644
--- a/libio/wfileops.c
+++ b/libio/wfileops.c
@@ -412,10 +412,11 @@ _IO_wfile_overflow (FILE *f, wint_t wch)
        return WEOF;
      }
    /* If currently reading or no buffer allocated. */
-  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0)
+  if ((f->_flags & _IO_CURRENTLY_PUTTING) == 0
+      || f->_wide_data->_IO_write_base == NULL)
      {
        /* Allocate a buffer if needed. */
-      if (f->_wide_data->_IO_write_base == 0)
+      if (f->_wide_data->_IO_write_base == NULL)
  	{
  	  _IO_wdoallocbuf (f);
  	  _IO_free_wbackup_area (f);
-- 
2.34.1

^ permalink raw reply	[flat|nested] 18+ messages in thread

end of thread, other threads:[~2022-03-08 17:27 UTC | newest]

Thread overview: 18+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-02-22 20:55 [PATCH v3] libio: Ensure output buffer for wchars (bug 28828) jobol
2022-03-04 19:39 ` Adhemerval Zanella
2022-03-04 19:53   ` Andreas Schwab
2022-03-07 11:03     ` Adhemerval Zanella
2022-03-07 11:29       ` Andreas Schwab
2022-03-07 11:33         ` Adhemerval Zanella
2022-03-07 11:37           ` Andreas Schwab
2022-03-08  8:44   ` José Bollo
2022-03-08  8:54 ` [PATCH] " jobol
2022-03-08  8:58 ` [PATCH v4] " jobol
2022-03-08 17:12   ` Adhemerval Zanella
2022-03-08 17:27     ` José Bollo
  -- strict thread matches above, loose matches on Subject: below --
2022-02-14 20:23 [PATCH] " José Bollo
2022-02-21 19:14 ` Adhemerval Zanella
2022-02-13 19:52 jobol
2022-02-14 14:15 ` Adhemerval Zanella
2022-02-14 18:10   ` José Bollo
2022-02-14 18:37     ` Adhemerval Zanella

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).