mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-30 23:54:04 +08:00
89c3cf52c7
Use PCI standard marco dev_is_pci() instead of directly compare pci_bus_type to check whether it is pci device. Signed-off-by: Yijing Wang <wangyijing@huawei.com> Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> Acked-by: Jan Beulich <JBeulich@suse.com>
51 lines
1.1 KiB
C
51 lines
1.1 KiB
C
#include <linux/pci.h>
|
|
#include <linux/usb.h>
|
|
#include <linux/usb/ehci_def.h>
|
|
#include <linux/usb/hcd.h>
|
|
#include <asm/xen/hypercall.h>
|
|
#include <xen/interface/physdev.h>
|
|
#include <xen/xen.h>
|
|
|
|
static int xen_dbgp_op(struct usb_hcd *hcd, int op)
|
|
{
|
|
#ifdef CONFIG_PCI
|
|
const struct device *ctrlr = hcd_to_bus(hcd)->controller;
|
|
#endif
|
|
struct physdev_dbgp_op dbgp;
|
|
|
|
if (!xen_initial_domain())
|
|
return 0;
|
|
|
|
dbgp.op = op;
|
|
|
|
#ifdef CONFIG_PCI
|
|
if (dev_is_pci(ctrlr)) {
|
|
const struct pci_dev *pdev = to_pci_dev(ctrlr);
|
|
|
|
dbgp.u.pci.seg = pci_domain_nr(pdev->bus);
|
|
dbgp.u.pci.bus = pdev->bus->number;
|
|
dbgp.u.pci.devfn = pdev->devfn;
|
|
dbgp.bus = PHYSDEVOP_DBGP_BUS_PCI;
|
|
} else
|
|
#endif
|
|
dbgp.bus = PHYSDEVOP_DBGP_BUS_UNKNOWN;
|
|
|
|
return HYPERVISOR_physdev_op(PHYSDEVOP_dbgp_op, &dbgp);
|
|
}
|
|
|
|
int xen_dbgp_reset_prep(struct usb_hcd *hcd)
|
|
{
|
|
return xen_dbgp_op(hcd, PHYSDEVOP_DBGP_RESET_PREPARE);
|
|
}
|
|
|
|
int xen_dbgp_external_startup(struct usb_hcd *hcd)
|
|
{
|
|
return xen_dbgp_op(hcd, PHYSDEVOP_DBGP_RESET_DONE);
|
|
}
|
|
|
|
#ifndef CONFIG_EARLY_PRINTK_DBGP
|
|
#include <linux/export.h>
|
|
EXPORT_SYMBOL_GPL(xen_dbgp_reset_prep);
|
|
EXPORT_SYMBOL_GPL(xen_dbgp_external_startup);
|
|
#endif
|