diff mbox

[v2,4/6] drivers:hv: Export a function that maps Linux proc num onto Hyper-V proc num

Message ID 1434387999-1885-5-git-send-email-jakeo@microsoft.com
State Changes Requested
Headers show

Commit Message

Jake Oshins June 15, 2015, 5:06 p.m. UTC
From: Jake Oshins <jakeo@microsoft.com>

This patch exports a function which maps Linux processor number onto Hyper-V
virtual processor number.  This is necessary in order to map message-
signaled interrupts (MSIs) into a VM, as the hypervisor needs to know the
right target VP.

Signed-off-by: Jake Oshins <jakeo@microsoft.com>
---
 drivers/hv/vmbus_drv.c | 16 ++++++++++++++++
 include/linux/hyperv.h |  2 ++
 2 files changed, 18 insertions(+)

Comments

gregkh@linuxfoundation.org June 15, 2015, 7:52 p.m. UTC | #1
On Mon, Jun 15, 2015 at 05:06:37PM +0000, jakeo@microsoft.com wrote:
> From: Jake Oshins <jakeo@microsoft.com>
> 
> This patch exports a function which maps Linux processor number onto Hyper-V
> virtual processor number.  This is necessary in order to map message-
> signaled interrupts (MSIs) into a VM, as the hypervisor needs to know the
> right target VP.
> 
> Signed-off-by: Jake Oshins <jakeo@microsoft.com>
> ---
>  drivers/hv/vmbus_drv.c | 16 ++++++++++++++++
>  include/linux/hyperv.h |  2 ++
>  2 files changed, 18 insertions(+)
> 
> diff --git a/drivers/hv/vmbus_drv.c b/drivers/hv/vmbus_drv.c
> index 067a469..65e4eb6 100644
> --- a/drivers/hv/vmbus_drv.c
> +++ b/drivers/hv/vmbus_drv.c
> @@ -1158,6 +1158,22 @@ int vmbus_allocate_mmio(struct resource **new, struct hv_device *device_obj,
>  }
>  EXPORT_SYMBOL_GPL(vmbus_allocate_mmio);
>  
> +/**
> + * This function returns the mapping between the Linux processor
> + * number and
> + * the hypervisor's virtual processor number, useful in making
> + * hypercalls and such that talk about specific processors.
> + *
> + * @param procnum - in Linux terms

What kind of comment structure is this?  It's not kernel doc :(

And "procnum" sounds like "process number", why not "cpu_number"?

--
To unsubscribe from this list: send the line "unsubscribe linux-pci" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Jake Oshins June 15, 2015, 9:23 p.m. UTC | #2
> -----Original Message-----
> From: Greg KH [mailto:gregkh@linuxfoundation.org]
> Sent: Monday, June 15, 2015 12:52 PM
> To: Jake Oshins
> Cc: KY Srinivasan; linux-kernel@vger.kernel.org;
> devel@linuxdriverproject.org; olaf@aepfle.de; apw@canonical.com;
> vkuznets@redhat.com; bhelgaas@google.com; linux-pci@vger.kernel.org;
> pebolle@tiscali.nl; Haiyang Zhang; Mike Ebersol
> Subject: Re: [PATCH v2 4/6] drivers:hv: Export a function that maps Linux
> proc num onto Hyper-V proc num
> 
> > +/**
> > + * This function returns the mapping between the Linux processor
> > + * number and
> > + * the hypervisor's virtual processor number, useful in making
> > + * hypercalls and such that talk about specific processors.
> > + *
> > + * @param procnum - in Linux terms
> 
> What kind of comment structure is this?  It's not kernel doc :(
> 
> And "procnum" sounds like "process number", why not "cpu_number"?

Thanks.  I'll wait a little while to see if any other feedback comes in and then I'll fix these and resend.

-- Jake Oshins

--
To unsubscribe from this list: send the line "unsubscribe linux-pci" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/hv/vmbus_drv.c b/drivers/hv/vmbus_drv.c
index 067a469..65e4eb6 100644
--- a/drivers/hv/vmbus_drv.c
+++ b/drivers/hv/vmbus_drv.c
@@ -1158,6 +1158,22 @@  int vmbus_allocate_mmio(struct resource **new, struct hv_device *device_obj,
 }
 EXPORT_SYMBOL_GPL(vmbus_allocate_mmio);
 
+/**
+ * This function returns the mapping between the Linux processor
+ * number and
+ * the hypervisor's virtual processor number, useful in making
+ * hypercalls and such that talk about specific processors.
+ *
+ * @param procnum - in Linux terms
+ *
+ * @return int - in Hyper-V terms
+ */
+int vmbus_procnum_to_vpnum(int procnum)
+{
+	return hv_context.vp_index[procnum];
+}
+EXPORT_SYMBOL_GPL(vmbus_procnum_to_vpnum);
+
 static int vmbus_acpi_add(struct acpi_device *device)
 {
 	acpi_status result;
diff --git a/include/linux/hyperv.h b/include/linux/hyperv.h
index ffd98d7..6fec42d 100644
--- a/include/linux/hyperv.h
+++ b/include/linux/hyperv.h
@@ -987,6 +987,8 @@  int vmbus_allocate_mmio(struct resource **new, struct hv_device *device_obj,
 			resource_size_t size, resource_size_t align,
 			bool fb_overlap_ok);
 
+int vmbus_procnum_to_vpnum(int procnum);
+
 /**
  * VMBUS_DEVICE - macro used to describe a specific hyperv vmbus device
  *