usb/xhci: refactor xhci_pci_setup()
xhci_pci_setup() is split into three pieces: - xhci_gen_setup() The major remaining of xhci_pci_setup() is now containing the generic part of the xhci setup. It allocates the xhci struct, setup hcs_params? and friends, performs xhci_halt(), xhci_init and so one. It also obtains the quirks via a callback - xhci_pci_quirks() It checks the origin of the xhci core and sets core specific quirks. - xhci_pci_setup() PCI specific setup functions. Besides calling xhci_gen_setup() with xhci_pci_quirks() as an argument it performs PCI specific setup like obtaining the address of sbrn via a PCI config space. Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
22d45f01a8
commit
da3c9c4fc5
|
@ -51,11 +51,12 @@ static int xhci_pci_reinit(struct xhci_hcd *xhci, struct pci_dev *pdev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* called during probe() after chip reset completes */
|
typedef void (*xhci_get_quirks_t)(struct device *, struct xhci_hcd *);
|
||||||
static int xhci_pci_setup(struct usb_hcd *hcd)
|
|
||||||
|
static int xhci_gen_setup(struct usb_hcd *hcd, xhci_get_quirks_t get_quirks)
|
||||||
{
|
{
|
||||||
struct xhci_hcd *xhci;
|
struct xhci_hcd *xhci;
|
||||||
struct pci_dev *pdev = to_pci_dev(hcd->self.controller);
|
struct device *dev = hcd->self.controller;
|
||||||
int retval;
|
int retval;
|
||||||
u32 temp;
|
u32 temp;
|
||||||
|
|
||||||
|
@ -107,6 +108,44 @@ static int xhci_pci_setup(struct usb_hcd *hcd)
|
||||||
xhci->hcc_params = xhci_readl(xhci, &xhci->cap_regs->hcc_params);
|
xhci->hcc_params = xhci_readl(xhci, &xhci->cap_regs->hcc_params);
|
||||||
xhci_print_registers(xhci);
|
xhci_print_registers(xhci);
|
||||||
|
|
||||||
|
get_quirks(dev, xhci);
|
||||||
|
|
||||||
|
/* Make sure the HC is halted. */
|
||||||
|
retval = xhci_halt(xhci);
|
||||||
|
if (retval)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
xhci_dbg(xhci, "Resetting HCD\n");
|
||||||
|
/* Reset the internal HC memory state and registers. */
|
||||||
|
retval = xhci_reset(xhci);
|
||||||
|
if (retval)
|
||||||
|
goto error;
|
||||||
|
xhci_dbg(xhci, "Reset complete\n");
|
||||||
|
|
||||||
|
temp = xhci_readl(xhci, &xhci->cap_regs->hcc_params);
|
||||||
|
if (HCC_64BIT_ADDR(temp)) {
|
||||||
|
xhci_dbg(xhci, "Enabling 64-bit DMA addresses.\n");
|
||||||
|
dma_set_mask(hcd->self.controller, DMA_BIT_MASK(64));
|
||||||
|
} else {
|
||||||
|
dma_set_mask(hcd->self.controller, DMA_BIT_MASK(32));
|
||||||
|
}
|
||||||
|
|
||||||
|
xhci_dbg(xhci, "Calling HCD init\n");
|
||||||
|
/* Initialize HCD and host controller data structures. */
|
||||||
|
retval = xhci_init(hcd);
|
||||||
|
if (retval)
|
||||||
|
goto error;
|
||||||
|
xhci_dbg(xhci, "Called HCD init\n");
|
||||||
|
return 0;
|
||||||
|
error:
|
||||||
|
kfree(xhci);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci)
|
||||||
|
{
|
||||||
|
struct pci_dev *pdev = to_pci_dev(dev);
|
||||||
|
|
||||||
/* Look for vendor-specific quirks */
|
/* Look for vendor-specific quirks */
|
||||||
if (pdev->vendor == PCI_VENDOR_ID_FRESCO_LOGIC &&
|
if (pdev->vendor == PCI_VENDOR_ID_FRESCO_LOGIC &&
|
||||||
pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK) {
|
pdev->device == PCI_DEVICE_ID_FRESCO_LOGIC_PDK) {
|
||||||
|
@ -146,33 +185,22 @@ static int xhci_pci_setup(struct usb_hcd *hcd)
|
||||||
xhci->quirks |= XHCI_RESET_ON_RESUME;
|
xhci->quirks |= XHCI_RESET_ON_RESUME;
|
||||||
xhci_dbg(xhci, "QUIRK: Resetting on resume\n");
|
xhci_dbg(xhci, "QUIRK: Resetting on resume\n");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Make sure the HC is halted. */
|
/* called during probe() after chip reset completes */
|
||||||
retval = xhci_halt(xhci);
|
static int xhci_pci_setup(struct usb_hcd *hcd)
|
||||||
|
{
|
||||||
|
struct xhci_hcd *xhci;
|
||||||
|
struct pci_dev *pdev = to_pci_dev(hcd->self.controller);
|
||||||
|
int retval;
|
||||||
|
|
||||||
|
retval = xhci_gen_setup(hcd, xhci_pci_quirks);
|
||||||
if (retval)
|
if (retval)
|
||||||
goto error;
|
return retval;
|
||||||
|
|
||||||
xhci_dbg(xhci, "Resetting HCD\n");
|
xhci = hcd_to_xhci(hcd);
|
||||||
/* Reset the internal HC memory state and registers. */
|
if (!usb_hcd_is_primary_hcd(hcd))
|
||||||
retval = xhci_reset(xhci);
|
return 0;
|
||||||
if (retval)
|
|
||||||
goto error;
|
|
||||||
xhci_dbg(xhci, "Reset complete\n");
|
|
||||||
|
|
||||||
temp = xhci_readl(xhci, &xhci->cap_regs->hcc_params);
|
|
||||||
if (HCC_64BIT_ADDR(temp)) {
|
|
||||||
xhci_dbg(xhci, "Enabling 64-bit DMA addresses.\n");
|
|
||||||
dma_set_mask(hcd->self.controller, DMA_BIT_MASK(64));
|
|
||||||
} else {
|
|
||||||
dma_set_mask(hcd->self.controller, DMA_BIT_MASK(32));
|
|
||||||
}
|
|
||||||
|
|
||||||
xhci_dbg(xhci, "Calling HCD init\n");
|
|
||||||
/* Initialize HCD and host controller data structures. */
|
|
||||||
retval = xhci_init(hcd);
|
|
||||||
if (retval)
|
|
||||||
goto error;
|
|
||||||
xhci_dbg(xhci, "Called HCD init\n");
|
|
||||||
|
|
||||||
pci_read_config_byte(pdev, XHCI_SBRN_OFFSET, &xhci->sbrn);
|
pci_read_config_byte(pdev, XHCI_SBRN_OFFSET, &xhci->sbrn);
|
||||||
xhci_dbg(xhci, "Got SBRN %u\n", (unsigned int) xhci->sbrn);
|
xhci_dbg(xhci, "Got SBRN %u\n", (unsigned int) xhci->sbrn);
|
||||||
|
@ -182,7 +210,6 @@ static int xhci_pci_setup(struct usb_hcd *hcd)
|
||||||
if (!retval)
|
if (!retval)
|
||||||
return retval;
|
return retval;
|
||||||
|
|
||||||
error:
|
|
||||||
kfree(xhci);
|
kfree(xhci);
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue