1*457c8996SThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only 29fa5780bSJan Beulich #include <linux/pci.h> 39fa5780bSJan Beulich #include <linux/usb.h> 49fa5780bSJan Beulich #include <linux/usb/ehci_def.h> 59fa5780bSJan Beulich #include <linux/usb/hcd.h> 69fa5780bSJan Beulich #include <asm/xen/hypercall.h> 79fa5780bSJan Beulich #include <xen/interface/physdev.h> 89fa5780bSJan Beulich #include <xen/xen.h> 99fa5780bSJan Beulich xen_dbgp_op(struct usb_hcd * hcd,int op)109fa5780bSJan Beulichstatic int xen_dbgp_op(struct usb_hcd *hcd, int op) 119fa5780bSJan Beulich { 12801e7fb7SIan Campbell #ifdef CONFIG_PCI 139fa5780bSJan Beulich const struct device *ctrlr = hcd_to_bus(hcd)->controller; 14801e7fb7SIan Campbell #endif 159fa5780bSJan Beulich struct physdev_dbgp_op dbgp; 169fa5780bSJan Beulich 179fa5780bSJan Beulich if (!xen_initial_domain()) 189fa5780bSJan Beulich return 0; 199fa5780bSJan Beulich 209fa5780bSJan Beulich dbgp.op = op; 219fa5780bSJan Beulich 229fa5780bSJan Beulich #ifdef CONFIG_PCI 2389c3cf52SYijing Wang if (dev_is_pci(ctrlr)) { 249fa5780bSJan Beulich const struct pci_dev *pdev = to_pci_dev(ctrlr); 259fa5780bSJan Beulich 269fa5780bSJan Beulich dbgp.u.pci.seg = pci_domain_nr(pdev->bus); 279fa5780bSJan Beulich dbgp.u.pci.bus = pdev->bus->number; 289fa5780bSJan Beulich dbgp.u.pci.devfn = pdev->devfn; 299fa5780bSJan Beulich dbgp.bus = PHYSDEVOP_DBGP_BUS_PCI; 309fa5780bSJan Beulich } else 319fa5780bSJan Beulich #endif 329fa5780bSJan Beulich dbgp.bus = PHYSDEVOP_DBGP_BUS_UNKNOWN; 339fa5780bSJan Beulich 349fa5780bSJan Beulich return HYPERVISOR_physdev_op(PHYSDEVOP_dbgp_op, &dbgp); 359fa5780bSJan Beulich } 369fa5780bSJan Beulich xen_dbgp_reset_prep(struct usb_hcd * hcd)379fa5780bSJan Beulichint xen_dbgp_reset_prep(struct usb_hcd *hcd) 389fa5780bSJan Beulich { 399fa5780bSJan Beulich return xen_dbgp_op(hcd, PHYSDEVOP_DBGP_RESET_PREPARE); 409fa5780bSJan Beulich } 419fa5780bSJan Beulich xen_dbgp_external_startup(struct usb_hcd * hcd)429fa5780bSJan Beulichint xen_dbgp_external_startup(struct usb_hcd *hcd) 439fa5780bSJan Beulich { 449fa5780bSJan Beulich return xen_dbgp_op(hcd, PHYSDEVOP_DBGP_RESET_DONE); 459fa5780bSJan Beulich } 469fa5780bSJan Beulich 479fa5780bSJan Beulich #ifndef CONFIG_EARLY_PRINTK_DBGP 489fa5780bSJan Beulich #include <linux/export.h> 499fa5780bSJan Beulich EXPORT_SYMBOL_GPL(xen_dbgp_reset_prep); 509fa5780bSJan Beulich EXPORT_SYMBOL_GPL(xen_dbgp_external_startup); 519fa5780bSJan Beulich #endif 52