]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
Drivers: hv: Specify receive buffer size using Hyper-V page size
authorHimadri Pandya <himadrispandya@gmail.com>
Thu, 25 Jul 2019 05:03:14 +0000 (05:03 +0000)
committerSasha Levin <sashal@kernel.org>
Fri, 22 Nov 2019 01:10:45 +0000 (20:10 -0500)
The recv_buffer is used to retrieve data from the VMbus ring buffer.
VMbus ring buffers are sized based on the guest page size which
Hyper-V assumes to be 4KB. But it may be different on some
architectures. So use the Hyper-V page size to allocate the
recv_buffer and set the maximum size to receive.

Signed-off-by: Himadri Pandya <himadri18.07@gmail.com>
Reviewed-by: Michael Kelley <mikelley@microsoft.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/hv/hv_fcopy.c
drivers/hv/hv_kvp.c
drivers/hv/hv_snapshot.c
drivers/hv/hv_util.c

index 7e30ae0635cc271f69011662be6c9b5ba8cee6f2..08fa4a5de64403db7acbd1d7b528c794d5a0ec8b 100644 (file)
@@ -13,6 +13,7 @@
 #include <linux/workqueue.h>
 #include <linux/hyperv.h>
 #include <linux/sched.h>
+#include <asm/hyperv-tlfs.h>
 
 #include "hyperv_vmbus.h"
 #include "hv_utils_transport.h"
@@ -234,7 +235,7 @@ void hv_fcopy_onchannelcallback(void *context)
        if (fcopy_transaction.state > HVUTIL_READY)
                return;
 
-       vmbus_recvpacket(channel, recv_buffer, PAGE_SIZE * 2, &recvlen,
+       vmbus_recvpacket(channel, recv_buffer, HV_HYP_PAGE_SIZE * 2, &recvlen,
                         &requestid);
        if (recvlen <= 0)
                return;
index 5054d1105236e15b3ec3912026fd08ae3bc99044..ae7c028dc5a8af989a643ae73c294896939236af 100644 (file)
@@ -27,6 +27,7 @@
 #include <linux/connector.h>
 #include <linux/workqueue.h>
 #include <linux/hyperv.h>
+#include <asm/hyperv-tlfs.h>
 
 #include "hyperv_vmbus.h"
 #include "hv_utils_transport.h"
@@ -661,7 +662,7 @@ void hv_kvp_onchannelcallback(void *context)
        if (kvp_transaction.state > HVUTIL_READY)
                return;
 
-       vmbus_recvpacket(channel, recv_buffer, PAGE_SIZE * 4, &recvlen,
+       vmbus_recvpacket(channel, recv_buffer, HV_HYP_PAGE_SIZE * 4, &recvlen,
                         &requestid);
 
        if (recvlen > 0) {
index 20ba95b75a946d6dbbe3b263e6aeddb046774514..03b6454268b3e8beb5a9f5fbfb5ffd118a393336 100644 (file)
@@ -12,6 +12,7 @@
 #include <linux/connector.h>
 #include <linux/workqueue.h>
 #include <linux/hyperv.h>
+#include <asm/hyperv-tlfs.h>
 
 #include "hyperv_vmbus.h"
 #include "hv_utils_transport.h"
@@ -297,7 +298,7 @@ void hv_vss_onchannelcallback(void *context)
        if (vss_transaction.state > HVUTIL_READY)
                return;
 
-       vmbus_recvpacket(channel, recv_buffer, PAGE_SIZE * 2, &recvlen,
+       vmbus_recvpacket(channel, recv_buffer, HV_HYP_PAGE_SIZE * 2, &recvlen,
                         &requestid);
 
        if (recvlen > 0) {
index e32681ee7b9f6a3119610eef0578e46a153656be..c2c08f26bd5f9c5bb965164d4d987625e17cbd59 100644 (file)
@@ -136,7 +136,7 @@ static void shutdown_onchannelcallback(void *context)
        struct icmsg_hdr *icmsghdrp;
 
        vmbus_recvpacket(channel, shut_txf_buf,
-                        PAGE_SIZE, &recvlen, &requestid);
+                        HV_HYP_PAGE_SIZE, &recvlen, &requestid);
 
        if (recvlen > 0) {
                icmsghdrp = (struct icmsg_hdr *)&shut_txf_buf[
@@ -284,7 +284,7 @@ static void timesync_onchannelcallback(void *context)
        u8 *time_txf_buf = util_timesynch.recv_buffer;
 
        vmbus_recvpacket(channel, time_txf_buf,
-                        PAGE_SIZE, &recvlen, &requestid);
+                        HV_HYP_PAGE_SIZE, &recvlen, &requestid);
 
        if (recvlen > 0) {
                icmsghdrp = (struct icmsg_hdr *)&time_txf_buf[
@@ -346,7 +346,7 @@ static void heartbeat_onchannelcallback(void *context)
        while (1) {
 
                vmbus_recvpacket(channel, hbeat_txf_buf,
-                                PAGE_SIZE, &recvlen, &requestid);
+                                HV_HYP_PAGE_SIZE, &recvlen, &requestid);
 
                if (!recvlen)
                        break;
@@ -390,7 +390,7 @@ static int util_probe(struct hv_device *dev,
                (struct hv_util_service *)dev_id->driver_data;
        int ret;
 
-       srv->recv_buffer = kmalloc(PAGE_SIZE * 4, GFP_KERNEL);
+       srv->recv_buffer = kmalloc(HV_HYP_PAGE_SIZE * 4, GFP_KERNEL);
        if (!srv->recv_buffer)
                return -ENOMEM;
        srv->channel = dev->channel;