R: getsockopt(SO_KEEPALIVE) returns incorrect option length

Marco Atzeri marco_atzeri@yahoo.it
Fri Jul 2 10:20:00 GMT 2010


--- Ven 2/7/10, Pavel Holejsovsky ha scritto:

> Hi,
> 
> I think that following problem shows problematic behavior
> in cygwin 1.7.5, at least incompatible with linux:
> 
> #include <stdio.h>
> #include <sys/socket.h>
> 
> int main() {
>         int sock, option, optlen =
> sizeof(int);
>         sock = socket(AF_INET,
> SOCK_STREAM, 0);
>         getsockopt(sock, SOL_SOCKET,
> SO_KEEPALIVE, &option, &optlen);
>         printf("option=%d,
> optlen=%d\n", option, optlen);
>         return 0;
> }
> 
> Prints optlen=1, while it is expected to be sizeof(int),
> i.e. 4.
> 
> This is most probably because uinderlying winsock call has
> this (mis)behavior, but I think that in cygwin layer this
> could be worked around to be more unix compatible.
> 
> This issue is relevant:
> 
> SO_KEEPALIVE value is actually a char on Windows, not BOOL
> https://bugzilla.gnome.org/show_bug.cgi?id=611756
> 
> And causes glib gio 2.24 to fail certain socket operations
> on cygwin.
> 
> thanks,
> Pavel

option=0, optlen=4

on XP-sp2, cygwin 1.7.5s(0.227/5/3) 20100628


MArco






--
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