19fa5780bSJan Beulich #include <linux/pci.h> 29fa5780bSJan Beulich #include <linux/usb.h> 39fa5780bSJan Beulich #include <linux/usb/ehci_def.h> 49fa5780bSJan Beulich #include <linux/usb/hcd.h> 59fa5780bSJan Beulich #include <asm/xen/hypercall.h> 69fa5780bSJan Beulich #include <xen/interface/physdev.h> 79fa5780bSJan Beulich #include <xen/xen.h> 89fa5780bSJan Beulich 99fa5780bSJan Beulich static int xen_dbgp_op(struct usb_hcd *hcd, int op) 109fa5780bSJan Beulich { 11801e7fb7SIan Campbell #ifdef CONFIG_PCI 129fa5780bSJan Beulich const struct device *ctrlr = hcd_to_bus(hcd)->controller; 13801e7fb7SIan Campbell #endif 149fa5780bSJan Beulich struct physdev_dbgp_op dbgp; 159fa5780bSJan Beulich 169fa5780bSJan Beulich if (!xen_initial_domain()) 179fa5780bSJan Beulich return 0; 189fa5780bSJan Beulich 199fa5780bSJan Beulich dbgp.op = op; 209fa5780bSJan Beulich 219fa5780bSJan Beulich #ifdef CONFIG_PCI 22*89c3cf52SYijing Wang if (dev_is_pci(ctrlr)) { 239fa5780bSJan Beulich const struct pci_dev *pdev = to_pci_dev(ctrlr); 249fa5780bSJan Beulich 259fa5780bSJan Beulich dbgp.u.pci.seg = pci_domain_nr(pdev->bus); 269fa5780bSJan Beulich dbgp.u.pci.bus = pdev->bus->number; 279fa5780bSJan Beulich dbgp.u.pci.devfn = pdev->devfn; 289fa5780bSJan Beulich dbgp.bus = PHYSDEVOP_DBGP_BUS_PCI; 299fa5780bSJan Beulich } else 309fa5780bSJan Beulich #endif 319fa5780bSJan Beulich dbgp.bus = PHYSDEVOP_DBGP_BUS_UNKNOWN; 329fa5780bSJan Beulich 339fa5780bSJan Beulich return HYPERVISOR_physdev_op(PHYSDEVOP_dbgp_op, &dbgp); 349fa5780bSJan Beulich } 359fa5780bSJan Beulich 369fa5780bSJan Beulich int xen_dbgp_reset_prep(struct usb_hcd *hcd) 379fa5780bSJan Beulich { 389fa5780bSJan Beulich return xen_dbgp_op(hcd, PHYSDEVOP_DBGP_RESET_PREPARE); 399fa5780bSJan Beulich } 409fa5780bSJan Beulich 419fa5780bSJan Beulich int xen_dbgp_external_startup(struct usb_hcd *hcd) 429fa5780bSJan Beulich { 439fa5780bSJan Beulich return xen_dbgp_op(hcd, PHYSDEVOP_DBGP_RESET_DONE); 449fa5780bSJan Beulich } 459fa5780bSJan Beulich 469fa5780bSJan Beulich #ifndef CONFIG_EARLY_PRINTK_DBGP 479fa5780bSJan Beulich #include <linux/export.h> 489fa5780bSJan Beulich EXPORT_SYMBOL_GPL(xen_dbgp_reset_prep); 499fa5780bSJan Beulich EXPORT_SYMBOL_GPL(xen_dbgp_external_startup); 509fa5780bSJan Beulich #endif 51