فهرست منبع

usb: Add support for txfifo threshold

CONFIG_USB_EHCI_TXFIFO_THRESH enables setting of the txfilltuning
field in the EHCI controller on reset.

Signed-off-by: Simon Glass <sjg@chromium.org>
Acked-by: Remy Bohmer <linux@bohmer.net>
Signed-off-by: Tom Warren <twarren@nvidia.com>
Simon Glass 13 سال پیش
والد
کامیت
9ab4ce223c
3فایلهای تغییر یافته به همراه15 افزوده شده و 1 حذف شده
  1. 3 0
      README
  2. 7 0
      drivers/usb/host/ehci-hcd.c
  3. 5 1
      drivers/usb/host/ehci.h

+ 3 - 0
README

@@ -1125,6 +1125,9 @@ The following options need to be configured:
 				May be defined to allow interrupt polling
 				May be defined to allow interrupt polling
 				instead of using asynchronous interrupts
 				instead of using asynchronous interrupts
 
 
+		CONFIG_USB_EHCI_TXFIFO_THRESH enables setting of the
+		txfilltuning field in the EHCI controller on reset.
+
 - USB Device:
 - USB Device:
 		Define the below if you wish to use the USB console.
 		Define the below if you wish to use the USB console.
 		Once firmware is rebuilt from a serial console issue the
 		Once firmware is rebuilt from a serial console issue the

+ 7 - 0
drivers/usb/host/ehci-hcd.c

@@ -255,6 +255,13 @@ static int ehci_reset(void)
 #endif
 #endif
 		ehci_writel(reg_ptr, tmp);
 		ehci_writel(reg_ptr, tmp);
 	}
 	}
+
+#ifdef CONFIG_USB_EHCI_TXFIFO_THRESH
+	cmd = ehci_readl(&hcor->or_txfilltuning);
+	cmd &= ~TXFIFO_THRESH(0x3f);
+	cmd |= TXFIFO_THRESH(CONFIG_USB_EHCI_TXFIFO_THRESH);
+	ehci_writel(&hcor->or_txfilltuning, cmd);
+#endif
 out:
 out:
 	return ret;
 	return ret;
 }
 }

+ 5 - 1
drivers/usb/host/ehci.h

@@ -80,7 +80,11 @@ struct ehci_hcor {
 	uint32_t or_ctrldssegment;
 	uint32_t or_ctrldssegment;
 	uint32_t or_periodiclistbase;
 	uint32_t or_periodiclistbase;
 	uint32_t or_asynclistaddr;
 	uint32_t or_asynclistaddr;
-	uint32_t _reserved_[9];
+	uint32_t _reserved_0_;
+	uint32_t or_burstsize;
+	uint32_t or_txfilltuning;
+#define TXFIFO_THRESH(p)		((p & 0x3f) << 16)
+	uint32_t _reserved_1_[6];
 	uint32_t or_configflag;
 	uint32_t or_configflag;
 #define FLAG_CF		(1 << 0)	/* true:  we'll support "high speed" */
 #define FLAG_CF		(1 << 0)	/* true:  we'll support "high speed" */
 	uint32_t or_portsc[CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS];
 	uint32_t or_portsc[CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS];