Blame SOURCES/kvm-io-Allow-empty-websocket-payload.patch

4a2fec
From 56192448a2221f518f3e959f511e1244100de600 Mon Sep 17 00:00:00 2001
4a2fec
From: "Daniel P. Berrange" <berrange@redhat.com>
4a2fec
Date: Wed, 20 Dec 2017 17:56:49 +0100
4a2fec
Subject: [PATCH 09/42] io: Allow empty websocket payload
4a2fec
4a2fec
RH-Author: Daniel P. Berrange <berrange@redhat.com>
4a2fec
Message-id: <20171220175702.29663-8-berrange@redhat.com>
4a2fec
Patchwork-id: 78453
4a2fec
O-Subject: [RHV-7.5 qemu-kvm-rhev PATCH v2 07/20] io: Allow empty websocket payload
4a2fec
Bugzilla: 1518649
4a2fec
RH-Acked-by: John Snow <jsnow@redhat.com>
4a2fec
RH-Acked-by: Jeffrey Cody <jcody@redhat.com>
4a2fec
RH-Acked-by: Miroslav Rezanina <mrezanin@redhat.com>
4a2fec
4a2fec
From: Brandon Carpenter <brandon.carpenter@cypherpath.com>
4a2fec
4a2fec
Some browsers send pings/pongs with no payload, so allow empty payloads
4a2fec
instead of closing the connection.
4a2fec
4a2fec
Signed-off-by: Brandon Carpenter <brandon.carpenter@cypherpath.com>
4a2fec
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
4a2fec
(cherry picked from commit 3a29640e2cbae9d47b89ffaf98ed358920eb6797)
4a2fec
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
4a2fec
---
4a2fec
 io/channel-websock.c | 62 +++++++++++++++++++++++++---------------------------
4a2fec
 1 file changed, 30 insertions(+), 32 deletions(-)
4a2fec
4a2fec
diff --git a/io/channel-websock.c b/io/channel-websock.c
4a2fec
index 909d636..b19b5d9 100644
4a2fec
--- a/io/channel-websock.c
4a2fec
+++ b/io/channel-websock.c
4a2fec
@@ -697,44 +697,42 @@ static int qio_channel_websock_decode_payload(QIOChannelWebsock *ioc,
4a2fec
                                               Error **errp)
4a2fec
 {
4a2fec
     size_t i;
4a2fec
-    size_t payload_len;
4a2fec
+    size_t payload_len = 0;
4a2fec
     uint32_t *payload32;
4a2fec
 
4a2fec
-    if (!ioc->payload_remain) {
4a2fec
-        error_setg(errp,
4a2fec
-                   "Decoding payload but no bytes of payload remain");
4a2fec
-        return -1;
4a2fec
-    }
4a2fec
-
4a2fec
-    /* If we aren't at the end of the payload, then drop
4a2fec
-     * off the last bytes, so we're always multiple of 4
4a2fec
-     * for purpose of unmasking, except at end of payload
4a2fec
-     */
4a2fec
-    if (ioc->encinput.offset < ioc->payload_remain) {
4a2fec
-        payload_len = ioc->encinput.offset - (ioc->encinput.offset % 4);
4a2fec
-    } else {
4a2fec
-        payload_len = ioc->payload_remain;
4a2fec
-    }
4a2fec
-    if (payload_len == 0) {
4a2fec
-        return QIO_CHANNEL_ERR_BLOCK;
4a2fec
-    }
4a2fec
+    if (ioc->payload_remain) {
4a2fec
+        /* If we aren't at the end of the payload, then drop
4a2fec
+         * off the last bytes, so we're always multiple of 4
4a2fec
+         * for purpose of unmasking, except at end of payload
4a2fec
+         */
4a2fec
+        if (ioc->encinput.offset < ioc->payload_remain) {
4a2fec
+            payload_len = ioc->encinput.offset - (ioc->encinput.offset % 4);
4a2fec
+        } else {
4a2fec
+            payload_len = ioc->payload_remain;
4a2fec
+        }
4a2fec
+        if (payload_len == 0) {
4a2fec
+            return QIO_CHANNEL_ERR_BLOCK;
4a2fec
+        }
4a2fec
 
4a2fec
-    ioc->payload_remain -= payload_len;
4a2fec
+        ioc->payload_remain -= payload_len;
4a2fec
 
4a2fec
-    /* unmask frame */
4a2fec
-    /* process 1 frame (32 bit op) */
4a2fec
-    payload32 = (uint32_t *)ioc->encinput.buffer;
4a2fec
-    for (i = 0; i < payload_len / 4; i++) {
4a2fec
-        payload32[i] ^= ioc->mask.u;
4a2fec
-    }
4a2fec
-    /* process the remaining bytes (if any) */
4a2fec
-    for (i *= 4; i < payload_len; i++) {
4a2fec
-        ioc->encinput.buffer[i] ^= ioc->mask.c[i % 4];
4a2fec
+        /* unmask frame */
4a2fec
+        /* process 1 frame (32 bit op) */
4a2fec
+        payload32 = (uint32_t *)ioc->encinput.buffer;
4a2fec
+        for (i = 0; i < payload_len / 4; i++) {
4a2fec
+            payload32[i] ^= ioc->mask.u;
4a2fec
+        }
4a2fec
+        /* process the remaining bytes (if any) */
4a2fec
+        for (i *= 4; i < payload_len; i++) {
4a2fec
+            ioc->encinput.buffer[i] ^= ioc->mask.c[i % 4];
4a2fec
+        }
4a2fec
     }
4a2fec
 
4a2fec
-    buffer_reserve(&ioc->rawinput, payload_len);
4a2fec
-    buffer_append(&ioc->rawinput, ioc->encinput.buffer, payload_len);
4a2fec
-    buffer_advance(&ioc->encinput, payload_len);
4a2fec
+    if (payload_len) {
4a2fec
+        buffer_reserve(&ioc->rawinput, payload_len);
4a2fec
+        buffer_append(&ioc->rawinput, ioc->encinput.buffer, payload_len);
4a2fec
+        buffer_advance(&ioc->encinput, payload_len);
4a2fec
+    }
4a2fec
     return 0;
4a2fec
 }
4a2fec
 
4a2fec
-- 
4a2fec
1.8.3.1
4a2fec