[parent not found: <"002201ce9414$7e0d7130$7a285390$@muller"@ics-cnrs.unistra.fr>]
* Re: [RFC] Avoid invalid parameter warnings in C runtime function for mingw builtr GDB
[not found] <"002201ce9414$7e0d7130$7a285390$@muller"@ics-cnrs.unistra.fr>
@ 2013-08-09 14:09 ` Eli Zaretskii
2013-08-13 9:13 ` Pierre Muller
` (2 more replies)
0 siblings, 3 replies; 6+ messages in thread
From: Eli Zaretskii @ 2013-08-09 14:09 UTC (permalink / raw)
To: Pierre Muller; +Cc: gdb-patches
> From: "Pierre Muller" <pierre.muller@ics-cnrs.unistra.fr>
> Date: Thu, 8 Aug 2013 10:51:37 +0200
>
> Lately I got several warnings with mingw built
> GDB's:
>
> warning: Invalid parameter passed to C runtime function.
>
> Use the new "set stop-on-debug-string-event on"
> command submitted previously in
> http://sourceware.org/ml/gdb-patches/2013-08/msg00236.html
>
> I was able to trace this down to
> the fopen call with mode that to "re".
> As stated in the source, the "e" mode is a glibc extension
> about close on exec which generates this warning.
>
> The patch below excludes this code if __MINGW32__ is defined,
> but maybe it should be excluded if O_CLOEXEC is zero?
Actually, if we want this to be portable, we should have a function to
make a file handle be non-inheritable, instead of relying on glibc
extensions. There _is_ a way to make a file handle non-inheritable on
Windows.
> diff -u -p -r1.7 filestuff.c
> --- src/gdb/common/filestuff.c 26 Jun 2013 08:01:55 -0000 1.7
> +++ src/gdb/common/filestuff.c 7 Aug 2013 12:35:55 -0000
> @@ -311,6 +311,7 @@ FILE *
> gdb_fopen_cloexec (const char *filename, const char *opentype)
> {
> FILE *result = NULL;
> +#ifndef __MINGW32__
> static int fopen_e_ever_failed;
>
> if (!fopen_e_ever_failed)
> @@ -320,17 +321,21 @@ gdb_fopen_cloexec (const char *filename,
> copy = alloca (strlen (opentype) + 2);
> strcpy (copy, opentype);
> /* This is a glibc extension but we try it unconditionally on
> - this path. */
> + this path, except when using Windows OS msvcrt dll,
> + in order to avoid a output debug string event. */
> strcat (copy, "e");
> result = fopen (filename, copy);
> }
> +#endif
>
> if (result == NULL)
> {
> /* Fallback. */
> result = fopen (filename, opentype);
> +#ifndef __MINGW32__
> if (result != NULL)
> fopen_e_ever_failed = 1;
> +#endif
> }
>
> if (result != NULL)
Wouldn't it be better to instead initialize fopen_e_ever_failed to 1
on MinGW? Then the rest of the code will "just work", no?
^ permalink raw reply [flat|nested] 6+ messages in thread* RE: [RFC] Avoid invalid parameter warnings in C runtime function for mingw builtr GDB
2013-08-09 14:09 ` Eli Zaretskii
@ 2013-08-13 9:13 ` Pierre Muller
[not found] ` <41630.7793967009$1376385245@news.gmane.org>
[not found] ` <"001401ce9805$6cce7050$466b50f0$@muller"@ics-cnrs.unistra.fr>
2 siblings, 0 replies; 6+ messages in thread
From: Pierre Muller @ 2013-08-13 9:13 UTC (permalink / raw)
To: 'Eli Zaretskii'; +Cc: gdb-patches
> -----Message d'origine-----
> De : gdb-patches-owner@sourceware.org [mailto:gdb-patches-
> owner@sourceware.org] De la part de Eli Zaretskii
> Envoyé : vendredi 9 août 2013 16:10
> À : Pierre Muller
> Cc : gdb-patches@sourceware.org
> Objet : Re: [RFC] Avoid invalid parameter warnings in C runtime function
for
> mingw builtr GDB
>
> > From: "Pierre Muller" <pierre.muller@ics-cnrs.unistra.fr>
> > Date: Thu, 8 Aug 2013 10:51:37 +0200
> >
> > Lately I got several warnings with mingw built
> > GDB's:
> >
> > warning: Invalid parameter passed to C runtime function.
> >
> > Use the new "set stop-on-debug-string-event on"
> > command submitted previously in
> > http://sourceware.org/ml/gdb-patches/2013-08/msg00236.html
> >
> > I was able to trace this down to
> > the fopen call with mode that to "re".
> > As stated in the source, the "e" mode is a glibc extension
> > about close on exec which generates this warning.
> >
> > The patch below excludes this code if __MINGW32__ is defined,
> > but maybe it should be excluded if O_CLOEXEC is zero?
>
> Actually, if we want this to be portable, we should have a function to
> make a file handle be non-inheritable, instead of relying on glibc
> extensions. There _is_ a way to make a file handle non-inheritable on
> Windows.
>
> > diff -u -p -r1.7 filestuff.c
> > --- src/gdb/common/filestuff.c 26 Jun 2013 08:01:55 -0000 1.7
> > +++ src/gdb/common/filestuff.c 7 Aug 2013 12:35:55 -0000
> > @@ -311,6 +311,7 @@ FILE *
> > gdb_fopen_cloexec (const char *filename, const char *opentype)
> > {
> > FILE *result = NULL;
> > +#ifndef __MINGW32__
> > static int fopen_e_ever_failed;
> >
> > if (!fopen_e_ever_failed)
> > @@ -320,17 +321,21 @@ gdb_fopen_cloexec (const char *filename,
> > copy = alloca (strlen (opentype) + 2);
> > strcpy (copy, opentype);
> > /* This is a glibc extension but we try it unconditionally on
> > - this path. */
> > + this path, except when using Windows OS msvcrt dll,
> > + in order to avoid a output debug string event. */
> > strcat (copy, "e");
> > result = fopen (filename, copy);
> > }
> > +#endif
> >
> > if (result == NULL)
> > {
> > /* Fallback. */
> > result = fopen (filename, opentype);
> > +#ifndef __MINGW32__
> > if (result != NULL)
> > fopen_e_ever_failed = 1;
> > +#endif
> > }
> >
> > if (result != NULL)
>
> Wouldn't it be better to instead initialize fopen_e_ever_failed to 1
> on MinGW? Then the rest of the code will "just work", no?
Once again, my insufficient C knowledge is to blame...
Would that be correct?
#if O_CLOEXEC
static int fopen_e_ever_failed = 0;
#else
static int fopen_e_ever_failed = 1;
#endif
But then the variable name is not appropriate anymore...
In fact, when I tried to read the code around that function, I
discovered that there is already another variable called
trust_o_cloexec
It seems to me that both are testing the same glibc extension,
trust_o_cloexec as it numeric form O_CLOEXEC
and fopen_e_ever_failed as its string mode equivalent "e".
Is it really possible that trust_o_cloexec and fopen_e_ever_failed
do not match?
Should a unique variable be enough?
Concerning my original RFC, should I resubmit it with the above suggestion?
Pierre Muller
^ permalink raw reply [flat|nested] 6+ messages in thread[parent not found: <41630.7793967009$1376385245@news.gmane.org>]
* Re: [RFC] Avoid invalid parameter warnings in C runtime function for mingw builtr GDB
[not found] ` <41630.7793967009$1376385245@news.gmane.org>
@ 2013-08-13 15:37 ` Tom Tromey
0 siblings, 0 replies; 6+ messages in thread
From: Tom Tromey @ 2013-08-13 15:37 UTC (permalink / raw)
To: Pierre Muller; +Cc: 'Eli Zaretskii', gdb-patches
>>>>> "Pierre" == Pierre Muller <pierre.muller@ics-cnrs.unistra.fr> writes:
Pierre> Once again, my insufficient C knowledge is to blame...
Pierre> Would that be correct?
Pierre> #if O_CLOEXEC
Pierre> static int fopen_e_ever_failed = 0;
Pierre> #else
Pierre> static int fopen_e_ever_failed = 1;
Pierre> #endif
O_CLOEXEC is unconditionally defined earlier.
But you can just write:
/* If we provide a fake O_CLOEXEC, then don't ever try "e". */
static int fopen_e_ever_failed = O_CLOEXEC == 0;
Pierre> But then the variable name is not appropriate anymore...
You can rename it if you want, but I don't really care either way.
Pierre> In fact, when I tried to read the code around that function, I
Pierre> discovered that there is already another variable called
Pierre> trust_o_cloexec
Pierre> It seems to me that both are testing the same glibc extension,
Pierre> trust_o_cloexec as it numeric form O_CLOEXEC
Pierre> and fopen_e_ever_failed as its string mode equivalent "e".
Pierre> Is it really possible that trust_o_cloexec and fopen_e_ever_failed
Pierre> do not match?
I forget exactly why I did this.
Maybe I was just being overly cautious.
Pierre> Should a unique variable be enough?
Maybe.
Tom
^ permalink raw reply [flat|nested] 6+ messages in thread
[parent not found: <"001401ce9805$6cce7050$466b50f0$@muller"@ics-cnrs.unistra.fr>]
* [RFC] Avoid invalid parameter warnings in C runtime function for mingw builtr GDB
@ 2013-08-08 8:51 Pierre Muller
0 siblings, 0 replies; 6+ messages in thread
From: Pierre Muller @ 2013-08-08 8:51 UTC (permalink / raw)
To: gdb-patches
Lately I got several warnings with mingw built
GDB's:
warning: Invalid parameter passed to C runtime function.
Use the new "set stop-on-debug-string-event on"
command submitted previously in
http://sourceware.org/ml/gdb-patches/2013-08/msg00236.html
I was able to trace this down to
the fopen call with mode that to "re".
As stated in the source, the "e" mode is a glibc extension
about close on exec which generates this warning.
The patch below excludes this code if __MINGW32__ is defined,
but maybe it should be excluded if O_CLOEXEC is zero?
Comments welcome.
Pierre Muller
GDB pascal language maintainer
2013-08-07 Pierre Muller <muller@sourceware.org>
* src/gdb/common/filestuff.c (gdb_fopen_cloexec): Do not
try to use "e" mode if linking to Windows OS msvcrt DLL,
to avoid getting a output debug string event.
Index: src/gdb/common/filestuff.c
===================================================================
RCS file: /cvs/src/src/gdb/common/filestuff.c,v
retrieving revision 1.7
diff -u -p -r1.7 filestuff.c
--- src/gdb/common/filestuff.c 26 Jun 2013 08:01:55 -0000 1.7
+++ src/gdb/common/filestuff.c 7 Aug 2013 12:35:55 -0000
@@ -311,6 +311,7 @@ FILE *
gdb_fopen_cloexec (const char *filename, const char *opentype)
{
FILE *result = NULL;
+#ifndef __MINGW32__
static int fopen_e_ever_failed;
if (!fopen_e_ever_failed)
@@ -320,17 +321,21 @@ gdb_fopen_cloexec (const char *filename,
copy = alloca (strlen (opentype) + 2);
strcpy (copy, opentype);
/* This is a glibc extension but we try it unconditionally on
- this path. */
+ this path, except when using Windows OS msvcrt dll,
+ in order to avoid a output debug string event. */
strcat (copy, "e");
result = fopen (filename, copy);
}
+#endif
if (result == NULL)
{
/* Fallback. */
result = fopen (filename, opentype);
+#ifndef __MINGW32__
if (result != NULL)
fopen_e_ever_failed = 1;
+#endif
}
if (result != NULL)
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2013-08-13 16:35 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
[not found] <22647.6293908947$1375951926@news.gmane.org>
2013-08-09 15:26 ` [RFC] Avoid invalid parameter warnings in C runtime function for mingw builtr GDB Tom Tromey
[not found] <"002201ce9414$7e0d7130$7a285390$@muller"@ics-cnrs.unistra.fr>
2013-08-09 14:09 ` Eli Zaretskii
2013-08-13 9:13 ` Pierre Muller
[not found] ` <41630.7793967009$1376385245@news.gmane.org>
2013-08-13 15:37 ` Tom Tromey
[not found] ` <"001401ce9805$6cce7050$466b50f0$@muller"@ics-cnrs.unistra.fr>
2013-08-13 16:35 ` Eli Zaretskii
2013-08-08 8:51 Pierre Muller
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox