ioctl() on socket fd's take 3 seconds on 1.7.7

Corinna Vinschen corinna-cygwin@cygwin.com
Mon Nov 22 13:17:00 GMT 2010


On Nov 20 18:25, Jason Curl wrote:
> On 15/11/2010 17:22, Corinna Vinschen wrote:
> >On Nov  9 09:20, Jason Curl wrote:
> >>   166   65418 [main] ipcheck 5580 ioctl: fd 3, cmd 80087364
> >>--- Process 5580, exception C0000005 at 610C8C86
> >
> >Crash in Cygwin, but the address doesn't help much, unfortunately.
> >
> >>Interestingly enough, the program works. That is, it finds all
> >>interfaces and returns correct values (except interface names are
> >>UUIDs instead of something more friendly like "eth0" that existed in
> >>1.5.26).
> >>
> >>It will be a little later when I'm able to generate a working test case.
> >
> >T'would be nice.  Please make it short and simple and, if possible, in
> >plain C.
> 
> I've generated a relatively simple test case that I can compile
> using cygwin1-20101102.dll.

Thank you.  I can't reproduce any slowness, each ioctl takes only a
couple of milliseconds.  At least I could reproduce the exception when
stracing the testcase and I've applied a matching patch to Cygwin.

Can you retry with the next developer snapshot?  Are the ioctl calls
still slow?  If so, I'm wondering if the GetAdaptersAddresses call is
rather slow if a lot of interfaces exist.  Every single ioctl in your
application calls GetAdaptersAddresses twice, like this:

bool
get_adapters_addresses (PIP_ADAPTER_ADDRESSES *pa_ret, ULONG family)
{
  DWORD ret, size = 0;
  PIP_ADAPTER_ADDRESSES pa0 = NULL;

  if (!pa_ret)
    return ERROR_BUFFER_OVERFLOW
           == GetAdaptersAddresses (family, GAA_FLAG_INCLUDE_PREFIX
                                            | GAA_FLAG_INCLUDE_ALL_INTERFACES,
                                    NULL, NULL, &size);
  do
    {
      ret = GetAdaptersAddresses (family, GAA_FLAG_INCLUDE_PREFIX
                                          | GAA_FLAG_INCLUDE_ALL_INTERFACES,
                                  NULL, pa0, &size);
      if (ret == ERROR_BUFFER_OVERFLOW
          && !(pa0 = (PIP_ADAPTER_ADDRESSES) realloc (pa0, size)))
        break;
    }
  while (ret == ERROR_BUFFER_OVERFLOW);
  if (ret != ERROR_SUCCESS)
    {
      if (pa0)
        free (pa0);
      *pa_ret = NULL;
      return false;
    }
  *pa_ret = pa0;
  return true;
}

Can you test how long this call takes in your scenario, and if it
might be the culprit?


Corinna

-- 
Corinna Vinschen                  Please, send mails regarding Cygwin to
Cygwin Project Co-Leader          cygwin AT cygwin DOT com
Red Hat

--
Problem reports:       http://cygwin.com/problems.html
FAQ:                   http://cygwin.com/faq/
Documentation:         http://cygwin.com/docs.html
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple



More information about the Cygwin mailing list