Re: Possible bug in the communications layer ?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Attaching the patch.

----- Original Message -----
> From: "Raghavendra Gowdappa" <rgowdapp@xxxxxxxxxx>
> To: "Xavier Hernandez" <xhernandez@xxxxxxxxxx>
> Cc: "Gluster Devel" <gluster-devel@xxxxxxxxxxx>
> Sent: Friday, April 29, 2016 5:14:02 PM
> Subject: Re:  Possible bug in the communications layer ?
> 
> 
> 
> ----- Original Message -----
> > From: "Xavier Hernandez" <xhernandez@xxxxxxxxxx>
> > To: "Raghavendra Gowdappa" <rgowdapp@xxxxxxxxxx>
> > Cc: "Gluster Devel" <gluster-devel@xxxxxxxxxxx>
> > Sent: Friday, April 29, 2016 1:21:57 PM
> > Subject: Re:  Possible bug in the communications layer ?
> > 
> > Hi Raghavendra,
> > 
> > yes, the readv response contains xdata. The dict length is 38 (0x26)
> > and, at the moment of failure, rsp.xdata.xdata_len already contains 0x26.
> 
> rsp.xdata.xdata_len having 0x26 even when decoding failed indicates that the
> approach used in socket.c to get the length of xdata is correct. However, I
> cannot find any other way of xdata going into payload vector other than
> xdata_len being zero. Just to be double sure, I've a patch containing debug
> message printing xdata_len when decoding fails in socket.c. Can you please
> apply the patch, run the tests and revert back with results?
> 
> > 
> > Xavi
> > 
> > On 29/04/16 09:10, Raghavendra Gowdappa wrote:
> > >
> > >
> > > ----- Original Message -----
> > >> From: "Raghavendra Gowdappa" <rgowdapp@xxxxxxxxxx>
> > >> To: "Xavier Hernandez" <xhernandez@xxxxxxxxxx>
> > >> Cc: "Gluster Devel" <gluster-devel@xxxxxxxxxxx>
> > >> Sent: Friday, April 29, 2016 12:36:43 PM
> > >> Subject: Re:  Possible bug in the communications layer ?
> > >>
> > >>
> > >>
> > >> ----- Original Message -----
> > >>> From: "Raghavendra Gowdappa" <rgowdapp@xxxxxxxxxx>
> > >>> To: "Xavier Hernandez" <xhernandez@xxxxxxxxxx>
> > >>> Cc: "Jeff Darcy" <jdarcy@xxxxxxxxxx>, "Gluster Devel"
> > >>> <gluster-devel@xxxxxxxxxxx>
> > >>> Sent: Friday, April 29, 2016 12:07:59 PM
> > >>> Subject: Re:  Possible bug in the communications layer ?
> > >>>
> > >>>
> > >>>
> > >>> ----- Original Message -----
> > >>>> From: "Xavier Hernandez" <xhernandez@xxxxxxxxxx>
> > >>>> To: "Jeff Darcy" <jdarcy@xxxxxxxxxx>
> > >>>> Cc: "Gluster Devel" <gluster-devel@xxxxxxxxxxx>
> > >>>> Sent: Thursday, April 28, 2016 8:15:36 PM
> > >>>> Subject: Re:  Possible bug in the communications layer
> > >>>> ?
> > >>>>
> > >>>>
> > >>>>
> > >>>> Hi Jeff,
> > >>>>
> > >>>> On 28.04.2016 15:20, Jeff Darcy wrote:
> > >>>>
> > >>>>
> > >>>>
> > >>>> This happens with Gluster 3.7.11 accessed through Ganesha and gfapi.
> > >>>> The
> > >>>> volume is a distributed-disperse 4*(4+2). I'm able to reproduce the
> > >>>> problem
> > >>>> easily doing the following test: iozone -t2 -s10g -r1024k -i0 -w
> > >>>> -F/iozone{1..2}.dat echo 3 >/proc/sys/vm/drop_caches iozone -t2 -s10g
> > >>>> -r1024k -i1 -w -F/iozone{1..2}.dat The error happens soon after
> > >>>> starting
> > >>>> the
> > >>>> read test. As can be seen in the data below, client3_3_readv_cbk() is
> > >>>> processing an iovec of 116 bytes, however it should be of 154 bytes
> > >>>> (the
> > >>>> buffer in memory really seems to contain 154 bytes). The data on the
> > >>>> network
> > >>>> seems ok (at least I haven't been able to identify any problem), so
> > >>>> this
> > >>>> must be a processing error on the client side. The last field in cut
> > >>>> buffer
> > >>>> of the sequentialized data corresponds to the length of the xdata
> > >>>> field:
> > >>>> 0x26. So at least 38 more byte should be present.
> > >>>> Nice detective work, Xavi.  It would be *very* interesting to see what
> > >>>> the value of the "count" parameter is (it's unfortunately optimized
> > >>>> out).
> > >>>> I'll bet it's two, and iov[1].iov_len is 38.  I have a weak memory of
> > >>>> some problems with how this iov is put together, a couple of years
> > >>>> ago,
> > >>>> and it looks like you might have tripped over one more.
> > >>>> It seems you are right. The count is 2 and the first 38 bytes of the
> > >>>> second
> > >>>> vector contains the remaining data of xdata field.
> > >>>
> > >>> This is the bug. client3_3_readv_cbk (and for that matter all the
> > >>> actors/cbks) expects response in utmost two vectors:
> > >>> 1. Program header containing request or response. This is subjected to
> > >>> decoding/encoding. This vector should point to a buffer that contains
> > >>> the
> > >>> entire program header/response contiguously.
> > >>> 2. If the procedure returns payload (like readv response or a write
> > >>> request),
> > >>> second vector contains the buffer pointing to the entire (contiguous)
> > >>> payload. Note that this payload is raw and is not subjected to
> > >>> encoding/decoding.
> > >>>
> > >>> In your case, this _clean_ separation is broken with part of program
> > >>> header
> > >>> slipping into 2nd vector supposed to contain read data (may be because
> > >>> of
> > >>> rpc fragmentation). I think this is a bug in socket layer. I'll update
> > >>> more
> > >>> on this.
> > >>
> > >> Does your read response include xdata too? I think the code related to
> > >> reading xdata in readv response is a bit murky.
> > >>
> > >> <socket.c/__socket_read_accepted_successful_reply>
> > >>
> > >>         case SP_STATE_ACCEPTED_SUCCESS_REPLY_INIT:
> > >>                 default_read_size = xdr_sizeof ((xdrproc_t)
> > >>                 xdr_gfs3_read_rsp,
> > >>                                                 &read_rsp);
> > >>
> > >>                 proghdr_buf = frag->fragcurrent;
> > >>
> > >>                 __socket_proto_init_pending (priv, default_read_size);
> > >>
> > >>                 frag->call_body.reply.accepted_success_state
> > >>                         = SP_STATE_READING_PROC_HEADER;
> > >>
> > >>                 /* fall through */
> > >>
> > >>         case SP_STATE_READING_PROC_HEADER:
> > >>                 __socket_proto_read (priv, ret);
> > >>
> > >>>>>>> By this time we've read read response _minus_ the xdata
> > >
> > > I meant we have read "readv response header"
> > >
> > >>
> > >>                 /* there can be 'xdata' in read response, figure it out
> > >>                 */
> > >>                 xdrmem_create (&xdr, proghdr_buf, default_read_size,
> > >>                                XDR_DECODE);
> > >>
> > >>>>>>>> We created xdr stream above with "default_read_size" (this doesn't
> > >>>>>>>> include xdata)
> > >>
> > >>                 /* This will fail if there is xdata sent from server, if
> > >>                 not,
> > >>                    well and good, we don't need to worry about  */
> > >>
> > >>>>>>>> what if xdata is present and decoding failed (as length of xdr
> > >>>>>>>> stream
> > >>>>>>>> above - default_read_size - doesn't include xdata)? would we have
> > >>>>>>>> a
> > >>>>>>>> valid value in read_rsp.xdata.xdata_len? This is the part I am
> > >>>>>>>> confused about. If read_rsp.xdata.xdata_len is not correct then
> > >>>>>>>> there
> > >>>>>>>> is a possibility that xdata might not be entirely present in the
> > >>>>>>>> vector socket passes to higher layers as progheader (with part or
> > >>>>>>>> entire xdata spilling over to payload vector).
> > >>
> > >>                 xdr_gfs3_read_rsp (&xdr, &read_rsp);
> > >>
> > >>                 free (read_rsp.xdata.xdata_val);
> > >>
> > >>                 /* need to round off to proper roof (%4), as XDR packing
> > >>                 pads
> > >>                    the end of opaque object with '0' */
> > >>                 size = roof (read_rsp.xdata.xdata_len, 4);
> > >>
> > >>                 if (!size) {
> > >>                         frag->call_body.reply.accepted_success_state
> > >>                                 = SP_STATE_READ_PROC_OPAQUE;
> > >>                         goto read_proc_opaque;
> > >>                 }
> > >>
> > >> </socket.c>
> > >>
> > >> Can you please confirm whether there was an xdata in the readv response
> > >> (may
> > >> be by looking in bricks) whose decoding failed?
> > >>
> > >> regards,
> > >> Raghavendra
> > >> _______________________________________________
> > >> Gluster-devel mailing list
> > >> Gluster-devel@xxxxxxxxxxx
> > >> http://www.gluster.org/mailman/listinfo/gluster-devel
> > >>
> > 
> 
diff --git a/rpc/rpc-transport/socket/src/socket.c b/rpc/rpc-transport/socket/src/socket.c
index ac95540..bd5db40 100644
--- a/rpc/rpc-transport/socket/src/socket.c
+++ b/rpc/rpc-transport/socket/src/socket.c
@@ -26,6 +26,7 @@
 #include "xdr-nfs3.h"
 #include "rpcsvc.h"
 
+#define USE_INSECURE_OPENSSL
 /* for TCP_USER_TIMEOUT */
 #if !defined(TCP_USER_TIMEOUT) && defined(GF_LINUX_HOST_OS)
 #include <linux/tcp.h>
@@ -1568,7 +1569,18 @@ __socket_read_accepted_successful_reply (rpc_transport_t *this)
 
                 /* This will fail if there is xdata sent from server, if not,
                    well and good, we don't need to worry about  */
-                xdr_gfs3_read_rsp (&xdr, &read_rsp);
+                if (!xdr_gfs3_read_rsp (&xdr, &read_rsp)) {
+                        gf_log (this->name, GF_LOG_WARNING,
+                                "xdr_gfs3_read_rsp failed. Probably there is an"
+                                " xdata in response. read_rsp.xdata.xdata_len "
+                                "= %u", read_rsp.xdata.xdata_len);
+                } else {
+                        gf_log (this->name, GF_LOG_WARNING,
+                                "xdr_gfs3_read_rsp succeeded. Probably there is"
+                                " no xdata in response. "
+                                "read_rsp.xdata.xdata_len = %u",
+                                read_rsp.xdata.xdata_len);
+                }
 
                 free (read_rsp.xdata.xdata_val);
 
_______________________________________________
Gluster-devel mailing list
Gluster-devel@xxxxxxxxxxx
http://www.gluster.org/mailman/listinfo/gluster-devel

[Index of Archives]     [Gluster Users]     [Ceph Users]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [eCos]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux