1
0
mirror of git://projects.qi-hardware.com/openwrt-xburst.git synced 2025-01-26 04:31:07 +02:00

brcm47xx: update usb driver to the version send for mainline kernel integartion

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@31089 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
hauke 2012-03-27 15:38:56 +00:00
parent ec28fb9573
commit 93a0a2c288
8 changed files with 215 additions and 267 deletions

View File

@ -1,48 +0,0 @@
From d85bba4eb399a8273aabaef5c21c89820d7a0514 Mon Sep 17 00:00:00 2001
From: Hauke Mehrtens <hauke@hauke-m.de>
Date: Thu, 9 Feb 2012 23:14:57 +0100
Subject: [PATCH 180/186] USB: HCI: add struct for ehci and ohci platform
driver
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
---
include/linux/usb/hci_driver.h | 32 ++++++++++++++++++++++++++++++++
1 files changed, 32 insertions(+), 0 deletions(-)
create mode 100644 include/linux/usb/hci_driver.h
--- /dev/null
+++ b/include/linux/usb/hci_driver.h
@@ -0,0 +1,32 @@
+/*
+ * Copyright (C) 2012 Hauke Mehrtens <hauke@hauke-m.de>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#ifndef __USB_CORE_HCI_PDRIVER_H
+#define __USB_CORE_HCI_PDRIVER_H
+
+#define USB_HCI_PDATA_PORT_POWER_SET (1 << 0)
+#define USB_HCI_PDATA_HAS_TT_SET (1 << 1)
+
+struct usb_hci_pdata {
+ int flags;
+ int caps_offset;
+ unsigned has_tt:1;
+ unsigned power_set_is_on:1;
+};
+
+#endif /* __USB_CORE_HCI_PDRIVER_H */

View File

@ -1,21 +1,3 @@
From 2232a2ab6015496fecdfad68a9d6794312a9b2f2 Mon Sep 17 00:00:00 2001
From: Hauke Mehrtens <hauke@hauke-m.de>
Date: Sat, 26 Nov 2011 21:20:54 +0100
Subject: [PATCH 181/186] USB: OHCI: Add a generic platform device driver
This adds a generic driver for platform devices. It works like the PCI
driver and is based on it. This is for devices which do not have an own
bus but their OHCI controller works like a PCI controller. It will be
used for the Broadcom bcma and ssb USB OHCI controller.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
---
drivers/usb/host/Kconfig | 10 ++
drivers/usb/host/ohci-hcd.c | 5 +
drivers/usb/host/ohci-platform.c | 183 ++++++++++++++++++++++++++++++++++++++
3 files changed, 198 insertions(+), 0 deletions(-)
create mode 100644 drivers/usb/host/ohci-platform.c
--- a/drivers/usb/host/Kconfig --- a/drivers/usb/host/Kconfig
+++ b/drivers/usb/host/Kconfig +++ b/drivers/usb/host/Kconfig
@@ -378,6 +378,16 @@ config USB_CNS3XXX_OHCI @@ -378,6 +378,16 @@ config USB_CNS3XXX_OHCI
@ -23,7 +5,7 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
It is needed for low-speed USB 1.0 device support. It is needed for low-speed USB 1.0 device support.
+config USB_OHCI_HCD_PLATFORM +config USB_OHCI_HCD_PLATFORM
+ bool "OHCI driver for a platform device" + bool "Generic OHCI driver for a platform device"
+ depends on USB_OHCI_HCD && EXPERIMENTAL + depends on USB_OHCI_HCD && EXPERIMENTAL
+ default n + default n
+ ---help--- + ---help---
@ -51,7 +33,7 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
!defined(OMAP1_PLATFORM_DRIVER) && \ !defined(OMAP1_PLATFORM_DRIVER) && \
--- /dev/null --- /dev/null
+++ b/drivers/usb/host/ohci-platform.c +++ b/drivers/usb/host/ohci-platform.c
@@ -0,0 +1,183 @@ @@ -0,0 +1,194 @@
+/* +/*
+ * Generic platform ohci driver + * Generic platform ohci driver
+ * + *
@ -68,13 +50,22 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ * Licensed under the GNU/GPL. See COPYING for details. + * Licensed under the GNU/GPL. See COPYING for details.
+ */ + */
+#include <linux/platform_device.h> +#include <linux/platform_device.h>
+#include <linux/usb/hci_driver.h> +#include <linux/usb/ohci_pdriver.h>
+ +
+static int ohci_platform_reset(struct usb_hcd *hcd) +static int ohci_platform_reset(struct usb_hcd *hcd)
+{ +{
+ struct platform_device *pdev = to_platform_device(hcd->self.controller);
+ struct usb_ohci_pdata *pdata = pdev->dev.platform_data;
+ struct ohci_hcd *ohci = hcd_to_ohci(hcd); + struct ohci_hcd *ohci = hcd_to_ohci(hcd);
+ int err; + int err;
+ +
+ if (pdata->big_endian_desc)
+ ohci->flags |= OHCI_QUIRK_BE_DESC;
+ if (pdata->big_endian_mmio)
+ ohci->flags |= OHCI_QUIRK_BE_MMIO;
+ if (pdata->no_big_frame_no)
+ ohci->flags |= OHCI_QUIRK_FRAME_NO;
+
+ ohci_hcd_init(ohci); + ohci_hcd_init(ohci);
+ err = ohci_init(ohci); + err = ohci_init(ohci);
+ +
@ -131,6 +122,8 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ int irq; + int irq;
+ int err = -ENOMEM; + int err = -ENOMEM;
+ +
+ BUG_ON(!dev->dev.platform_data);
+
+ if (usb_disabled()) + if (usb_disabled())
+ return -ENODEV; + return -ENODEV;
+ +
@ -235,3 +228,44 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ .pm = &ohci_platform_pm_ops, + .pm = &ohci_platform_pm_ops,
+ } + }
+}; +};
--- /dev/null
+++ b/include/linux/usb/ohci_pdriver.h
@@ -0,0 +1,38 @@
+/*
+ * Copyright (C) 2012 Hauke Mehrtens <hauke@hauke-m.de>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#ifndef __USB_CORE_OHCI_PDRIVER_H
+#define __USB_CORE_OHCI_PDRIVER_H
+
+/**
+ * struct usb_ohci_pdata - platform_data for generic ohci driver
+ *
+ * @big_endian_desc: BE descriptors
+ * @big_endian_mmio: BE registers
+ * @no_big_frame_no: no big endian frame_no shift
+ *
+ * These are general configuration options for the OHCI controller. All of
+ * these options are activating more or less workarounds for some hardware.
+ */
+struct usb_ohci_pdata {
+ unsigned big_endian_desc:1;
+ unsigned big_endian_mmio:1;
+ unsigned no_big_frame_no:1;
+};
+
+#endif /* __USB_CORE_OHCI_PDRIVER_H */

View File

@ -1,21 +1,3 @@
From 1be00523336ac484c52681f838dfb8a76e8531cd Mon Sep 17 00:00:00 2001
From: Hauke Mehrtens <hauke@hauke-m.de>
Date: Sat, 26 Nov 2011 21:28:56 +0100
Subject: [PATCH 182/186] USB: EHCI: Add a generic platform device driver
This adds a generic driver for platform devices. It works like the PCI
driver and is based on it. This is for devices which do not have an own
bus but their EHCI controller works like a PCI controller. It will be
used for the Broadcom bcma and ssb USB EHCI controller.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
---
drivers/usb/host/Kconfig | 10 ++
drivers/usb/host/ehci-hcd.c | 5 +
drivers/usb/host/ehci-platform.c | 199 ++++++++++++++++++++++++++++++++++++++
3 files changed, 214 insertions(+), 0 deletions(-)
create mode 100644 drivers/usb/host/ehci-platform.c
--- a/drivers/usb/host/Kconfig --- a/drivers/usb/host/Kconfig
+++ b/drivers/usb/host/Kconfig +++ b/drivers/usb/host/Kconfig
@@ -388,6 +388,16 @@ config USB_OHCI_HCD_PLATFORM @@ -388,6 +388,16 @@ config USB_OHCI_HCD_PLATFORM
@ -51,7 +33,7 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
!defined(XILINX_OF_PLATFORM_DRIVER) !defined(XILINX_OF_PLATFORM_DRIVER)
--- /dev/null --- /dev/null
+++ b/drivers/usb/host/ehci-platform.c +++ b/drivers/usb/host/ehci-platform.c
@@ -0,0 +1,199 @@ @@ -0,0 +1,198 @@
+/* +/*
+ * Generic platform ehci driver + * Generic platform ehci driver
+ * + *
@ -73,32 +55,29 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ * Licensed under the GNU/GPL. See COPYING for details. + * Licensed under the GNU/GPL. See COPYING for details.
+ */ + */
+#include <linux/platform_device.h> +#include <linux/platform_device.h>
+#include <linux/usb/hci_driver.h> +#include <linux/usb/ehci_pdriver.h>
+ +
+static int ehci_platform_reset(struct usb_hcd *hcd) +static int ehci_platform_reset(struct usb_hcd *hcd)
+{ +{
+ struct platform_device *pdev = to_platform_device(hcd->self.controller); + struct platform_device *pdev = to_platform_device(hcd->self.controller);
+ struct usb_hci_pdata *pdata = pdev->dev.platform_data; + struct usb_ehci_pdata *pdata = pdev->dev.platform_data;
+ struct ehci_hcd *ehci = hcd_to_ehci(hcd); + struct ehci_hcd *ehci = hcd_to_ehci(hcd);
+ int caps_offset = 0;
+ int flags = 0;
+ int retval; + int retval;
+ +
+ if (pdata) {
+ caps_offset = pdata->caps_offset;
+ flags = pdata->flags;
+ }
+
+ if (flags & USB_HCI_PDATA_HAS_TT_SET)
+ hcd->has_tt = pdata->has_tt; + hcd->has_tt = pdata->has_tt;
+ ehci->has_synopsys_hc_bug = pdata->has_synopsys_hc_bug;
+ ehci->big_endian_desc = pdata->big_endian_desc;
+ ehci->big_endian_mmio = pdata->big_endian_mmio;
+ +
+ ehci->caps = hcd->regs + caps_offset; + ehci->caps = hcd->regs + pdata->caps_offset;
+ retval = ehci_setup(hcd); + retval = ehci_setup(hcd);
+ if (retval) + if (retval)
+ return retval; + return retval;
+ +
+ if (flags & USB_HCI_PDATA_PORT_POWER_SET) + if (pdata->port_power_on)
+ ehci_port_power(ehci, pdata->power_set_is_on); + ehci_port_power(ehci, 1);
+ if (pdata->port_power_off)
+ ehci_port_power(ehci, 0);
+ +
+ return 0; + return 0;
+} +}
@ -144,6 +123,8 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ int irq; + int irq;
+ int err = -ENOMEM; + int err = -ENOMEM;
+ +
+ BUG_ON(!dev->dev.platform_data);
+
+ if (usb_disabled()) + if (usb_disabled())
+ return -ENODEV; + return -ENODEV;
+ +
@ -251,3 +232,52 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ .pm = &ehci_platform_pm_ops, + .pm = &ehci_platform_pm_ops,
+ } + }
+}; +};
--- /dev/null
+++ b/include/linux/usb/ehci_pdriver.h
@@ -0,0 +1,46 @@
+/*
+ * Copyright (C) 2012 Hauke Mehrtens <hauke@hauke-m.de>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#ifndef __USB_CORE_EHCI_PDRIVER_H
+#define __USB_CORE_EHCI_PDRIVER_H
+
+/**
+ * struct usb_ehci_pdata - platform_data for generic ehci driver
+ *
+ * @caps_offset: offset of the EHCI Capability Registers to the start of
+ * the io memory region provided to the driver.
+ * @has_tt: set to 1 if TT is integrated in root hub.
+ * @port_power_on: set to 1 if the controller needs a power up after
+ * initialization.
+ * @port_power_off: set to 1 if the controller needs to be powered down
+ * after initialization.
+ *
+ * These are general configuration options for the EHCI controller. All of
+ * these options are activating more or less workarounds for some hardware.
+ */
+struct usb_ehci_pdata {
+ int caps_offset;
+ unsigned has_tt:1;
+ unsigned has_synopsys_hc_bug:1;
+ unsigned big_endian_desc:1;
+ unsigned big_endian_mmio:1;
+ unsigned port_power_on:1;
+ unsigned port_power_off:1;
+};
+
+#endif /* __USB_CORE_EHCI_PDRIVER_H */

View File

@ -0,0 +1,45 @@
--- a/drivers/bcma/scan.c
+++ b/drivers/bcma/scan.c
@@ -297,6 +297,23 @@ static int bcma_get_next_core(struct bcm
return -EILSEQ;
}
+ /* First Slave Address Descriptor should be port 0:
+ * the main register space for the core
+ */
+ tmp = bcma_erom_get_addr_desc(bus, eromptr, SCAN_ADDR_TYPE_SLAVE, 0);
+ if (tmp <= 0) {
+ /* Try again to see if it is a bridge */
+ tmp = bcma_erom_get_addr_desc(bus, eromptr,
+ SCAN_ADDR_TYPE_BRIDGE, 0);
+ if (tmp <= 0) {
+ return -EILSEQ;
+ } else {
+ pr_info("Bridge found\n");
+ return -ENXIO;
+ }
+ }
+ core->addr = tmp;
+
/* get & parse slave ports */
for (i = 0; i < ports[1]; i++) {
for (j = 0; ; j++) {
@@ -309,7 +326,7 @@ static int bcma_get_next_core(struct bcm
break;
} else {
if (i == 0 && j == 0)
- core->addr = tmp;
+ core->addr1 = tmp;
}
}
}
--- a/include/linux/bcma/bcma.h
+++ b/include/linux/bcma/bcma.h
@@ -139,6 +139,7 @@ struct bcma_device {
u8 core_unit;
u32 addr;
+ u32 addr1;
u32 wrap;
void __iomem *io_addr;

View File

@ -1,24 +1,3 @@
From 70fc4b2a6200ef7a1b99a6aa28234b919f23b43c Mon Sep 17 00:00:00 2001
From: Hauke Mehrtens <hauke@hauke-m.de>
Date: Sat, 26 Nov 2011 21:33:41 +0100
Subject: [PATCH 184/186] USB: Add driver for the bcma bus
This adds a USB driver using the generic platform device driver for the
USB controller found on the Broadcom bcma bus. The bcma bus just
exposes one device which serves the OHCI and the EHCI controller at the
same time. This driver probes for this USB controller and creates and
registers two new platform devices which will be probed by the new
generic platform device driver. This makes it possible to use the EHCI
and the OCHI controller on the bcma bus at the same time.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
---
drivers/usb/host/Kconfig | 12 ++
drivers/usb/host/Makefile | 1 +
drivers/usb/host/bcma-hcd.c | 328 +++++++++++++++++++++++++++++++++++++++++++
3 files changed, 341 insertions(+), 0 deletions(-)
create mode 100644 drivers/usb/host/bcma-hcd.c
--- a/drivers/usb/host/Kconfig --- a/drivers/usb/host/Kconfig
+++ b/drivers/usb/host/Kconfig +++ b/drivers/usb/host/Kconfig
@@ -618,3 +618,15 @@ config USB_PXA168_EHCI @@ -618,3 +618,15 @@ config USB_PXA168_EHCI
@ -46,12 +25,12 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+obj-$(CONFIG_USB_HCD_BCMA) += bcma-hcd.o +obj-$(CONFIG_USB_HCD_BCMA) += bcma-hcd.o
--- /dev/null --- /dev/null
+++ b/drivers/usb/host/bcma-hcd.c +++ b/drivers/usb/host/bcma-hcd.c
@@ -0,0 +1,328 @@ @@ -0,0 +1,334 @@
+/* +/*
+ * Broadcom specific Advanced Microcontroller Bus + * Broadcom specific Advanced Microcontroller Bus
+ * Broadcom USB-core driver (BCMA bus glue) + * Broadcom USB-core driver (BCMA bus glue)
+ * + *
+ * Copyright 2011 Hauke Mehrtens <hauke@hauke-m.de> + * Copyright 2011-2012 Hauke Mehrtens <hauke@hauke-m.de>
+ * + *
+ * Based on ssb-ohci driver + * Based on ssb-ohci driver
+ * Copyright 2007 Michael Buesch <m@bues.ch> + * Copyright 2007 Michael Buesch <m@bues.ch>
@ -71,7 +50,8 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+#include <linux/delay.h> +#include <linux/delay.h>
+#include <linux/platform_device.h> +#include <linux/platform_device.h>
+#include <linux/module.h> +#include <linux/module.h>
+#include <linux/usb/hci_driver.h> +#include <linux/usb/ehci_pdriver.h>
+#include <linux/usb/ohci_pdriver.h>
+ +
+MODULE_AUTHOR("Hauke Mehrtens"); +MODULE_AUTHOR("Hauke Mehrtens");
+MODULE_DESCRIPTION("Common USB driver for BCMA Bus"); +MODULE_DESCRIPTION("Common USB driver for BCMA Bus");
@ -206,13 +186,14 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ } + }
+} +}
+ +
+static const struct usb_hci_pdata p_data = { +static const struct usb_ehci_pdata ehci_pdata = {
+ .flags = USB_HCI_PDATA_PORT_POWER_SET, +};
+ .power_set_is_on = 1, +
+static const struct usb_ohci_pdata ohci_pdata = {
+}; +};
+ +
+static struct platform_device * __devinit +static struct platform_device * __devinit
+bcma_hcd_create_pdev(struct bcma_device *dev, char *name, u32 addr) +bcma_hcd_create_pdev(struct bcma_device *dev, bool ohci, u32 addr)
+{ +{
+ struct platform_device *hci_dev; + struct platform_device *hci_dev;
+ struct resource hci_res[2]; + struct resource hci_res[2];
@ -227,7 +208,8 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ hci_res[1].start = dev->irq; + hci_res[1].start = dev->irq;
+ hci_res[1].flags = IORESOURCE_IRQ; + hci_res[1].flags = IORESOURCE_IRQ;
+ +
+ hci_dev = platform_device_alloc(name, 0); + hci_dev = platform_device_alloc(ohci ? "ohci-platform" :
+ "ehci-platform" , 0);
+ if (!hci_dev) + if (!hci_dev)
+ return NULL; + return NULL;
+ +
@ -238,7 +220,12 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ ARRAY_SIZE(hci_res)); + ARRAY_SIZE(hci_res));
+ if (ret) + if (ret)
+ goto err_alloc; + goto err_alloc;
+ ret = platform_device_add_data(hci_dev, &p_data, sizeof(p_data)); + if (ohci)
+ ret = platform_device_add_data(hci_dev, &ohci_pdata,
+ sizeof(ohci_pdata));
+ else
+ ret = platform_device_add_data(hci_dev, &ehci_pdata,
+ sizeof(ehci_pdata));
+ if (ret) + if (ret)
+ goto err_alloc; + goto err_alloc;
+ ret = platform_device_add(hci_dev); + ret = platform_device_add(hci_dev);
@ -284,15 +271,13 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ && chipinfo->rev == 0) + && chipinfo->rev == 0)
+ ohci_addr = 0x18009000; + ohci_addr = 0x18009000;
+ +
+ usb_dev->ohci_dev = bcma_hcd_create_pdev(dev, "ohci-platform", + usb_dev->ohci_dev = bcma_hcd_create_pdev(dev, true, ohci_addr);
+ ohci_addr);
+ if (IS_ERR(usb_dev->ohci_dev)) { + if (IS_ERR(usb_dev->ohci_dev)) {
+ err = PTR_ERR(usb_dev->ohci_dev); + err = PTR_ERR(usb_dev->ohci_dev);
+ goto err_free_usb_dev; + goto err_free_usb_dev;
+ } + }
+ +
+ usb_dev->ehci_dev = bcma_hcd_create_pdev(dev, "ehci-platform", + usb_dev->ehci_dev = bcma_hcd_create_pdev(dev, false, dev->addr);
+ dev->addr);
+ if (IS_ERR(usb_dev->ehci_dev)) { + if (IS_ERR(usb_dev->ehci_dev)) {
+ err = PTR_ERR(usb_dev->ehci_dev); + err = PTR_ERR(usb_dev->ehci_dev);
+ goto err_unregister_ohci_dev; + goto err_unregister_ohci_dev;

View File

@ -1,61 +0,0 @@
From adebff2358c2b631fc04e31ba87eee48e546c655 Mon Sep 17 00:00:00 2001
From: Hauke Mehrtens <hauke@hauke-m.de>
Date: Sun, 20 Nov 2011 18:22:35 +0100
Subject: [PATCH 183/186] bcma: scan for extra address space
Some cores like the USB core have two address spaces. In the USB host
controller one address space is used for the OHCI and the other for the
EHCI controller interface. The USB controller is the only core I found
with two address spaces. This code is based on the AI scan function
ai_scan() in shared/aiutils.c i the Broadcom SDK.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
---
drivers/bcma/scan.c | 18 +++++++++++++++++-
include/linux/bcma/bcma.h | 1 +
2 files changed, 18 insertions(+), 1 deletions(-)
--- a/drivers/bcma/scan.c
+++ b/drivers/bcma/scan.c
@@ -297,6 +297,22 @@ static int bcma_get_next_core(struct bcm
return -EILSEQ;
}
+
+ /* First Slave Address Descriptor should be port 0:
+ * the main register space for the core
+ */
+ tmp = bcma_erom_get_addr_desc(bus, eromptr, SCAN_ADDR_TYPE_SLAVE, 0);
+ if (tmp <= 0) {
+ /* Try again to see if it is a bridge */
+ tmp = bcma_erom_get_addr_desc(bus, eromptr,
+ SCAN_ADDR_TYPE_BRIDGE, 0);
+ if (tmp > 0) {
+ pr_info("found bridge");
+ return -ENXIO;
+ }
+ }
+ core->addr = tmp;
+
/* get & parse slave ports */
for (i = 0; i < ports[1]; i++) {
for (j = 0; ; j++) {
@@ -309,7 +325,7 @@ static int bcma_get_next_core(struct bcm
break;
} else {
if (i == 0 && j == 0)
- core->addr = tmp;
+ core->addr1 = tmp;
}
}
}
--- a/include/linux/bcma/bcma.h
+++ b/include/linux/bcma/bcma.h
@@ -139,6 +139,7 @@ struct bcma_device {
u8 core_unit;
u32 addr;
+ u32 addr1;
u32 wrap;
void __iomem *io_addr;

View File

@ -1,27 +1,3 @@
From 1840ddf07a452e640549fbd82e2f570da28e377f Mon Sep 17 00:00:00 2001
From: Hauke Mehrtens <hauke@hauke-m.de>
Date: Sat, 26 Nov 2011 21:35:17 +0100
Subject: [PATCH 185/186] USB: Add driver for the ssb bus
This adds a USB driver using the generic platform device driver for the
USB controller found on the Broadcom ssb bus. The ssb bus just
exposes one device which serves the OHCI and the EHCI controller at the
same time. This driver probes for this USB controller and creates and
registers two new platform devices which will be probed by the new
generic platform device driver. This makes it possible to use the EHCI
and the OCHI controller on the ssb bus at the same time.
The old ssb OHCI USB driver will be removed in the next step as this
driver also provide an OHCI driver and an EHCI for the cores supporting
it.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
---
drivers/usb/host/Kconfig | 12 ++
drivers/usb/host/Makefile | 1 +
drivers/usb/host/ssb-hcd.c | 273 ++++++++++++++++++++++++++++++++++++++++++++
3 files changed, 286 insertions(+), 0 deletions(-)
create mode 100644 drivers/usb/host/ssb-hcd.c
--- a/drivers/usb/host/Kconfig --- a/drivers/usb/host/Kconfig
+++ b/drivers/usb/host/Kconfig +++ b/drivers/usb/host/Kconfig
@ -50,12 +26,12 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+obj-$(CONFIG_USB_HCD_SSB) += ssb-hcd.o +obj-$(CONFIG_USB_HCD_SSB) += ssb-hcd.o
--- /dev/null --- /dev/null
+++ b/drivers/usb/host/ssb-hcd.c +++ b/drivers/usb/host/ssb-hcd.c
@@ -0,0 +1,273 @@ @@ -0,0 +1,279 @@
+/* +/*
+ * Sonics Silicon Backplane + * Sonics Silicon Backplane
+ * Broadcom USB-core driver (SSB bus glue) + * Broadcom USB-core driver (SSB bus glue)
+ * + *
+ * Copyright 2011 Hauke Mehrtens <hauke@hauke-m.de> + * Copyright 2011-2012 Hauke Mehrtens <hauke@hauke-m.de>
+ * + *
+ * Based on ssb-ohci driver + * Based on ssb-ohci driver
+ * Copyright 2007 Michael Buesch <m@bues.ch> + * Copyright 2007 Michael Buesch <m@bues.ch>
@ -75,7 +51,8 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+#include <linux/delay.h> +#include <linux/delay.h>
+#include <linux/platform_device.h> +#include <linux/platform_device.h>
+#include <linux/module.h> +#include <linux/module.h>
+#include <linux/usb/hci_driver.h> +#include <linux/usb/ehci_pdriver.h>
+#include <linux/usb/ohci_pdriver.h>
+ +
+MODULE_AUTHOR("Hauke Mehrtens"); +MODULE_AUTHOR("Hauke Mehrtens");
+MODULE_DESCRIPTION("Common USB driver for SSB Bus"); +MODULE_DESCRIPTION("Common USB driver for SSB Bus");
@ -146,13 +123,14 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ return flags; + return flags;
+} +}
+ +
+static const struct usb_hci_pdata p_data = { +static const struct usb_ehci_pdata ehci_pdata = {
+ .flags = USB_HCI_PDATA_PORT_POWER_SET, +};
+ .power_set_is_on = 1, +
+static const struct usb_ohci_pdata ohci_pdata = {
+}; +};
+ +
+static struct platform_device * __devinit +static struct platform_device * __devinit
+ssb_hcd_create_pdev(struct ssb_device *dev, char *name, u32 addr, u32 len) +ssb_hcd_create_pdev(struct ssb_device *dev, bool ohci, u32 addr, u32 len)
+{ +{
+ struct platform_device *hci_dev; + struct platform_device *hci_dev;
+ struct resource hci_res[2]; + struct resource hci_res[2];
@ -167,7 +145,8 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ hci_res[1].start = dev->irq; + hci_res[1].start = dev->irq;
+ hci_res[1].flags = IORESOURCE_IRQ; + hci_res[1].flags = IORESOURCE_IRQ;
+ +
+ hci_dev = platform_device_alloc(name, 0); + hci_dev = platform_device_alloc(ohci ? "ohci-platform" :
+ "ehci-platform" , 0);
+ if (!hci_dev) + if (!hci_dev)
+ return NULL; + return NULL;
+ +
@ -178,7 +157,12 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ ARRAY_SIZE(hci_res)); + ARRAY_SIZE(hci_res));
+ if (ret) + if (ret)
+ goto err_alloc; + goto err_alloc;
+ ret = platform_device_add_data(hci_dev, &p_data, sizeof(p_data)); + if (ohci)
+ ret = platform_device_add_data(hci_dev, &ohci_pdata,
+ sizeof(ohci_pdata));
+ else
+ ret = platform_device_add_data(hci_dev, &ehci_pdata,
+ sizeof(ehci_pdata));
+ if (ret) + if (ret)
+ goto err_alloc; + goto err_alloc;
+ ret = platform_device_add(hci_dev); + ret = platform_device_add(hci_dev);
@ -226,8 +210,7 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ +
+ start = ssb_admatch_base(tmp); + start = ssb_admatch_base(tmp);
+ len = (coreid == SSB_DEV_USB20_HOST) ? 0x800 : ssb_admatch_size(tmp); + len = (coreid == SSB_DEV_USB20_HOST) ? 0x800 : ssb_admatch_size(tmp);
+ usb_dev->ohci_dev = ssb_hcd_create_pdev(dev, "ohci-platform", start, + usb_dev->ohci_dev = ssb_hcd_create_pdev(dev, true, start, len);
+ len);
+ if (IS_ERR(usb_dev->ohci_dev)) { + if (IS_ERR(usb_dev->ohci_dev)) {
+ err = PTR_ERR(usb_dev->ohci_dev); + err = PTR_ERR(usb_dev->ohci_dev);
+ goto err_free_usb_dev; + goto err_free_usb_dev;
@ -235,8 +218,7 @@ Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
+ +
+ if (coreid == SSB_DEV_USB20_HOST) { + if (coreid == SSB_DEV_USB20_HOST) {
+ start = ssb_admatch_base(tmp) + 0x800; /* ehci core offset */ + start = ssb_admatch_base(tmp) + 0x800; /* ehci core offset */
+ usb_dev->ehci_dev = ssb_hcd_create_pdev(dev, "ehci-platform", + usb_dev->ehci_dev = ssb_hcd_create_pdev(dev, false, start, len);
+ start, len);
+ if (IS_ERR(usb_dev->ehci_dev)) { + if (IS_ERR(usb_dev->ehci_dev)) {
+ err = PTR_ERR(usb_dev->ehci_dev); + err = PTR_ERR(usb_dev->ehci_dev);
+ goto err_unregister_ohci_dev; + goto err_unregister_ohci_dev;

View File

@ -1,41 +1,22 @@
From 57857d7df6c22eaf11e3c67042d55a9546415059 Mon Sep 17 00:00:00 2001
From: Hauke Mehrtens <hauke@hauke-m.de>
Date: Sat, 26 Nov 2011 21:36:50 +0100
Subject: [PATCH 186/186] USB: OHCI: remove old SSB OHCI driver
This is now replaced by the new ssb USB driver, which also supports
devices with an EHCI controller.
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
---
drivers/usb/host/Kconfig | 13 --
drivers/usb/host/ohci-hcd.c | 21 +----
drivers/usb/host/ohci-ssb.c | 260 -------------------------------------------
3 files changed, 1 insertions(+), 293 deletions(-)
delete mode 100644 drivers/usb/host/ohci-ssb.c
--- a/drivers/usb/host/Kconfig --- a/drivers/usb/host/Kconfig
+++ b/drivers/usb/host/Kconfig +++ b/drivers/usb/host/Kconfig
@@ -351,19 +351,6 @@ config USB_OHCI_HCD_PCI @@ -352,10 +352,15 @@ config USB_OHCI_HCD_PCI
Enables support for PCI-bus plug-in USB controller cards.
If unsure, say Y. If unsure, say Y.
-config USB_OHCI_HCD_SSB config USB_OHCI_HCD_SSB
- bool "OHCI support for Broadcom SSB OHCI core" - bool "OHCI support for Broadcom SSB OHCI core"
- depends on USB_OHCI_HCD && (SSB = y || SSB = USB_OHCI_HCD) && EXPERIMENTAL + bool "OHCI support for Broadcom SSB OHCI core (DEPRECATED)"
- default n depends on USB_OHCI_HCD && (SSB = y || SSB = USB_OHCI_HCD) && EXPERIMENTAL
- ---help--- + select USB_HCD_SSB
- Support for the Sonics Silicon Backplane (SSB) attached + select USB_OHCI_HCD_PLATFORM
- Broadcom USB OHCI core. default n
- ---help---
- This device is present in some embedded devices with + This option is deprecated now and the driver was removed, use
- Broadcom based SSB bus. + USB_HCD_SSB and USB_OHCI_HCD_PLATFORM instead.
- +
- If unsure, say N. Support for the Sonics Silicon Backplane (SSB) attached
- Broadcom USB OHCI core.
config USB_OHCI_SH
bool "OHCI support for SuperH USB controller"
depends on USB_OHCI_HCD && SUPERH
--- a/drivers/usb/host/ohci-hcd.c --- a/drivers/usb/host/ohci-hcd.c
+++ b/drivers/usb/host/ohci-hcd.c +++ b/drivers/usb/host/ohci-hcd.c
@@ -1076,11 +1076,6 @@ MODULE_LICENSE ("GPL"); @@ -1076,11 +1076,6 @@ MODULE_LICENSE ("GPL");