#define NETVSC_XDP_HDRM 256
 
+#define NETVSC_MIN_OUT_MSG_SIZE (sizeof(struct vmpacket_descriptor) + \
+                                sizeof(struct nvsp_message))
+#define NETVSC_MIN_IN_MSG_SIZE sizeof(struct vmpacket_descriptor)
+
+/* Estimated requestor size:
+ * out_ring_size/min_out_msg_size + in_ring_size/min_in_msg_size
+ */
+static inline u32 netvsc_rqstor_size(unsigned long ringbytes)
+{
+       return ringbytes / NETVSC_MIN_OUT_MSG_SIZE +
+               ringbytes / NETVSC_MIN_IN_MSG_SIZE;
+}
+
 #define NETVSC_XFER_HEADER_SIZE(rng_cnt) \
                (offsetof(struct vmtransfer_page_packet_header, ranges) + \
                (rng_cnt) * sizeof(struct vmtransfer_page_range))
 
 
        vmbus_sendpacket(dev->channel, init_pkt,
                               sizeof(struct nvsp_message),
-                              (unsigned long)init_pkt,
+                              VMBUS_RQST_ID_NO_RESPONSE,
                               VM_PKT_DATA_INBAND, 0);
 }
 
                ret = vmbus_sendpacket(device->channel,
                                       revoke_packet,
                                       sizeof(struct nvsp_message),
-                                      (unsigned long)revoke_packet,
+                                      VMBUS_RQST_ID_NO_RESPONSE,
                                       VM_PKT_DATA_INBAND, 0);
                /* If the failure is because the channel is rescinded;
                 * ignore the failure since we cannot send on a rescinded
                ret = vmbus_sendpacket(device->channel,
                                       revoke_packet,
                                       sizeof(struct nvsp_message),
-                                      (unsigned long)revoke_packet,
+                                      VMBUS_RQST_ID_NO_RESPONSE,
                                       VM_PKT_DATA_INBAND, 0);
 
                /* If the failure is because the channel is rescinded;
 
        ret = vmbus_sendpacket(device->channel, init_packet,
                                sizeof(struct nvsp_message),
-                               (unsigned long)init_packet,
+                               VMBUS_RQST_ID_NO_RESPONSE,
                                VM_PKT_DATA_INBAND, 0);
 
        return ret;
        /* Send the init request */
        ret = vmbus_sendpacket(device->channel, init_packet,
                                sizeof(struct nvsp_message),
-                               (unsigned long)init_packet,
+                               VMBUS_RQST_ID_NO_RESPONSE,
                                VM_PKT_DATA_INBAND, 0);
        if (ret != 0)
                goto cleanup;
                                    const struct vmpacket_descriptor *desc,
                                    int budget)
 {
-       struct sk_buff *skb = (struct sk_buff *)(unsigned long)desc->trans_id;
        struct net_device_context *ndev_ctx = netdev_priv(ndev);
+       struct sk_buff *skb;
        u16 q_idx = 0;
        int queue_sends;
+       u64 cmd_rqst;
+
+       cmd_rqst = vmbus_request_addr(&channel->requestor, (u64)desc->trans_id);
+       if (cmd_rqst == VMBUS_RQST_ERROR) {
+               netdev_err(ndev, "Incorrect transaction id\n");
+               return;
+       }
+
+       skb = (struct sk_buff *)(unsigned long)cmd_rqst;
 
        /* Notify the layer above us */
        if (likely(skb)) {
                       netvsc_poll, NAPI_POLL_WEIGHT);
 
        /* Open the channel */
+       device->channel->rqstor_size = netvsc_rqstor_size(netvsc_ring_bytes);
        ret = vmbus_open(device->channel, netvsc_ring_bytes,
                         netvsc_ring_bytes,  NULL, 0,
                         netvsc_channel_cb, net_device->chan_table);