union hv_synic_event_flags *event;
        bool handled = false;
 
-       page_addr = hv_context.synic_message_page[cpu];
-       msg = (struct hv_message *)page_addr + VMBUS_MESSAGE_SINT;
-
-       /* Check if there are actual msgs to be process */
-       if (msg->header.message_type != HVMSG_NONE) {
-               handled = true;
-               tasklet_schedule(&msg_dpc);
-       }
+       /*
+        * Check for events before checking for messages. This is the order
+        * in which events and messages are checked in Windows guests on
+        * Hyper-V, and the Windows team suggested we do the same.
+        */
 
        page_addr = hv_context.synic_event_page[cpu];
        event = (union hv_synic_event_flags *)page_addr + VMBUS_MESSAGE_SINT;
                tasklet_schedule(&event_dpc);
        }
 
+       page_addr = hv_context.synic_message_page[cpu];
+       msg = (struct hv_message *)page_addr + VMBUS_MESSAGE_SINT;
+
+       /* Check if there are actual msgs to be processed */
+       if (msg->header.message_type != HVMSG_NONE) {
+               handled = true;
+               tasklet_schedule(&msg_dpc);
+       }
+
        if (handled)
                return IRQ_HANDLED;
        else