[Xcb] [PATCH] Increase unix socket send buffer to at least 64KB

Mark Kettenis mark.kettenis at xs4all.nl
Tue Feb 2 11:08:06 PST 2016


> Date: Sun, 24 Jan 2016 10:48:41 +0100
> From: Matthieu Herrb <matthieu at 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.
> >=20
> > Signed-off-by: Mark Kettenis <kettenis at openbsd.org>
> 
> Reviewed-by: Matthieu Herrb <matthieu at 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(+)
> >=20
> > 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 =3D sizeof(int);
> > +    int val;
> > =20
> >      if (protocol && strcmp("unix",protocol))
> >          return -1;
> > @@ -440,6 +442,11 @@ static int _xcb_open_unix(char *protocol, const char=
>  *file)
> >      fd =3D _xcb_socket(AF_UNIX, SOCK_STREAM, 0);
> >      if(fd =3D=3D -1)
> >          return -1;
> > +    if(getsockopt(fd, SOL_SOCKET, SO_SNDBUF, &val, &len) =3D=3D 0 && val=
>  < 64 * 1024)
> > +    {
> > +        val =3D 64 * 1024;
> > +        setsockopt(fd, SOL_SOCKET, SO_SNDBUF, &val, sizeof(int));
> > +    }
> >      if(connect(fd, (struct sockaddr *) &addr, sizeof(addr)) =3D=3D -1) {
> >          close(fd);
> >          return -1;
> > --=20
> > 2.7.0
> >=20
> > _______________________________________________
> > Xcb mailing list
> > Xcb at lists.freedesktop.org
> > http://lists.freedesktop.org/mailman/listinfo/xcb
> 
> --=20
> Matthieu Herrb


More information about the Xcb mailing list