librb: commio: Must set addrlen before every call to accept()
If an IPv4 connection is dropped by the pre-callback, and there is a pending IPv6 connection on the same listening socket then the retried accept() will be unable to populate `st` because `addrlen` will be too small. Also initialise `st` each time to avoid a clang static analysis warning.
This commit is contained in:
parent
8467fd9caf
commit
b0adc7bf97
1 changed files with 4 additions and 5 deletions
|
@ -346,11 +346,14 @@ rb_accept_tryaccept(rb_fde_t *F, void *data)
|
|||
{
|
||||
struct rb_sockaddr_storage st;
|
||||
rb_fde_t *new_F;
|
||||
rb_socklen_t addrlen = sizeof(st);
|
||||
rb_socklen_t addrlen;
|
||||
int new_fd;
|
||||
|
||||
while(1)
|
||||
{
|
||||
memset(&st, 0, sizeof(st));
|
||||
addrlen = sizeof(st);
|
||||
|
||||
new_fd = accept(F->fd, (struct sockaddr *)&st, &addrlen);
|
||||
rb_get_errno();
|
||||
if(new_fd < 0)
|
||||
|
@ -752,9 +755,6 @@ mangle_mapped_sockaddr(struct sockaddr *in)
|
|||
{
|
||||
struct sockaddr_in6 *in6 = (struct sockaddr_in6 *)in;
|
||||
|
||||
if(in->sa_family == AF_INET)
|
||||
return;
|
||||
|
||||
if(in->sa_family == AF_INET6 && IN6_IS_ADDR_V4MAPPED(&in6->sin6_addr))
|
||||
{
|
||||
struct sockaddr_in in4;
|
||||
|
@ -764,7 +764,6 @@ mangle_mapped_sockaddr(struct sockaddr *in)
|
|||
in4.sin_addr.s_addr = ((uint32_t *)&in6->sin6_addr)[3];
|
||||
memcpy(in, &in4, sizeof(struct sockaddr_in));
|
||||
}
|
||||
return;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
Loading…
Reference in a new issue