[prev in list] [next in list] [prev in thread] [next in thread] 

List:       freedesktop-xcb
Subject:    Re: [Xcb] [PATCH] Increase unix socket send buffer to at least 64KB
From:       Mark Kettenis <mark.kettenis () xs4all ! nl>
Date:       2016-02-02 19:08:06
Message-ID: 201602021908.u12J8655005785 () glazunov ! sibelius ! xs4all ! nl
[Download RAW message or body]

> Date: Sun, 24 Jan 2016 10:48:41 +0100
> From: Matthieu Herrb <matthieu@herrb.eu>
>
> On Sat, Jan 23, 2016 at 05:29:32PM +0100, Mark Kettenis wrote:
> > Some systems (e.g. OpenBSD) have a rather small default socket send buffer
> > size of 4KB.  The result is that sending requests with a largish payload
> > requires serveral writev(2) system calls.  Make sure the socket send buff> er
> > is at least 64KB such that we're likely to succeed with a single system
> > call for most requests.  A similar change was made to the xtrans code
> > some time ago.
> > 
> > Signed-off-by: Mark Kettenis <kettenis@openbsd.org>
>
> Reviewed-by: Matthieu Herrb <matthieu@herrb.eu>

Looks like I don't have write permission to the libxcb repo.  Can
somebody push this for me, or give me write permission?

Thanks,

Mark

> > ---
> >  src/xcb_util.c | 7 +++++++
> >  1 file changed, 7 insertions(+)
> > 
> > diff --git a/src/xcb_util.c b/src/xcb_util.c
> > index ba0f108..a3357ef 100644
> > --- a/src/xcb_util.c
> > +++ b/src/xcb_util.c
> > @@ -428,6 +428,8 @@ static int _xcb_open_unix(char *protocol, const char > *file)
> >  {
> >      int fd;
> >      struct sockaddr_un addr;
> > +    socklen_t len = sizeof(int);
> > +    int val;
> >  
> >      if (protocol && strcmp("unix",protocol))
> >          return -1;
> > @@ -440,6 +442,11 @@ static int _xcb_open_unix(char *protocol, const char>  *file)
> >      fd = _xcb_socket(AF_UNIX, SOCK_STREAM, 0);
> >      if(fd == -1)
> >          return -1;
> > +    if(getsockopt(fd, SOL_SOCKET, SO_SNDBUF, &val, &len) == 0 && val>  < 64 * 1024)
> > +    {
> > +        val = 64 * 1024;
> > +        setsockopt(fd, SOL_SOCKET, SO_SNDBUF, &val, sizeof(int));
> > +    }
> >      if(connect(fd, (struct sockaddr *) &addr, sizeof(addr)) == -1) {
> >          close(fd);
> >          return -1;
> > -- 
> > 2.7.0
> > 
> > _______________________________________________
> > Xcb mailing list
> > Xcb@lists.freedesktop.org
> > http://lists.freedesktop.org/mailman/listinfo/xcb
>
> -- 
> Matthieu Herrb
_______________________________________________
Xcb mailing list
Xcb@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/xcb
[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic