aboutsummaryrefslogtreecommitdiffstats
path: root/target/linux/adm5120/patches-2.6.38
diff options
context:
space:
mode:
authorFlorian Fainelli <florian@openwrt.org>2012-04-04 15:53:09 +0000
committerFlorian Fainelli <florian@openwrt.org>2012-04-04 15:53:09 +0000
commitb180e0fb3b1b3b89b2ac0e9502919ab4b1785af7 (patch)
tree332c45090920ea5e5974a0e90bac969ab31aa861 /target/linux/adm5120/patches-2.6.38
parentf087e07b5cdd8a042d1f9530e9a909268a87b2a5 (diff)
downloadupstream-b180e0fb3b1b3b89b2ac0e9502919ab4b1785af7.tar.gz
upstream-b180e0fb3b1b3b89b2ac0e9502919ab4b1785af7.tar.bz2
upstream-b180e0fb3b1b3b89b2ac0e9502919ab4b1785af7.zip
fix support for 2.6.38 kernel
This patch fixes the following issues I encountered while compiling kernel 2.6.38.8 for my Omnima Embedded Controller/Edimax BR6104KP: - kernel comes up with machine selection during build, even though everything was properly set in menuconfig - USB api changes Successfully built and tested with r29755. Signed-off-by: Hartmut Knaack <knaack.h [at] gmx.de> SVN-Revision: 31194
Diffstat (limited to 'target/linux/adm5120/patches-2.6.38')
-rw-r--r--target/linux/adm5120/patches-2.6.38/010-adm5120_usb_new_api.patch53
1 files changed, 53 insertions, 0 deletions
diff --git a/target/linux/adm5120/patches-2.6.38/010-adm5120_usb_new_api.patch b/target/linux/adm5120/patches-2.6.38/010-adm5120_usb_new_api.patch
new file mode 100644
index 0000000000..14c54bbd5b
--- /dev/null
+++ b/target/linux/adm5120/patches-2.6.38/010-adm5120_usb_new_api.patch
@@ -0,0 +1,53 @@
+--- a/drivers/usb/host/adm5120-hcd.c
++++ b/drivers/usb/host/adm5120-hcd.c
+@@ -32,6 +32,7 @@
+ #include <linux/list.h>
+ #include <linux/usb.h>
+ #include <linux/usb/otg.h>
++#include <linux/usb/hcd.h>
+ #include <linux/dma-mapping.h>
+ #include <linux/dmapool.h>
+ #include <linux/reboot.h>
+@@ -43,8 +44,6 @@
+ #include <asm/unaligned.h>
+ #include <asm/byteorder.h>
+
+-#include "../core/hcd.h"
+-#include "../core/hub.h"
+
+ #define DRIVER_VERSION "0.27.0"
+ #define DRIVER_AUTHOR "Gabor Juhos <juhosg@openwrt.org>"
+@@ -571,7 +570,7 @@ static int admhc_run(struct admhcd *ahcd
+ periodic_reinit(ahcd);
+
+ /* use rhsc irqs after khubd is fully initialized */
+- hcd->poll_rh = 1;
++ set_bit(HCD_FLAG_POLL_RH, &hcd->flags);
+ hcd->uses_new_polling = 1;
+
+ #if 0
+@@ -688,7 +687,7 @@ static irqreturn_t admhc_irq(struct usb_
+ */
+ admhc_vdbg(ahcd, "Resume Detect\n");
+ admhc_intr_ack(ahcd, ADMHC_INTR_RESI);
+- hcd->poll_rh = 1;
++ set_bit(HCD_FLAG_POLL_RH, &hcd->flags);
+ if (ahcd->autostop) {
+ spin_lock(&ahcd->lock);
+ admhc_rh_resume(ahcd);
+--- a/drivers/usb/host/adm5120-hub.c
++++ b/drivers/usb/host/adm5120-hub.c
+@@ -106,8 +106,11 @@ admhc_hub_status_data(struct usb_hcd *hc
+ }
+ }
+
+- hcd->poll_rh = admhc_root_hub_state_changes(ahcd, changed,
+- any_connected);
++ if (admhc_root_hub_state_changes(ahcd, changed,
++ any_connected))
++ set_bit(HCD_FLAG_POLL_RH, &hcd->flags);
++ else
++ clear_bit(HCD_FLAG_POLL_RH, &hcd->flags);
+
+ done:
+ spin_unlock_irqrestore(&ahcd->lock, flags);