1. 01 6月, 2015 1 次提交
  2. 25 5月, 2015 1 次提交
  3. 03 4月, 2015 2 次提交
  4. 25 3月, 2015 1 次提交
  5. 02 3月, 2015 3 次提交
    • K
      Drivers: hv: vmbus: Get rid of some unnecessary messages · 37f492ce
      K. Y. Srinivasan 提交于
      Currently we log messages when either we are not able to map an ID to a
      channel or when the channel does not have a callback associated
      (in the channel interrupt handling path). These messages don't add
      any value, get rid of them.
      Signed-off-by: NK. Y. Srinivasan <kys@microsoft.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      37f492ce
    • D
      hv: vmbus_post_msg: retry the hypercall on some transient errors · 89f9f679
      Dexuan Cui 提交于
      I got HV_STATUS_INVALID_CONNECTION_ID on Hyper-V 2008 R2 when keeping running
      "rmmod hv_netvsc; modprobe hv_netvsc; rmmod hv_utils; modprobe hv_utils"
      in a Linux guest. Looks the host has some kind of throttling mechanism if
      some kinds of hypercalls are sent too frequently.
      Without the patch, the driver can occasionally fail to load.
      
      Also let's retry HV_STATUS_INSUFFICIENT_MEMORY, though we didn't get it
      before.
      
      Removed 'case -ENOMEM', since the hypervisor doesn't return this.
      
      CC: "K. Y. Srinivasan" <kys@microsoft.com>
      Reviewed-by: NJason Wang <jasowang@redhat.com>
      Signed-off-by: NDexuan Cui <decui@microsoft.com>
      Signed-off-by: NK. Y. Srinivasan <kys@microsoft.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      89f9f679
    • V
      Drivers: hv: vmbus: teardown hv_vmbus_con workqueue and vmbus_connection pages on shutdown · 09a19628
      Vitaly Kuznetsov 提交于
      We need to destroy hv_vmbus_con on module shutdown, otherwise the following
      crash is sometimes observed:
      
      [   76.569845] hv_vmbus: Hyper-V Host Build:9600-6.3-17-0.17039; Vmbus version:3.0
      [   82.598859] BUG: unable to handle kernel paging request at ffffffffa0003480
      [   82.599287] IP: [<ffffffffa0003480>] 0xffffffffa0003480
      [   82.599287] PGD 1f34067 PUD 1f35063 PMD 3f72d067 PTE 0
      [   82.599287] Oops: 0010 [#1] SMP
      [   82.599287] Modules linked in: [last unloaded: hv_vmbus]
      [   82.599287] CPU: 0 PID: 26 Comm: kworker/0:1 Not tainted 3.19.0-rc5_bug923184+ #488
      [   82.599287] Hardware name: Microsoft Corporation Virtual Machine/Virtual Machine, BIOS Hyper-V UEFI Release v1.0 11/26/2012
      [   82.599287] Workqueue: hv_vmbus_con 0xffffffffa0003480
      [   82.599287] task: ffff88007b6ddfa0 ti: ffff88007f8f8000 task.ti: ffff88007f8f8000
      [   82.599287] RIP: 0010:[<ffffffffa0003480>]  [<ffffffffa0003480>] 0xffffffffa0003480
      [   82.599287] RSP: 0018:ffff88007f8fbe00  EFLAGS: 00010202
      ...
      
      To avoid memory leaks we need to free monitor_pages and int_page for
      vmbus_connection. Implement vmbus_disconnect() function by separating cleanup
      path from vmbus_connect().
      
      As we use hv_vmbus_con to release channels (see free_channel() in channel_mgmt.c)
      we need to make sure the work was done before we remove the queue, do that with
      drain_workqueue(). We also need to avoid handling messages  which can (potentially)
      create new channels, so set vmbus_connection.conn_state = DISCONNECTED at the very
      beginning of vmbus_exit() and check for that in vmbus_onmessage_work().
      Signed-off-by: NVitaly Kuznetsov <vkuznets@redhat.com>
      Signed-off-by: NK. Y. Srinivasan <kys@microsoft.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      09a19628
  6. 12 1月, 2015 1 次提交
  7. 24 9月, 2014 1 次提交
  8. 10 7月, 2014 1 次提交
  9. 29 5月, 2014 1 次提交
  10. 04 5月, 2014 2 次提交
  11. 17 4月, 2014 1 次提交
  12. 08 2月, 2014 2 次提交
  13. 27 9月, 2013 2 次提交
  14. 31 8月, 2013 1 次提交
  15. 04 6月, 2013 1 次提交
    • K
      Drivers: hv: vmbus: Implement multi-channel support · e68d2971
      K. Y. Srinivasan 提交于
      Starting with Win8, the host supports multiple sub-channels for a given
      device. As in the past, the initial channel offer specifies the device and
      is associated with both the type and the instance GUIDs. For performance
      critical devices, the host may support multiple sub-channels. The sub-channels
      share the same type and instance GUID as the primary channel. The number of
      sub-channels offerrred to the guest depends on the number of virtual CPUs
      assigned to the guest. The guest can request the creation of these sub-channels
      and once created and opened, the guest can distribute the traffic across all
      the channels (the primary and the sub-channels). A request sent on a sub-channel
      will have the response delivered on the same sub-channel.
      
      At channel (sub-channel) creation we bind the channel interrupt to a CPU and
      with this sub-channel support we will be able to spread the interrupt load
      of a given device across all available CPUs.
      Signed-off-by: NK. Y. Srinivasan <kys@microsoft.com>
      Reviewed-by: NHaiyang Zhang <haiyangz@microsoft.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      e68d2971
  16. 18 1月, 2013 10 次提交
  17. 11 10月, 2011 2 次提交
  18. 07 9月, 2011 1 次提交
  19. 30 8月, 2011 4 次提交
  20. 26 8月, 2011 2 次提交