summaryrefslogtreecommitdiff
path: root/packages/linux/linux-rp-2.6.22/usb-ohci-hooks-r2.patch
diff options
context:
space:
mode:
authorFlorian Boor <florian.boor@kernelconcepts.de>2008-01-21 21:09:09 +0000
committerFlorian Boor <florian.boor@kernelconcepts.de>2008-01-21 21:09:09 +0000
commitafd58cdcce656ced784bfca78d7d96e2edca8cee (patch)
treeb49291fedc042760b35f74afa9b7e82b591147e5 /packages/linux/linux-rp-2.6.22/usb-ohci-hooks-r2.patch
parentac6de0f3c0d8d5fe5708d9125c1319fbf5d627a6 (diff)
parenta7a4c7d6f9bbcda53d3bf07d51142d41e1a4558b (diff)
merge of '1cc9d40e03f431fac4150580f6a58521cae55509'
and 'a250ef0b1707ead866fe051ca88c56e538d51bfb'
Diffstat (limited to 'packages/linux/linux-rp-2.6.22/usb-ohci-hooks-r2.patch')
-rw-r--r--packages/linux/linux-rp-2.6.22/usb-ohci-hooks-r2.patch180
1 files changed, 0 insertions, 180 deletions
diff --git a/packages/linux/linux-rp-2.6.22/usb-ohci-hooks-r2.patch b/packages/linux/linux-rp-2.6.22/usb-ohci-hooks-r2.patch
deleted file mode 100644
index 3656e98f0c..0000000000
--- a/packages/linux/linux-rp-2.6.22/usb-ohci-hooks-r2.patch
+++ /dev/null
@@ -1,180 +0,0 @@
-Index: linux-2.6.15/drivers/usb/host/ohci.h
-===================================================================
---- linux-2.6.15.orig/drivers/usb/host/ohci.h
-+++ linux-2.6.15/drivers/usb/host/ohci.h
-@@ -336,6 +336,23 @@ typedef struct urb_priv {
- // sizeof (struct td) ~= 64 == 2^6 ...
- #define TD_HASH_FUNC(td_dma) ((td_dma ^ (td_dma >> 6)) % TD_HASH_SIZE)
-
-+struct ohci_hcd;
-+
-+/*
-+ * Hooks to support controllers that must resort to a PIO-ish
-+ * implementation because they only dma with on-chip memory.
-+ */
-+struct ohci_ops {
-+ void* (*dma_pool_alloc) (struct dma_pool *pool, gfp_t mem_flags,
-+ dma_addr_t *handle);
-+ void (*dma_pool_free) (struct dma_pool *pool, void *vaddr,
-+ dma_addr_t addr);
-+
-+ void (*td_fill) (struct ohci_hcd *ohci, u32 info, dma_addr_t data,
-+ int len, struct urb *urb, int index);
-+ void (*td_done) (struct ohci_hcd *ohci, struct urb *urb,
-+ struct td *td);
-+};
-
- /*
- * This is the full ohci controller description
-@@ -346,6 +363,7 @@ typedef struct urb_priv {
-
- struct ohci_hcd {
- spinlock_t lock;
-+ const struct ohci_ops *ops;
-
- /*
- * I/O memory used to communicate with the HC (dma-consistent)
-Index: linux-2.6.15/drivers/usb/host/ohci-mem.c
-===================================================================
---- linux-2.6.15.orig/drivers/usb/host/ohci-mem.c
-+++ linux-2.6.15/drivers/usb/host/ohci-mem.c
-@@ -21,10 +21,13 @@
- * No memory seen by this driver is pagable.
- */
-
-+static const struct ohci_ops ohci_ops;
-+
- /*-------------------------------------------------------------------------*/
-
- static void ohci_hcd_init (struct ohci_hcd *ohci)
- {
-+ ohci->ops = &ohci_ops;
- ohci->next_statechange = jiffies;
- spin_lock_init (&ohci->lock);
- INIT_LIST_HEAD (&ohci->pending);
-@@ -88,7 +91,7 @@ td_alloc (struct ohci_hcd *hc, gfp_t mem
- dma_addr_t dma;
- struct td *td;
-
-- td = dma_pool_alloc (hc->td_cache, mem_flags, &dma);
-+ td = hc->ops->dma_pool_alloc (hc->td_cache, mem_flags, &dma);
- if (td) {
- /* in case hc fetches it, make it look dead */
- memset (td, 0, sizeof *td);
-@@ -110,7 +113,7 @@ td_free (struct ohci_hcd *hc, struct td
- *prev = td->td_hash;
- else if ((td->hwINFO & cpu_to_hc32(hc, TD_DONE)) != 0)
- ohci_dbg (hc, "no hash for td %p\n", td);
-- dma_pool_free (hc->td_cache, td, td->td_dma);
-+ hc->ops->dma_pool_free (hc->td_cache, td, td->td_dma);
- }
-
- /*-------------------------------------------------------------------------*/
-@@ -122,7 +125,7 @@ ed_alloc (struct ohci_hcd *hc, gfp_t mem
- dma_addr_t dma;
- struct ed *ed;
-
-- ed = dma_pool_alloc (hc->ed_cache, mem_flags, &dma);
-+ ed = hc->ops->dma_pool_alloc (hc->ed_cache, mem_flags, &dma);
- if (ed) {
- memset (ed, 0, sizeof (*ed));
- INIT_LIST_HEAD (&ed->td_list);
-@@ -134,6 +137,6 @@ ed_alloc (struct ohci_hcd *hc, gfp_t mem
- static void
- ed_free (struct ohci_hcd *hc, struct ed *ed)
- {
-- dma_pool_free (hc->ed_cache, ed, ed->dma);
-+ hc->ops->dma_pool_free (hc->ed_cache, ed, ed->dma);
- }
-
-Index: linux-2.6.15/drivers/usb/host/ohci-q.c
-===================================================================
---- linux-2.6.15.orig/drivers/usb/host/ohci-q.c
-+++ linux-2.6.15/drivers/usb/host/ohci-q.c
-@@ -629,7 +629,7 @@ static void td_submit_urb (
- : TD_T_TOGGLE | TD_CC | TD_DP_IN;
- /* TDs _could_ transfer up to 8K each */
- while (data_len > 4096) {
-- td_fill (ohci, info, data, 4096, urb, cnt);
-+ ohci->ops->td_fill (ohci, info, data, 4096, urb, cnt);
- data += 4096;
- data_len -= 4096;
- cnt++;
-@@ -637,11 +637,11 @@ static void td_submit_urb (
- /* maybe avoid ED halt on final TD short read */
- if (!(urb->transfer_flags & URB_SHORT_NOT_OK))
- info |= TD_R;
-- td_fill (ohci, info, data, data_len, urb, cnt);
-+ ohci->ops->td_fill (ohci, info, data, data_len, urb, cnt);
- cnt++;
- if ((urb->transfer_flags & URB_ZERO_PACKET)
- && cnt < urb_priv->length) {
-- td_fill (ohci, info, 0, 0, urb, cnt);
-+ ohci->ops->td_fill (ohci, info, 0, 0, urb, cnt);
- cnt++;
- }
- /* maybe kickstart bulk list */
-@@ -656,17 +656,18 @@ static void td_submit_urb (
- */
- case PIPE_CONTROL:
- info = TD_CC | TD_DP_SETUP | TD_T_DATA0;
-- td_fill (ohci, info, urb->setup_dma, 8, urb, cnt++);
-+ ohci->ops->td_fill (ohci, info, urb->setup_dma, 8, urb, cnt++);
- if (data_len > 0) {
- info = TD_CC | TD_R | TD_T_DATA1;
- info |= is_out ? TD_DP_OUT : TD_DP_IN;
- /* NOTE: mishandles transfers >8K, some >4K */
-- td_fill (ohci, info, data, data_len, urb, cnt++);
-+ ohci->ops->td_fill (ohci, info, data, data_len,
-+ urb, cnt++);
- }
- info = (is_out || data_len == 0)
- ? TD_CC | TD_DP_IN | TD_T_DATA1
- : TD_CC | TD_DP_OUT | TD_T_DATA1;
-- td_fill (ohci, info, data, 0, urb, cnt++);
-+ ohci->ops->td_fill (ohci, info, data, 0, urb, cnt++);
- /* maybe kickstart control list */
- wmb ();
- ohci_writel (ohci, OHCI_CLF, &ohci->regs->cmdstatus);
-@@ -685,7 +686,7 @@ static void td_submit_urb (
- // a 2^16 iso range, vs other HCs max of 2^10)
- frame += cnt * urb->interval;
- frame &= 0xffff;
-- td_fill (ohci, TD_CC | TD_ISO | frame,
-+ ohci->ops->td_fill (ohci, TD_CC | TD_ISO | frame,
- data + urb->iso_frame_desc [cnt].offset,
- urb->iso_frame_desc [cnt].length, urb, cnt);
- }
-@@ -788,6 +789,14 @@ static void td_done (struct ohci_hcd *oh
- }
- }
-
-+/* default operations for most HCs */
-+static const struct ohci_ops ohci_ops = {
-+ .dma_pool_alloc = dma_pool_alloc,
-+ .dma_pool_free = dma_pool_free,
-+ .td_fill = td_fill,
-+ .td_done = td_done,
-+};
-+
- /*-------------------------------------------------------------------------*/
-
- static inline struct td *
-@@ -984,7 +993,7 @@ rescan_this:
- *prev = td->hwNextTD | savebits;
-
- /* HC may have partly processed this TD */
-- td_done (ohci, urb, td);
-+ ohci->ops->td_done (ohci, urb, td);
- urb_priv->td_cnt++;
-
- /* if URB is done, clean up */
-@@ -1079,7 +1088,7 @@ dl_done_list (struct ohci_hcd *ohci, str
- struct ed *ed = td->ed;
-
- /* update URB's length and status from TD */
-- td_done (ohci, urb, td);
-+ ohci->ops->td_done (ohci, urb, td);
- urb_priv->td_cnt++;
-
- /* If all this urb's TDs are done, call complete() */