From: Sergio Durigan Junior <sergiodj@redhat.com>
To: Pedro Alves <palves@redhat.com>
Cc: GDB Patches <gdb-patches@sourceware.org>,
Bernhard Wodok <barto@gmx.net>,
Paul Carroll <pcarroll@codesourcery.com>
Subject: Re: [PATCH] Fix PR win32/24284: tcp_auto_retry doesn't work in MinGW
Date: Thu, 29 Aug 2019 16:36:00 -0000 [thread overview]
Message-ID: <87zhjs9be2.fsf@redhat.com> (raw)
In-Reply-To: <64a05dd3-ad63-eb64-49b4-cbc5faf51824@redhat.com> (Pedro Alves's message of "Thu, 29 Aug 2019 13:15:41 +0100")
On Thursday, August 29 2019, Pedro Alves wrote:
> On 8/27/19 4:50 PM, Sergio Durigan Junior wrote:
>> This was reported by Bernhard Wodok, along with a patch to fix the
>> issue. I adjusted the patch a bit, and I'm submitting the patch on
>> his behalf.
>>
>> According to Bernhard, the issue can be reproduced by doing:
>>
>> 1. start gdb
>> 2. enter 'target remote :2345'
>> 3. observe that it throws a "connection refused" error immediately
>> instead of waiting and throwing a timeout error
>>
>> I.e., I believe it can be reproduced by our current tests, which is
>> why I'm not proposing any extra tests here (well, I don't use nor have
>> any Windows system to test this, so...).
>>
>> The problem happens because we call 'gdb_select' passing 0 as its
>> first argument,
Thanks for the review, Pedro.
> I assume this is from wait_for_connect? Please mention that above.
Yes. I'll do that.
> Must be, because I just now noticed that gdb_usleep is now dead code.
>
> The comment in wait_for_connect is quite curious, kind of implies that
> this worked on Windows at some point:
>
> /* Use gdb_select here, since we have no file descriptors, and on
> Windows, plain select doesn't work in that case. */
> n = gdb_select (0, NULL, NULL, NULL, &t);
Indeed. This comment was added by:
commit 84603566b73e9ad18d094da3b7510ab480db8170
Author: Sandra Loosemore <sandra@codesourcery.com>
Date: Tue Jan 6 17:07:08 2009 +0000
It's not entirely clear that calling gdb_select on Windows will actually
call WaitForMultipleObjects. There is a 'select'c call in the Windows
API:
https://docs.microsoft.com/en-us/windows/win32/api/winsock2/nf-winsock2-select
So maybe it was assumed that the code would call this function
instead...
>> --- a/gdb/mingw-hdep.c
>> +++ b/gdb/mingw-hdep.c
>> @@ -64,6 +64,17 @@ gdb_select (int n, fd_set *readfds, fd_set *writefds, fd_set *exceptfds,
>> int num_ready;
>> size_t indx;
>>
>> + if (n == 0)
>> + {
>> + /* The MS API says that the first argument to
>> + WaitForMultipleObjects cannot be zero. That's we just use
>> + a regular Sleep here. */
>
> The sentence:
>
> "That's we just use a regular Sleep here."
>
> is non-grammatical. Missing a "why" in "That's why" ?
Yes, fixed.
> OK with that fixed.
Thanks, pushed: 16d01f9cd49f553a958a69ad3c9f781ebd402da8
--
Sergio
GPG key ID: 237A 54B1 0287 28BF 00EF 31F4 D0EB 7628 65FC 5E36
Please send encrypted e-mail if possible
http://sergiodj.net/
prev parent reply other threads:[~2019-08-29 16:36 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-08-27 15:50 Sergio Durigan Junior
2019-08-29 12:15 ` Pedro Alves
2019-08-29 16:36 ` Sergio Durigan Junior [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87zhjs9be2.fsf@redhat.com \
--to=sergiodj@redhat.com \
--cc=barto@gmx.net \
--cc=gdb-patches@sourceware.org \
--cc=palves@redhat.com \
--cc=pcarroll@codesourcery.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox