|
@@ -32,6 +32,9 @@
|
|
|
|
|
|
#include "hyperv_vmbus.h"
|
|
|
|
|
|
+static void init_vp_index(struct vmbus_channel *channel,
|
|
|
+ const uuid_le *type_guid);
|
|
|
+
|
|
|
/**
|
|
|
* vmbus_prep_negotiate_resp() - Create default response for Hyper-V Negotiate message
|
|
|
* @icmsghdrp: Pointer to msg header structure
|
|
@@ -272,6 +275,8 @@ static void vmbus_process_offer(struct vmbus_channel *newchannel)
|
|
|
goto err_free_chan;
|
|
|
}
|
|
|
|
|
|
+ init_vp_index(newchannel, &newchannel->offermsg.offer.if_type);
|
|
|
+
|
|
|
if (newchannel->target_cpu != get_cpu()) {
|
|
|
put_cpu();
|
|
|
smp_call_function_single(newchannel->target_cpu,
|
|
@@ -476,8 +481,6 @@ static void vmbus_onoffer(struct vmbus_channel_message_header *hdr)
|
|
|
offer->connection_id;
|
|
|
}
|
|
|
|
|
|
- init_vp_index(newchannel, &offer->offer.if_type);
|
|
|
-
|
|
|
memcpy(&newchannel->offermsg, offer,
|
|
|
sizeof(struct vmbus_channel_offer_channel));
|
|
|
newchannel->monitor_grp = (u8)offer->monitorid / 32;
|