Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 248906
b: refs/heads/master
c: 04677c0
h: refs/heads/master
v: v3
  • Loading branch information
K. Y. Srinivasan authored and Greg Kroah-Hartman committed Apr 5, 2011
1 parent 4924d0c commit 8fc782f
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 18 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 52e5c1cec89879bd64eb4e681b4cb1525eabb472
refs/heads/master: 04677c0862677430f8bf5bbc356bd44bcba48f1f
32 changes: 15 additions & 17 deletions trunk/drivers/staging/hv/vmbus_drv.c
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@
struct pci_dev *hv_pci_dev;

/* Main vmbus driver data structure */
struct vmbus_driver_context {
struct hv_bus {
struct bus_type bus;
struct tasklet_struct msg_dpc;
struct tasklet_struct event_dpc;
Expand Down Expand Up @@ -99,7 +99,7 @@ static struct device_attribute vmbus_device_attrs[] = {
};

/* The one and only one */
static struct vmbus_driver_context vmbus_drv = {
static struct hv_bus hv_bus = {
.bus.name = "vmbus",
.bus.match = vmbus_match,
.bus.shutdown = vmbus_shutdown,
Expand Down Expand Up @@ -368,7 +368,6 @@ static ssize_t vmbus_show_device_attr(struct device *dev,
*/
static int vmbus_bus_init(struct pci_dev *pdev)
{
struct vmbus_driver_context *vmbus_drv_ctx = &vmbus_drv;
int ret;
unsigned int vector;

Expand All @@ -393,16 +392,16 @@ static int vmbus_bus_init(struct pci_dev *pdev)
}


vmbus_drv_ctx->bus.name = driver_name;
hv_bus.bus.name = driver_name;

/* Initialize the bus context */
tasklet_init(&vmbus_drv_ctx->msg_dpc, vmbus_on_msg_dpc,
tasklet_init(&hv_bus.msg_dpc, vmbus_on_msg_dpc,
(unsigned long)NULL);
tasklet_init(&vmbus_drv_ctx->event_dpc, vmbus_on_event,
tasklet_init(&hv_bus.event_dpc, vmbus_on_event,
(unsigned long)NULL);

/* Now, register the bus with LDM */
ret = bus_register(&vmbus_drv_ctx->bus);
ret = bus_register(&hv_bus.bus);
if (ret) {
ret = -1;
goto cleanup;
Expand All @@ -417,7 +416,7 @@ static int vmbus_bus_init(struct pci_dev *pdev)
DPRINT_ERR(VMBUS_DRV, "ERROR - Unable to request IRQ %d",
pdev->irq);

bus_unregister(&vmbus_drv_ctx->bus);
bus_unregister(&hv_bus.bus);

ret = -1;
goto cleanup;
Expand All @@ -435,7 +434,7 @@ static int vmbus_bus_init(struct pci_dev *pdev)
ret = vmbus_connect();
if (ret) {
free_irq(pdev->irq, pdev);
bus_unregister(&vmbus_drv_ctx->bus);
bus_unregister(&hv_bus.bus);
goto cleanup;
}

Expand All @@ -454,7 +453,6 @@ static int vmbus_bus_init(struct pci_dev *pdev)
*/
static void vmbus_bus_exit(void)
{
struct vmbus_driver_context *vmbus_drv_ctx = &vmbus_drv;


vmbus_release_unattached_channels();
Expand All @@ -463,12 +461,12 @@ static void vmbus_bus_exit(void)

hv_cleanup();

bus_unregister(&vmbus_drv_ctx->bus);
bus_unregister(&hv_bus.bus);

free_irq(hv_pci_dev->irq, hv_pci_dev);

tasklet_kill(&vmbus_drv_ctx->msg_dpc);
tasklet_kill(&vmbus_drv_ctx->event_dpc);
tasklet_kill(&hv_bus.msg_dpc);
tasklet_kill(&hv_bus.event_dpc);
}


Expand All @@ -491,7 +489,7 @@ int vmbus_child_driver_register(struct device_driver *drv)
drv, drv->name);

/* The child driver on this vmbus */
drv->bus = &vmbus_drv.bus;
drv->bus = &hv_bus.bus;

ret = driver_register(drv);

Expand Down Expand Up @@ -585,7 +583,7 @@ int vmbus_child_device_register(struct hv_device *child_device_obj)
atomic_inc_return(&device_num));

/* The new device belongs to this bus */
child_device_obj->device.bus = &vmbus_drv.bus; /* device->dev.bus; */
child_device_obj->device.bus = &hv_bus.bus; /* device->dev.bus; */
child_device_obj->device.parent = &hv_pci_dev->dev;
child_device_obj->device.release = vmbus_device_release;

Expand Down Expand Up @@ -853,10 +851,10 @@ static irqreturn_t vmbus_isr(int irq, void *dev_id)
/* Schedules a dpc if necessary */
if (ret > 0) {
if (test_bit(0, (unsigned long *)&ret))
tasklet_schedule(&vmbus_drv.msg_dpc);
tasklet_schedule(&hv_bus.msg_dpc);

if (test_bit(1, (unsigned long *)&ret))
tasklet_schedule(&vmbus_drv.event_dpc);
tasklet_schedule(&hv_bus.event_dpc);

return IRQ_HANDLED;
} else {
Expand Down

0 comments on commit 8fc782f

Please sign in to comment.