hv_pcichild_maximum
 };
 
-enum hv_pcidev_ref_reason {
-       hv_pcidev_ref_invalid = 0,
-       hv_pcidev_ref_initial,
-       hv_pcidev_ref_by_slot,
-       hv_pcidev_ref_packet,
-       hv_pcidev_ref_pnp,
-       hv_pcidev_ref_childlist,
-       hv_pcidev_irqdata,
-       hv_pcidev_ref_max
-};
-
 struct hv_pci_dev {
        /* List protected by pci_rescan_remove_lock */
        struct list_head list_entry;
 
 static struct hv_pci_dev *get_pcichild_wslot(struct hv_pcibus_device *hbus,
                                                u32 wslot);
-static void get_pcichild(struct hv_pci_dev *hv_pcidev,
-                        enum hv_pcidev_ref_reason reason);
-static void put_pcichild(struct hv_pci_dev *hv_pcidev,
-                        enum hv_pcidev_ref_reason reason);
+
+static void get_pcichild(struct hv_pci_dev *hpdev)
+{
+       refcount_inc(&hpdev->refs);
+}
+
+static void put_pcichild(struct hv_pci_dev *hpdev)
+{
+       if (refcount_dec_and_test(&hpdev->refs))
+               kfree(hpdev);
+}
 
 static void get_hvpcibus(struct hv_pcibus_device *hv_pcibus);
 static void put_hvpcibus(struct hv_pcibus_device *hv_pcibus);
 
        _hv_pcifront_read_config(hpdev, where, size, val);
 
-       put_pcichild(hpdev, hv_pcidev_ref_by_slot);
+       put_pcichild(hpdev);
        return PCIBIOS_SUCCESSFUL;
 }
 
 
        _hv_pcifront_write_config(hpdev, where, size, val);
 
-       put_pcichild(hpdev, hv_pcidev_ref_by_slot);
+       put_pcichild(hpdev);
        return PCIBIOS_SUCCESSFUL;
 }
 
        }
 
        hv_int_desc_free(hpdev, int_desc);
-       put_pcichild(hpdev, hv_pcidev_ref_by_slot);
+       put_pcichild(hpdev);
 }
 
 static int hv_set_affinity(struct irq_data *data, const struct cpumask *dest,
        msg->address_lo = comp.int_desc.address & 0xffffffff;
        msg->data = comp.int_desc.data;
 
-       put_pcichild(hpdev, hv_pcidev_ref_by_slot);
+       put_pcichild(hpdev);
        return;
 
 free_int_desc:
        kfree(int_desc);
 drop_reference:
-       put_pcichild(hpdev, hv_pcidev_ref_by_slot);
+       put_pcichild(hpdev);
 return_null_message:
        msg->address_hi = 0;
        msg->address_lo = 0;
        complete(&completion->host_event);
 }
 
-static void get_pcichild(struct hv_pci_dev *hpdev,
-                           enum hv_pcidev_ref_reason reason)
-{
-       refcount_inc(&hpdev->refs);
-}
-
-static void put_pcichild(struct hv_pci_dev *hpdev,
-                           enum hv_pcidev_ref_reason reason)
-{
-       if (refcount_dec_and_test(&hpdev->refs))
-               kfree(hpdev);
-}
-
 /**
  * new_pcichild_device() - Create a new child device
  * @hbus:      The internal struct tracking this root PCI bus.
 
        hpdev->desc = *desc;
        refcount_set(&hpdev->refs, 1);
-       get_pcichild(hpdev, hv_pcidev_ref_childlist);
+       get_pcichild(hpdev);
        spin_lock_irqsave(&hbus->device_list_lock, flags);
 
        list_add_tail(&hpdev->list_entry, &hbus->children);
        list_for_each_entry(iter, &hbus->children, list_entry) {
                if (iter->desc.win_slot.slot == wslot) {
                        hpdev = iter;
-                       get_pcichild(hpdev, hv_pcidev_ref_by_slot);
+                       get_pcichild(hpdev);
                        break;
                }
        }
                                             list_entry);
                        if (hpdev->reported_missing) {
                                found = true;
-                               put_pcichild(hpdev, hv_pcidev_ref_childlist);
+                               put_pcichild(hpdev);
                                list_move_tail(&hpdev->list_entry, &removed);
                                break;
                        }
                hpdev = list_first_entry(&removed, struct hv_pci_dev,
                                         list_entry);
                list_del(&hpdev->list_entry);
-               put_pcichild(hpdev, hv_pcidev_ref_initial);
+               put_pcichild(hpdev);
        }
 
        switch (hbus->state) {
                         sizeof(*ejct_pkt), (unsigned long)&ctxt.pkt,
                         VM_PKT_DATA_INBAND, 0);
 
-       put_pcichild(hpdev, hv_pcidev_ref_childlist);
-       put_pcichild(hpdev, hv_pcidev_ref_pnp);
+       put_pcichild(hpdev);
+       put_pcichild(hpdev);
        put_hvpcibus(hpdev->hbus);
 }
 
 static void hv_pci_eject_device(struct hv_pci_dev *hpdev)
 {
        hpdev->state = hv_pcichild_ejecting;
-       get_pcichild(hpdev, hv_pcidev_ref_pnp);
+       get_pcichild(hpdev);
        INIT_WORK(&hpdev->wrk, hv_eject_device_work);
        get_hvpcibus(hpdev->hbus);
        queue_work(hpdev->hbus->wq, &hpdev->wrk);
                                                      dev_message->wslot.slot);
                                if (hpdev) {
                                        hv_pci_eject_device(hpdev);
-                                       put_pcichild(hpdev,
-                                                       hv_pcidev_ref_by_slot);
+                                       put_pcichild(hpdev);
                                }
                                break;
 
                                PCI_RESOURCES_ASSIGNED2;
                        res_assigned2->wslot.slot = hpdev->desc.win_slot.slot;
                }
-               put_pcichild(hpdev, hv_pcidev_ref_by_slot);
+               put_pcichild(hpdev);
 
                ret = vmbus_sendpacket(hdev->channel, &pkt->message,
                                size_res, (unsigned long)pkt,
                pkt.message_type.type = PCI_RESOURCES_RELEASED;
                pkt.wslot.slot = hpdev->desc.win_slot.slot;
 
-               put_pcichild(hpdev, hv_pcidev_ref_by_slot);
+               put_pcichild(hpdev);
 
                ret = vmbus_sendpacket(hdev->channel, &pkt, sizeof(pkt), 0,
                                       VM_PKT_DATA_INBAND, 0);