From c1c5562770c8fae3b5d6400a039e4798ab3350be Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Tue, 22 Mar 2011 22:52:29 +0100 Subject: [PATCH 01/83] v4l-utils: add patch to fix an overflow so imon MCE remotes should work after loding ir-keytable, thanks much to nektarios Signed-off-by: Stephan Raue --- .../patches/v4l-utils-0.8.3-01-fix_overflow.patch | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-01-fix_overflow.patch diff --git a/packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-01-fix_overflow.patch b/packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-01-fix_overflow.patch new file mode 100644 index 0000000000..ca933de490 --- /dev/null +++ b/packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-01-fix_overflow.patch @@ -0,0 +1,12 @@ +diff -Naur v4l-utils-0.8.3/utils/keytable/keytable.c v4l-utils-0.8.3.patch/utils/keytable/keytable.c +--- v4l-utils-0.8.3/utils/keytable/keytable.c 2011-02-09 23:04:27.000000000 +0100 ++++ v4l-utils-0.8.3.patch/utils/keytable/keytable.c 2011-03-22 22:40:16.957618675 +0100 +@@ -267,7 +267,7 @@ + perror("value"); + } + +- nextkey->codes[0] = (unsigned) strtol(scancode, NULL, 0); ++ nextkey->codes[0] = (unsigned) strtoul(scancode, NULL, 0); + nextkey->codes[1] = (unsigned) value; + nextkey->next = calloc(1, sizeof(*nextkey)); + if (!nextkey->next) { From f8d5713ffd160eb86b94d25e2fe922d99a002bd3 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 03:04:07 +0100 Subject: [PATCH 02/83] projects/*/linux: add DVB NGENE support to various builds (Intel, ION, Generic) Signed-off-by: Stephan Raue --- projects/Generic/linux/linux.i386.conf | 7 ++++--- projects/ION/linux/linux.i386.conf | 7 ++++--- projects/ION/linux/linux.x86_64.conf | 7 ++++--- projects/Intel/linux/linux.i386.conf | 7 ++++--- projects/Intel/linux/linux.x86_64.conf | 7 ++++--- 5 files changed, 20 insertions(+), 15 deletions(-) diff --git a/projects/Generic/linux/linux.i386.conf b/projects/Generic/linux/linux.i386.conf index 23130f3b62..5e2291e31a 100644 --- a/projects/Generic/linux/linux.i386.conf +++ b/projects/Generic/linux/linux.i386.conf @@ -1,6 +1,6 @@ # # Automatically generated make config: don't edit -# Linux/i386 2.6.38-rc8 Kernel Configuration +# Linux/i386 2.6.38 Kernel Configuration # # CONFIG_64BIT is not set CONFIG_X86_32=y @@ -1608,6 +1608,7 @@ CONFIG_MEDIA_TUNER_TEA5767=y CONFIG_MEDIA_TUNER_MT20XX=y CONFIG_MEDIA_TUNER_MT2060=m CONFIG_MEDIA_TUNER_MT2266=m +CONFIG_MEDIA_TUNER_MT2131=m CONFIG_MEDIA_TUNER_QT1010=m CONFIG_MEDIA_TUNER_XC2028=y CONFIG_MEDIA_TUNER_XC5000=y @@ -1707,7 +1708,7 @@ CONFIG_DVB_MANTIS=y # # Supported nGene Adapters # -# CONFIG_DVB_NGENE is not set +CONFIG_DVB_NGENE=m # # Supported DVB Frontends @@ -1766,6 +1767,7 @@ CONFIG_DVB_STV0297=m # # ATSC (North American/Korean Terrestrial/Cable DTV) frontends # +CONFIG_DVB_LGDT330X=m CONFIG_DVB_LGDT3305=m CONFIG_DVB_S5H1411=m @@ -2475,7 +2477,6 @@ CONFIG_MACH_NO_WESTBRIDGE=y # CONFIG_SPEAKUP is not set # CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4 is not set # CONFIG_X86_PLATFORM_DEVICES is not set -# CONFIG_HWSPINLOCK is not set # # Firmware Drivers diff --git a/projects/ION/linux/linux.i386.conf b/projects/ION/linux/linux.i386.conf index 5e27eb0aa5..f0fc601e66 100644 --- a/projects/ION/linux/linux.i386.conf +++ b/projects/ION/linux/linux.i386.conf @@ -1,6 +1,6 @@ # # Automatically generated make config: don't edit -# Linux/i386 2.6.38-rc8 Kernel Configuration +# Linux/i386 2.6.38 Kernel Configuration # # CONFIG_64BIT is not set CONFIG_X86_32=y @@ -1511,6 +1511,7 @@ CONFIG_MEDIA_TUNER_TEA5767=y CONFIG_MEDIA_TUNER_MT20XX=y CONFIG_MEDIA_TUNER_MT2060=m CONFIG_MEDIA_TUNER_MT2266=m +CONFIG_MEDIA_TUNER_MT2131=m CONFIG_MEDIA_TUNER_QT1010=m CONFIG_MEDIA_TUNER_XC2028=y CONFIG_MEDIA_TUNER_XC5000=y @@ -1610,7 +1611,7 @@ CONFIG_DVB_MANTIS=y # # Supported nGene Adapters # -# CONFIG_DVB_NGENE is not set +CONFIG_DVB_NGENE=m # # Supported DVB Frontends @@ -1669,6 +1670,7 @@ CONFIG_DVB_STV0297=m # # ATSC (North American/Korean Terrestrial/Cable DTV) frontends # +CONFIG_DVB_LGDT330X=m CONFIG_DVB_LGDT3305=m CONFIG_DVB_S5H1411=m @@ -2340,7 +2342,6 @@ CONFIG_MACH_NO_WESTBRIDGE=y # CONFIG_SPEAKUP is not set # CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4 is not set # CONFIG_X86_PLATFORM_DEVICES is not set -# CONFIG_HWSPINLOCK is not set # # Firmware Drivers diff --git a/projects/ION/linux/linux.x86_64.conf b/projects/ION/linux/linux.x86_64.conf index 09ce547ec6..187f7953fd 100644 --- a/projects/ION/linux/linux.x86_64.conf +++ b/projects/ION/linux/linux.x86_64.conf @@ -1,6 +1,6 @@ # # Automatically generated make config: don't edit -# Linux/x86_64 2.6.38-rc8 Kernel Configuration +# Linux/x86_64 2.6.38 Kernel Configuration # CONFIG_64BIT=y # CONFIG_X86_32 is not set @@ -1453,6 +1453,7 @@ CONFIG_MEDIA_TUNER_TEA5767=y CONFIG_MEDIA_TUNER_MT20XX=y CONFIG_MEDIA_TUNER_MT2060=m CONFIG_MEDIA_TUNER_MT2266=m +CONFIG_MEDIA_TUNER_MT2131=m CONFIG_MEDIA_TUNER_QT1010=m CONFIG_MEDIA_TUNER_XC2028=y CONFIG_MEDIA_TUNER_XC5000=y @@ -1552,7 +1553,7 @@ CONFIG_DVB_MANTIS=y # # Supported nGene Adapters # -# CONFIG_DVB_NGENE is not set +CONFIG_DVB_NGENE=m # # Supported DVB Frontends @@ -1611,6 +1612,7 @@ CONFIG_DVB_STV0297=m # # ATSC (North American/Korean Terrestrial/Cable DTV) frontends # +CONFIG_DVB_LGDT330X=m CONFIG_DVB_LGDT3305=m CONFIG_DVB_S5H1411=m @@ -2283,7 +2285,6 @@ CONFIG_MACH_NO_WESTBRIDGE=y # CONFIG_SPEAKUP is not set # CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4 is not set # CONFIG_X86_PLATFORM_DEVICES is not set -# CONFIG_HWSPINLOCK is not set # # Firmware Drivers diff --git a/projects/Intel/linux/linux.i386.conf b/projects/Intel/linux/linux.i386.conf index c90c1923f6..71ff023fcb 100644 --- a/projects/Intel/linux/linux.i386.conf +++ b/projects/Intel/linux/linux.i386.conf @@ -1,6 +1,6 @@ # # Automatically generated make config: don't edit -# Linux/i386 2.6.38-rc8 Kernel Configuration +# Linux/i386 2.6.38 Kernel Configuration # # CONFIG_64BIT is not set CONFIG_X86_32=y @@ -1484,6 +1484,7 @@ CONFIG_MEDIA_TUNER_TEA5767=y CONFIG_MEDIA_TUNER_MT20XX=y CONFIG_MEDIA_TUNER_MT2060=m CONFIG_MEDIA_TUNER_MT2266=m +CONFIG_MEDIA_TUNER_MT2131=m CONFIG_MEDIA_TUNER_QT1010=m CONFIG_MEDIA_TUNER_XC2028=y CONFIG_MEDIA_TUNER_XC5000=y @@ -1581,7 +1582,7 @@ CONFIG_DVB_HOPPER=y # # Supported nGene Adapters # -# CONFIG_DVB_NGENE is not set +CONFIG_DVB_NGENE=m # # Supported DVB Frontends @@ -1639,6 +1640,7 @@ CONFIG_DVB_STV0297=m # # ATSC (North American/Korean Terrestrial/Cable DTV) frontends # +CONFIG_DVB_LGDT330X=m CONFIG_DVB_LGDT3305=m CONFIG_DVB_S5H1411=m @@ -2332,7 +2334,6 @@ CONFIG_MACH_NO_WESTBRIDGE=y # CONFIG_SPEAKUP is not set # CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4 is not set # CONFIG_X86_PLATFORM_DEVICES is not set -# CONFIG_HWSPINLOCK is not set # # Firmware Drivers diff --git a/projects/Intel/linux/linux.x86_64.conf b/projects/Intel/linux/linux.x86_64.conf index 2c691f0c31..91a55cb68d 100644 --- a/projects/Intel/linux/linux.x86_64.conf +++ b/projects/Intel/linux/linux.x86_64.conf @@ -1,6 +1,6 @@ # # Automatically generated make config: don't edit -# Linux/x86_64 2.6.38-rc8 Kernel Configuration +# Linux/x86_64 2.6.38 Kernel Configuration # CONFIG_64BIT=y # CONFIG_X86_32 is not set @@ -1428,6 +1428,7 @@ CONFIG_MEDIA_TUNER_TEA5767=y CONFIG_MEDIA_TUNER_MT20XX=y CONFIG_MEDIA_TUNER_MT2060=m CONFIG_MEDIA_TUNER_MT2266=m +CONFIG_MEDIA_TUNER_MT2131=m CONFIG_MEDIA_TUNER_QT1010=m CONFIG_MEDIA_TUNER_XC2028=y CONFIG_MEDIA_TUNER_XC5000=y @@ -1527,7 +1528,7 @@ CONFIG_DVB_MANTIS=y # # Supported nGene Adapters # -# CONFIG_DVB_NGENE is not set +CONFIG_DVB_NGENE=m # # Supported DVB Frontends @@ -1586,6 +1587,7 @@ CONFIG_DVB_STV0297=m # # ATSC (North American/Korean Terrestrial/Cable DTV) frontends # +CONFIG_DVB_LGDT330X=m CONFIG_DVB_LGDT3305=m CONFIG_DVB_S5H1411=m @@ -2270,7 +2272,6 @@ CONFIG_MACH_NO_WESTBRIDGE=y # CONFIG_SPEAKUP is not set # CONFIG_TOUCHSCREEN_SYNAPTICS_I2C_RMI4 is not set # CONFIG_X86_PLATFORM_DEVICES is not set -# CONFIG_HWSPINLOCK is not set # # Firmware Drivers From 2a2653191bce3a376dd116850d30ec7f0a37d0b6 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 03:07:20 +0100 Subject: [PATCH 03/83] config/path: move some optimizations to config/optimize Signed-off-by: Stephan Raue --- config/optimize | 29 +++++++++++++++++++++++++++++ config/path | 29 ----------------------------- 2 files changed, 29 insertions(+), 29 deletions(-) diff --git a/config/optimize b/config/optimize index ffd03af6a4..ddd6d83579 100644 --- a/config/optimize +++ b/config/optimize @@ -25,3 +25,32 @@ GCC_OPTIM="$GCC_OPTIM -flto" LD_OPTIM="$LD_OPTIM -fuse-linker-plugin" LD_OPTIM="$LD_OPTIM -fuse-ld=gold" LD_OPTIM="$LD_OPTIM -Wl,--as-needed" + +if [ "$DEBUG" = yes ]; then + TARGET_CFLAGS="$TARGET_CFLAGS -ggdb" + TARGET_CXXFLAGS="$TARGET_CXXFLAGS -ggdb" + TARGET_LDFLAGS="$TARGET_LDFLAGS -ggdb" +else + TARGET_CFLAGS="$TARGET_CFLAGS -fomit-frame-pointer" + TARGET_CXXFLAGS="$TARGET_CXXFLAGS -fomit-frame-pointer" + TARGET_LDFLAGS="$TARGET_LDFLAGS -s" +fi + +TARGET_CPPFLAGS= +TARGET_CFLAGS="$TARGET_CFLAGS -Wall -pipe $GCC_OPTIM $PROJECT_CFLAGS" +TARGET_CXXFLAGS="$TARGET_CFLAGS" +TARGET_LDFLAGS="$TARGET_LDFLAGS $GCC_OPTIM $LD_OPTIM" + +HOST_CPPFLAGS="" +HOST_CFLAGS="-O2 -Wall -pipe -I$ROOT/$TOOLCHAIN/include" +HOST_CXXFLAGS="$HOST_CFLAGS" +HOST_LDFLAGS="-Wl,-rpath,$ROOT/$TOOLCHAIN/lib -L$ROOT/$TOOLCHAIN/lib" + +# use -fPIC when necessary + case "`uname -m`" in + x86_64|ppc64|arm|armeb|armel) + HOST_CFLAGS="$HOST_CFLAGS -fPIC" + HOST_CXXFLAGS="$HOST_CXXFLAGS -fPIC" + HOST_LDFLAGS="$HOST_LDFLAGS -fPIC" + ;; + esac diff --git a/config/path b/config/path index 729e8cc286..f992b30df0 100644 --- a/config/path +++ b/config/path @@ -86,21 +86,6 @@ TARGET_STRIP=${TARGET_PREFIX}strip . config/optimize -TARGET_CPPFLAGS= -TARGET_CFLAGS="$TARGET_CFLAGS -Wall -pipe $GCC_OPTIM $PROJECT_CFLAGS" -TARGET_CXXFLAGS="$TARGET_CFLAGS" -TARGET_LDFLAGS="$TARGET_LDFLAGS $GCC_OPTIM $LD_OPTIM" - -if [ "$DEBUG" = yes ]; then - TARGET_CFLAGS="$TARGET_CFLAGS -ggdb" - TARGET_CXXFLAGS="$TARGET_CXXFLAGS -ggdb" - TARGET_LDFLAGS="$TARGET_LDFLAGS -ggdb" -else - TARGET_CFLAGS="$TARGET_CFLAGS -fomit-frame-pointer" - TARGET_CXXFLAGS="$TARGET_CXXFLAGS -fomit-frame-pointer" - TARGET_LDFLAGS="$TARGET_LDFLAGS -s" -fi - TARGET_PKG_CONFIG_PATH="" TARGET_PKG_CONFIG_LIBDIR="$SYSROOT_PREFIX/usr/lib/pkgconfig:$SYSROOT_PREFIX/usr/share/pkgconfig" TARGET_PKG_CONFIG_SYSROOT_DIR="$SYSROOT_PREFIX" @@ -116,20 +101,6 @@ HOST_RANLIB=ranlib HOST_OBJCOPY=objcopy HOST_STRIP=strip -HOST_CPPFLAGS="" -HOST_CFLAGS="-O2 -Wall -pipe -I$ROOT/$TOOLCHAIN/include" -HOST_CXXFLAGS="$HOST_CFLAGS" -HOST_LDFLAGS="-Wl,-rpath,$ROOT/$TOOLCHAIN/lib -L$ROOT/$TOOLCHAIN/lib" - -# use -fPIC when necessary - case "`uname -m`" in - x86_64|ppc64|arm|armeb|armel) - HOST_CFLAGS="$HOST_CFLAGS -fPIC" - HOST_CXXFLAGS="$HOST_CXXFLAGS -fPIC" - HOST_LDFLAGS="$HOST_LDFLAGS -fPIC" - ;; - esac - HOST_PKG_CONFIG_PATH="" HOST_PKG_CONFIG_LIBDIR="$ROOT/$TOOLCHAIN/lib/pkgconfig:$ROOT/$TOOLCHAIN/share/pkgconfig" HOST_PKG_CONFIG_SYSROOT_DIR="" From dbe90955514f9f69e72b10f9968db110d946e159 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 03:07:37 +0100 Subject: [PATCH 04/83] config/arch.x86_64: cleanup Signed-off-by: Stephan Raue --- config/arch.x86_64 | 1 - 1 file changed, 1 deletion(-) diff --git a/config/arch.x86_64 b/config/arch.x86_64 index 4875f386d0..e0d6b2ae0f 100644 --- a/config/arch.x86_64 +++ b/config/arch.x86_64 @@ -8,5 +8,4 @@ # setup ARCH specific *FLAGS TARGET_CFLAGS="-fPIC -march=$TARGET_CPU -m64" - TARGET_CXXFLAGS="$TARGET_CFLAGS" TARGET_LDFLAGS="-fPIC -march=$TARGET_CPU -m64" From 2a96df12ecf30106179f21a6a7f8ffedaa1b78f4 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 03:09:34 +0100 Subject: [PATCH 05/83] xproto: update to xproto-7.0.21 Signed-off-by: Stephan Raue --- packages/x11/proto/xproto/meta | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/x11/proto/xproto/meta b/packages/x11/proto/xproto/meta index 9ea1cb25fc..669399d008 100644 --- a/packages/x11/proto/xproto/meta +++ b/packages/x11/proto/xproto/meta @@ -19,7 +19,7 @@ ################################################################################ PKG_NAME="xproto" -PKG_VERSION="7.0.20" +PKG_VERSION="7.0.21" PKG_REV="1" PKG_ARCH="any" PKG_LICENSE="OSS" From 8a9c2837a13d59addb627df918c70699b2e4e91f Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 07:20:39 +0100 Subject: [PATCH 06/83] installer: fix file permissions, thanks to gr8rx Signed-off-by: Stephan Raue --- packages/tools/installer/scripts/installer | 0 1 file changed, 0 insertions(+), 0 deletions(-) mode change 100644 => 100755 packages/tools/installer/scripts/installer diff --git a/packages/tools/installer/scripts/installer b/packages/tools/installer/scripts/installer old mode 100644 new mode 100755 From 44aca974d74c83e20c5b958e0617a48560967471 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 10:27:11 +0100 Subject: [PATCH 07/83] v4l-utils: add patch to fix support for 'OTHER' protocol, thanks much to nektarios Signed-off-by: Stephan Raue --- .../v4l-utils-0.8.3-02-fix_OTHER_protocol.patch | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-02-fix_OTHER_protocol.patch diff --git a/packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-02-fix_OTHER_protocol.patch b/packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-02-fix_OTHER_protocol.patch new file mode 100644 index 0000000000..3521ae68d4 --- /dev/null +++ b/packages/sysutils/v4l-utils/patches/v4l-utils-0.8.3-02-fix_OTHER_protocol.patch @@ -0,0 +1,12 @@ +diff -Naur v4l-utils-0.8.3/utils/keytable/keytable.c v4l-utils-0.8.3.patch/utils/keytable/keytable.c +--- v4l-utils-0.8.3/utils/keytable/keytable.c 2011-02-09 23:04:27.000000000 +0100 ++++ v4l-utils-0.8.3.patch/utils/keytable/keytable.c 2011-03-23 10:24:09.391305852 +0100 +@@ -454,6 +454,8 @@ + ch_proto |= SONY; + else if (!strcasecmp(p,"lirc")) + ch_proto |= LIRC; ++ else if (!strcasecmp(p,"other")) ++ ch_proto |= OTHER; + else + goto err_inval; + p = strtok(NULL, ",;"); From 74e718042646a00a587ec4ce296f0241c45d0d64 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 10:27:39 +0100 Subject: [PATCH 08/83] linux: remove unneeded patch Signed-off-by: Stephan Raue --- ...panda_remove_unused_power_regulators.patch | 69 ------------------- 1 file changed, 69 deletions(-) delete mode 100644 packages/linux/patches/linux-2.6.39-next-20110321-322-panda_remove_unused_power_regulators.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-322-panda_remove_unused_power_regulators.patch b/packages/linux/patches/linux-2.6.39-next-20110321-322-panda_remove_unused_power_regulators.patch deleted file mode 100644 index 30693eca5b..0000000000 --- a/packages/linux/patches/linux-2.6.39-next-20110321-322-panda_remove_unused_power_regulators.patch +++ /dev/null @@ -1,69 +0,0 @@ -the pandaboard does not use the VUSIM or VAUX1 power regulators on the TWL6030 -and are left floating. if the VUSIM and VAUX1 power regulators are initilized, -noise on the unloaded regulators generates an overcurrent interrupt causing the -system to power down. this patch removes the initialization of the unused power -regulators of VUSIM and VAUX1. - -Signed-off-by: David Anders ---- - arch/arm/mach-omap2/board-omap4panda.c | 28 ---------------------------- - 1 files changed, 0 insertions(+), 28 deletions(-) - -diff --git a/arch/arm/mach-omap2/board-omap4panda.c b/arch/arm/mach-omap2/board-omap4panda.c -index e944025..abc913b 100644 ---- a/arch/arm/mach-omap2/board-omap4panda.c -+++ b/arch/arm/mach-omap2/board-omap4panda.c -@@ -220,19 +220,6 @@ static int __init omap4_twl6030_hsmmc_init(struct omap2_hsmmc_info *controllers) - return 0; - } - --static struct regulator_init_data omap4_panda_vaux1 = { -- .constraints = { -- .min_uV = 1000000, -- .max_uV = 3000000, -- .apply_uV = true, -- .valid_modes_mask = REGULATOR_MODE_NORMAL -- | REGULATOR_MODE_STANDBY, -- .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE -- | REGULATOR_CHANGE_MODE -- | REGULATOR_CHANGE_STATUS, -- }, --}; -- - static struct regulator_init_data omap4_panda_vaux2 = { - .constraints = { - .min_uV = 1200000, -@@ -288,19 +275,6 @@ static struct regulator_init_data omap4_panda_vpp = { - }, - }; - --static struct regulator_init_data omap4_panda_vusim = { -- .constraints = { -- .min_uV = 1200000, -- .max_uV = 2900000, -- .apply_uV = true, -- .valid_modes_mask = REGULATOR_MODE_NORMAL -- | REGULATOR_MODE_STANDBY, -- .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE -- | REGULATOR_CHANGE_MODE -- | REGULATOR_CHANGE_STATUS, -- }, --}; -- - static struct regulator_init_data omap4_panda_vana = { - .constraints = { - .min_uV = 2100000, -@@ -356,12 +330,10 @@ static struct twl4030_platform_data omap4_panda_twldata = { - /* Regulators */ - .vmmc = &omap4_panda_vmmc, - .vpp = &omap4_panda_vpp, -- .vusim = &omap4_panda_vusim, - .vana = &omap4_panda_vana, - .vcxio = &omap4_panda_vcxio, - .vdac = &omap4_panda_vdac, - .vusb = &omap4_panda_vusb, -- .vaux1 = &omap4_panda_vaux1, - .vaux2 = &omap4_panda_vaux2, - .vaux3 = &omap4_panda_vaux3, - .usb = &omap4_usbphy_data, --- 1.7.0.4 From 2d945f8f5018501915bae52305d0cdc9cd3e1cd6 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Wed, 23 Mar 2011 23:38:15 -0700 Subject: [PATCH 09/83] README: cleanup --- README | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/README b/README index e4ea56c5ea..4d6fb26362 100644 --- a/README +++ b/README @@ -1,8 +1,8 @@ http://www.OpenELEC.tv -The Open Embedded Linux Enterainment Center – OpenELEC.tv +OpenELEC - Open Embedded Linux Enterainment Center -OpenELEC.tv runs XBMC, a complete media center solution (xbmc.org). +OpenELEC runs XBMC, a complete media center solution (xbmc.org). The base system has been designed and built from the ground up to be as efficient as possible – consuming only a tiny footprint, cutting edge hardware support and a set-top box experience. @@ -52,4 +52,4 @@ freenode. Happy XBMC'ing -OpenELEC.tv Development Team +OpenELEC Development Team From d60feb1087e35c639bda29a7d61a38c6be1eae62 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Thu, 24 Mar 2011 13:43:43 +0100 Subject: [PATCH 10/83] linux: update alternate version to linux-2.6.39-next-20110324 Signed-off-by: Stephan Raue --- packages/linux/meta | 2 +- ...-20110321-051_add_ite-cir_driver-0.1.patch | 2998 ----------------- ...6.39-next-20110324-000_crosscompile.patch} | 0 ...next-20110324-002_bash_only_feature.patch} | 0 ...39-next-20110324-003-no_dev_console.patch} | 0 ...24-004_lower_undefined_mode_timeout.patch} | 0 ...t-20110324-005_kconfig_no_timestamp.patch} | 0 ....6.39-next-20110324-006_enable_utf8.patch} | 0 ...39-next-20110324-007_die_floppy_die.patch} | 0 ...08-hda_intel_prealloc_4mb_dmabuffer.patch} | 0 ...09_disable_i8042_check_on_apple_mac.patch} | 0 ...0110324-052-aureal_remote_quirk-0.1.patch} | 0 ...i-remote_all_keys_and_keychange-0.1.patch} | 0 ...ioneer_DVR-216D_failed_xfermode-0.1.patch} | 0 ...inux_omap_dss2_fix_SMC_instructions.patch} | 0 ...ext-20110324-716_mm-zero_swappiness.patch} | 0 16 files changed, 1 insertion(+), 2999 deletions(-) delete mode 100644 packages/linux/patches/linux-2.6.39-next-20110321-051_add_ite-cir_driver-0.1.patch rename packages/linux/patches/{linux-2.6.39-next-20110321-000_crosscompile.patch => linux-2.6.39-next-20110324-000_crosscompile.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-002_bash_only_feature.patch => linux-2.6.39-next-20110324-002_bash_only_feature.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-003-no_dev_console.patch => linux-2.6.39-next-20110324-003-no_dev_console.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-004_lower_undefined_mode_timeout.patch => linux-2.6.39-next-20110324-004_lower_undefined_mode_timeout.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-005_kconfig_no_timestamp.patch => linux-2.6.39-next-20110324-005_kconfig_no_timestamp.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-006_enable_utf8.patch => linux-2.6.39-next-20110324-006_enable_utf8.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-007_die_floppy_die.patch => linux-2.6.39-next-20110324-007_die_floppy_die.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-008-hda_intel_prealloc_4mb_dmabuffer.patch => linux-2.6.39-next-20110324-008-hda_intel_prealloc_4mb_dmabuffer.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-009_disable_i8042_check_on_apple_mac.patch => linux-2.6.39-next-20110324-009_disable_i8042_check_on_apple_mac.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-052-aureal_remote_quirk-0.1.patch => linux-2.6.39-next-20110324-052-aureal_remote_quirk-0.1.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-053_ati-remote_all_keys_and_keychange-0.1.patch => linux-2.6.39-next-20110324-053_ati-remote_all_keys_and_keychange-0.1.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-062-Pioneer_DVR-216D_failed_xfermode-0.1.patch => linux-2.6.39-next-20110324-062-Pioneer_DVR-216D_failed_xfermode-0.1.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-321-linux_omap_dss2_fix_SMC_instructions.patch => linux-2.6.39-next-20110324-321-linux_omap_dss2_fix_SMC_instructions.patch} (100%) rename packages/linux/patches/{linux-2.6.39-next-20110321-716_mm-zero_swappiness.patch => linux-2.6.39-next-20110324-716_mm-zero_swappiness.patch} (100%) diff --git a/packages/linux/meta b/packages/linux/meta index a437e2418d..7893e4bd6b 100644 --- a/packages/linux/meta +++ b/packages/linux/meta @@ -37,7 +37,7 @@ PKG_IS_ADDON="no" PKG_AUTORECONF="no" if [ "$LINUX_NEXT" = "yes" -a "$LINUX" = "default" ]; then - PKG_VERSION="2.6.39-next-20110321" + PKG_VERSION="2.6.39-next-20110324" PKG_URL="http://www.kernel.org/pub/linux/kernel/v2.6/$PKG_NAME-$PKG_VERSION.tar.bz2" # PKG_URL="http://www.kernel.org/pub/linux/kernel/v2.6/testing/$PKG_NAME-$PKG_VERSION.tar.bz2" PKG_URL="$OPENELEC_SRC/$PKG_NAME-$PKG_VERSION.tar.bz2" diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-051_add_ite-cir_driver-0.1.patch b/packages/linux/patches/linux-2.6.39-next-20110321-051_add_ite-cir_driver-0.1.patch deleted file mode 100644 index 338523f3d9..0000000000 --- a/packages/linux/patches/linux-2.6.39-next-20110321-051_add_ite-cir_driver-0.1.patch +++ /dev/null @@ -1,2998 +0,0 @@ -diff -Naur linux-2.6.38-rc5/drivers/media/rc/ite-cir.c linux-2.6.38-rc5.patch/drivers/media/rc/ite-cir.c ---- linux-2.6.38-rc5/drivers/media/rc/ite-cir.c 1970-01-01 01:00:00.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/media/rc/ite-cir.c 2011-02-22 03:19:26.753636264 +0100 -@@ -0,0 +1,1334 @@ -+/* -+ * Driver for ITE Tech Inc. IT8712F/IT8512 CIR -+ * -+ * Copyright (C) 2010 Juan J. Garcia de Soria -+ * -+ * Based on nuvoton-cir and lirc_it87 drivers. -+ * -+ * 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -+ * USA -+ */ -+ -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+#include -+ -+#include "ite-cir.h" -+ -+/* module parameters */ -+ -+/* debug level */ -+static int debug; -+module_param(debug, int, S_IRUGO | S_IWUSR); -+MODULE_PARM_DESC(debug, "Enable debugging output"); -+ -+/* low limit for RX carrier freq, Hz, 0 for no RX demodulation */ -+static int rx_low_carrier_freq; -+module_param(rx_low_carrier_freq, int, S_IRUGO | S_IWUSR); -+MODULE_PARM_DESC(rx_low_carrier_freq, "Override low RX carrier frequency, Hz, \ -+0 for no RX demodulation"); -+ -+/* high limit for RX carrier freq, Hz, 0 for no RX demodulation */ -+static int rx_high_carrier_freq; -+module_param(rx_high_carrier_freq, int, S_IRUGO | S_IWUSR); -+MODULE_PARM_DESC(rx_high_carrier_freq, "Override high RX carrier frequency, \ -+Hz, 0 for no RX demodulation"); -+ -+/* override tx carrier frequency */ -+static int tx_carrier_freq; -+module_param(tx_carrier_freq, int, S_IRUGO | S_IWUSR); -+MODULE_PARM_DESC(tx_carrier_freq, "Override TX carrier frequency, Hz"); -+ -+/* override tx duty cycle */ -+static int tx_duty_cycle; -+module_param(tx_duty_cycle, int, S_IRUGO | S_IWUSR); -+MODULE_PARM_DESC(tx_duty_cycle, "Override TX duty cycle, 1-100"); -+ -+/* override default sample period */ -+static long sample_period; -+module_param(sample_period, long, S_IRUGO | S_IWUSR); -+MODULE_PARM_DESC(sample_period, "Override carrier sample period, \ -+us"); -+ -+/* override detected model id */ -+static int model_number = -1; -+module_param(model_number, int, S_IRUGO | S_IWUSR); -+MODULE_PARM_DESC(model_number, "Use this model number, don't \ -+autodetect"); -+ -+ -+/* forward declaration */ -+static void ite_set_carrier_params(struct ite_dev *dev); -+ -+ -+/* IT8712F HW-specific functions */ -+ -+/* retrieve a bitmask of the current causes for a pending interrupt; this may -+ * be composed of ITE_IRQ_TX_FIFO, ITE_IRQ_RX_FIFO and ITE_IRQ_RX_FIFO_OVERRUN -+ * */ -+static int it87_get_irq_causes(struct ite_dev *dev) -+{ -+ u8 iflags; -+ int ret = 0; -+ -+ /* read the interrupt flags */ -+ iflags = inb(dev->cir_addr + IT87_IIR) & IT87_II; -+ -+ switch (iflags) { -+ case IT87_II_RXDS: -+ ret = ITE_IRQ_RX_FIFO; -+ break; -+ case IT87_II_RXFO: -+ ret = ITE_IRQ_RX_FIFO_OVERRUN; -+ break; -+ case IT87_II_TXLDL: -+ ret = ITE_IRQ_TX_FIFO; -+ break; -+ } -+ -+ return ret; -+} -+ -+/* set the carrier parameters; to be called with the spinlock held */ -+static void it87_set_carrier_params(struct ite_dev *dev, bool high_freq, -+ bool use_demodulator, u8 carrier_freq_bits, u8 allowance_bits, -+ u8 pulse_width_bits) -+{ -+ u8 val; -+ -+ /* program the RCR register */ -+ val = inb(dev->cir_addr + IT87_RCR) -+ & ~(IT87_HCFS | IT87_RXEND | IT87_RXDCR); -+ -+ if (high_freq) -+ val |= IT87_HCFS; -+ -+ if (use_demodulator) -+ val |= IT87_RXEND; -+ -+ val |= allowance_bits; -+ -+ outb(val, dev->cir_addr + IT87_RCR); -+ -+ /* program the TCR2 register */ -+ outb((carrier_freq_bits << IT87_CFQ_SHIFT) | pulse_width_bits, -+ dev->cir_addr + IT87_TCR2); -+} -+ -+/* read up to buf_size bytes from the RX FIFO; to be called with the spinlock -+ * held */ -+static int it87_get_rx_bytes(struct ite_dev *dev, u8 *buf, int buf_size) -+{ -+ int fifo, read = 0; -+ -+ /* read how many bytes are still in the FIFO */ -+ fifo = inb(dev->cir_addr + IT87_RSR) & IT87_RXBFC; -+ -+ while (fifo > 0 && buf_size > 0) { -+ *(buf++) = inb(dev->cir_addr + IT87_DR); -+ fifo--; -+ read++; -+ buf_size--; -+ } -+ -+ return read; -+} -+ -+/* return how many bytes we can send through the FIFO; this will be called -+ * with the device spinlock NOT HELD while waiting for the TX FIFO to get -+ * empty; let's expect this won't be a problem */ -+static int it87_get_tx_free_slots(struct ite_dev *dev) -+{ -+ return inb(dev->cir_addr + IT87_TSR) & IT87_TXBFC; -+} -+ -+/* put a byte to the TX fifo; this should be called with the spinlock held */ -+static void it87_put_tx_byte(struct ite_dev *dev, u8 value) -+{ -+ outb(value, dev->cir_addr + IT87_DR); -+} -+ -+/* idle the receiver so that we won't receive samples until another -+ pulse is detected; this must be called with the device spinlock held */ -+static void it87_idle_rx(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* disable streaming by clearing RXACT writing it as 1 */ -+ outb(inb(dev->cir_addr + IT87_RCR) | IT87_RXACT, -+ dev->cir_addr + IT87_RCR); -+ -+ /* clear the FIFO */ -+ outb(inb(dev->cir_addr + IT87_TCR1) | IT87_FIFOCLR, -+ dev->cir_addr + IT87_TCR1); -+} -+ -+/* disable the receiver; this must be called with the device spinlock held */ -+static void it87_disable_rx(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* disable the receiver interrupts */ -+ outb(inb(dev->cir_addr + IT87_IER) & ~(IT87_RDAIE | IT87_RFOIE), -+ dev->cir_addr + IT87_IER); -+ -+ /* disable the receiver */ -+ outb(inb(dev->cir_addr + IT87_RCR) & ~IT87_RXEN, -+ dev->cir_addr + IT87_RCR); -+ -+ /* clear the FIFO and RXACT (actually RXACT should have been cleared -+ * in the previous outb() call) */ -+ it87_idle_rx(dev); -+} -+ -+/* enable the receiver; this must be called with the device spinlock held */ -+static void it87_enable_rx(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* enable the receiver by setting RXEN */ -+ outb(inb(dev->cir_addr + IT87_RCR) | IT87_RXEN, -+ dev->cir_addr + IT87_RCR); -+ -+ /* just prepare it to idle for the next reception */ -+ it87_idle_rx(dev); -+ -+ /* enable the receiver interrupts and master enable flag */ -+ outb(inb(dev->cir_addr + IT87_IER) -+ | IT87_RDAIE | IT87_RFOIE | IT87_IEC, -+ dev->cir_addr + IT87_IER); -+} -+ -+/* disable the transmitter interrupt; this must be called with the device -+ * spinlock held */ -+static void it87_disable_tx_interrupt(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* disable the transmitter interrupts */ -+ outb(inb(dev->cir_addr + IT87_IER) & ~IT87_TLDLIE, -+ dev->cir_addr + IT87_IER); -+} -+ -+/* enable the transmitter interrupt; this must be called with the device -+ * spinlock held */ -+static void it87_enable_tx_interrupt(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* enable the transmitter interrupts and master enable flag */ -+ outb(inb(dev->cir_addr + IT87_IER) -+ | IT87_TLDLIE | IT87_IEC, -+ dev->cir_addr + IT87_IER); -+} -+ -+/* disable the device; this must be called with the device spinlock held */ -+static void it87_disable(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* clear out all interrupt enable flags */ -+ outb(inb(dev->cir_addr + IT87_IER) & ~(IT87_IEC | IT87_RFOIE | -+ IT87_RDAIE | IT87_TLDLIE), dev->cir_addr + IT87_IER); -+ -+ /* disable the receiver */ -+ it87_disable_rx(dev); -+ -+ /* erase the FIFO */ -+ outb(IT87_FIFOCLR | inb(dev->cir_addr + IT87_TCR1), -+ dev->cir_addr + IT87_TCR1); -+} -+ -+/* initialize the hardware */ -+static void it87_init_hardware(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* enable just the baud rate divisor register, -+ disabling all the interrupts at the same time */ -+ outb((inb(dev->cir_addr + IT87_IER) & ~(IT87_IEC | IT87_RFOIE | -+ IT87_RDAIE | IT87_TLDLIE)) | IT87_BR, -+ dev->cir_addr + IT87_IER); -+ -+ /* write out the baud rate divisor */ -+ outb(ITE_BAUDRATE_DIVISOR & 0xff, dev->cir_addr + IT87_BDLR); -+ outb((ITE_BAUDRATE_DIVISOR >> 8) & 0xff, dev->cir_addr + IT87_BDHR); -+ -+ /* disable the baud rate divisor register again */ -+ outb(inb(dev->cir_addr + IT87_IER) & ~IT87_BR, -+ dev->cir_addr + IT87_IER); -+ -+ /* program the RCR register defaults */ -+ outb(ITE_RXDCR_DEFAULT, dev->cir_addr + IT87_RCR); -+ -+ /* program the TCR1 register */ -+ outb(IT87_TXMPM_DEFAULT -+ | IT87_TXENDF -+ | IT87_TXRLE -+ | IT87_FIFOTL_DEFAULT -+ | IT87_FIFOCLR, dev->cir_addr + IT87_TCR1); -+ -+ /* program the carrier parameters */ -+ ite_set_carrier_params(dev); -+} -+ -+/* IT8512F on ITE8708 HW-specific functions */ -+ -+/* retrieve a bitmask of the current causes for a pending interrupt; this may -+ * be composed of ITE_IRQ_TX_FIFO, ITE_IRQ_RX_FIFO and ITE_IRQ_RX_FIFO_OVERRUN -+ * */ -+static int it8708_get_irq_causes(struct ite_dev *dev) -+{ -+ u8 iflags; -+ int ret = 0; -+ -+ /* read the interrupt flags */ -+ iflags = inb(dev->cir_addr + IT8708_C0IIR); -+ -+ if (iflags & IT85_TLDLI) -+ ret |= ITE_IRQ_TX_FIFO; -+ if (iflags & IT85_RDAI) -+ ret |= ITE_IRQ_RX_FIFO; -+ if (iflags & IT85_RFOI) -+ ret |= ITE_IRQ_RX_FIFO_OVERRUN; -+ -+ return ret; -+} -+ -+/* set the carrier parameters; to be called with the spinlock held */ -+static void it8708_set_carrier_params(struct ite_dev *dev, bool high_freq, -+ bool use_demodulator, u8 carrier_freq_bits, u8 allowance_bits, -+ u8 pulse_width_bits) -+{ -+ u8 val; -+ -+ /* program the C0CFR register, with HRAE=1 */ -+ outb(inb(dev->cir_addr + IT8708_BANKSEL) | IT8708_HRAE, dev->cir_addr -+ + IT8708_BANKSEL); -+ -+ val = (inb(dev->cir_addr + IT8708_C0CFR) -+ & ~(IT85_HCFS | IT85_CFQ)) | carrier_freq_bits; -+ -+ if (high_freq) -+ val |= IT85_HCFS; -+ -+ outb(val, dev->cir_addr + IT8708_C0CFR); -+ -+ outb(inb(dev->cir_addr + IT8708_BANKSEL) & ~IT8708_HRAE, dev->cir_addr -+ + IT8708_BANKSEL); -+ -+ /* program the C0RCR register */ -+ val = inb(dev->cir_addr + IT8708_C0RCR) -+ & ~(IT85_RXEND | IT85_RXDCR); -+ -+ if (use_demodulator) -+ val |= IT85_RXEND; -+ -+ val |= allowance_bits; -+ -+ outb(val, dev->cir_addr + IT8708_C0RCR); -+ -+ /* program the C0TCR register */ -+ val = inb(dev->cir_addr + IT8708_C0TCR) & ~IT85_TXMPW; -+ val |= pulse_width_bits; -+ outb(val, dev->cir_addr + IT8708_C0TCR); -+} -+ -+/* read up to buf_size bytes from the RX FIFO; to be called with the spinlock -+ * held */ -+static int it8708_get_rx_bytes(struct ite_dev *dev, u8 *buf, int buf_size) -+{ -+ int fifo, read = 0; -+ -+ /* read how many bytes are still in the FIFO */ -+ fifo = inb(dev->cir_addr + IT8708_C0RFSR) & IT85_RXFBC; -+ -+ while (fifo > 0 && buf_size > 0) { -+ *(buf++) = inb(dev->cir_addr + IT8708_C0DR); -+ fifo--; -+ read++; -+ buf_size--; -+ } -+ -+ return read; -+} -+ -+/* return how many bytes we can send through the FIFO; this will be called -+ * with the device spinlock NOT HELD while waiting for the TX FIFO to get -+ * empty; let's expect this won't be a problem */ -+static int it8708_get_tx_free_slots(struct ite_dev *dev) -+{ -+ return inb(dev->cir_addr + IT8708_C0TFSR) & IT85_TXFBC; -+} -+ -+/* put a byte to the TX fifo; this should be called with the spinlock held */ -+static void it8708_put_tx_byte(struct ite_dev *dev, u8 value) -+{ -+ outb(value, dev->cir_addr + IT8708_C0DR); -+} -+ -+/* idle the receiver so that we won't receive samples until another -+ pulse is detected; this must be called with the device spinlock held */ -+static void it8708_idle_rx(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* disable streaming by clearing RXACT writing it as 1 */ -+ outb(inb(dev->cir_addr + IT8708_C0RCR) | IT85_RXACT, -+ dev->cir_addr + IT8708_C0RCR); -+ -+ /* clear the FIFO */ -+ outb(inb(dev->cir_addr + IT8708_C0MSTCR) | IT85_FIFOCLR, -+ dev->cir_addr + IT8708_C0MSTCR); -+} -+ -+/* disable the receiver; this must be called with the device spinlock held */ -+static void it8708_disable_rx(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* disable the receiver interrupts */ -+ outb(inb(dev->cir_addr + IT8708_C0IER) & ~(IT85_RDAIE | IT85_RFOIE), -+ dev->cir_addr + IT8708_C0IER); -+ -+ /* disable the receiver */ -+ outb(inb(dev->cir_addr + IT8708_C0RCR) & ~IT85_RXEN, -+ dev->cir_addr + IT8708_C0RCR); -+ -+ /* clear the FIFO and RXACT (actually RXACT should have been cleared -+ * in the previous outb() call) */ -+ it8708_idle_rx(dev); -+} -+ -+/* enable the receiver; this must be called with the device spinlock held */ -+static void it8708_enable_rx(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* enable the receiver by setting RXEN */ -+ outb(inb(dev->cir_addr + IT8708_C0RCR) | IT85_RXEN, -+ dev->cir_addr + IT8708_C0RCR); -+ -+ /* just prepare it to idle for the next reception */ -+ it8708_idle_rx(dev); -+ -+ /* enable the receiver interrupts and master enable flag */ -+ outb(inb(dev->cir_addr + IT8708_C0IER) -+ | IT85_RDAIE | IT85_RFOIE | IT85_IEC, -+ dev->cir_addr + IT8708_C0IER); -+} -+ -+/* disable the transmitter interrupt; this must be called with the device -+ * spinlock held */ -+static void it8708_disable_tx_interrupt(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* disable the transmitter interrupts */ -+ outb(inb(dev->cir_addr + IT8708_C0IER) & ~IT85_TLDLIE, -+ dev->cir_addr + IT8708_C0IER); -+} -+ -+/* enable the transmitter interrupt; this must be called with the device -+ * spinlock held */ -+static void it8708_enable_tx_interrupt(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* enable the transmitter interrupts and master enable flag */ -+ outb(inb(dev->cir_addr + IT8708_C0IER) -+ | IT85_TLDLIE | IT85_IEC, -+ dev->cir_addr + IT8708_C0IER); -+} -+ -+/* disable the device; this must be called with the device spinlock held */ -+static void it8708_disable(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* clear out all interrupt enable flags */ -+ outb(inb(dev->cir_addr + IT8708_C0IER) & ~(IT85_IEC | IT85_RFOIE | -+ IT85_RDAIE | IT85_TLDLIE), dev->cir_addr + IT8708_C0IER); -+ -+ /* disable the receiver */ -+ it8708_disable_rx(dev); -+ -+ /* erase the FIFO */ -+ outb(IT85_FIFOCLR | inb(dev->cir_addr + IT8708_C0MSTCR), -+ dev->cir_addr + IT8708_C0MSTCR); -+} -+ -+/* initialize the hardware */ -+static void it8708_init_hardware(struct ite_dev *dev) -+{ -+ ite_dbg("%s called", __func__); -+ -+ /* disable all the interrupts */ -+ outb(inb(dev->cir_addr + IT8708_C0IER) & ~(IT85_IEC | IT85_RFOIE | -+ IT85_RDAIE | IT85_TLDLIE), dev->cir_addr + IT8708_C0IER); -+ -+ /* program the baud rate divisor */ -+ outb(inb(dev->cir_addr + IT8708_BANKSEL) | IT8708_HRAE, dev->cir_addr -+ + IT8708_BANKSEL); -+ -+ outb(ITE_BAUDRATE_DIVISOR & 0xff, dev->cir_addr + IT8708_C0BDLR); -+ outb((ITE_BAUDRATE_DIVISOR >> 8) & 0xff, -+ dev->cir_addr + IT8708_C0BDHR); -+ -+ outb(inb(dev->cir_addr + IT8708_BANKSEL) & ~IT8708_HRAE, dev->cir_addr -+ + IT8708_BANKSEL); -+ -+ -+ /* program the C0MSTCR register defaults */ -+ outb((inb(dev->cir_addr + IT8708_C0MSTCR) & ~(IT85_ILSEL | IT85_ILE | -+ IT85_FIFOTL | IT85_FIFOCLR | IT85_RESET)) | -+ IT85_FIFOTL_DEFAULT, dev->cir_addr + IT8708_C0MSTCR); -+ -+ /* program the C0RCR register defaults */ -+ outb((inb(dev->cir_addr + IT8708_C0RCR) & ~(IT85_RXEN | IT85_RDWOS | -+ IT85_RXEND | IT85_RXACT | IT85_RXDCR)) | -+ ITE_RXDCR_DEFAULT, dev->cir_addr + IT8708_C0RCR); -+ -+ /* program the C0TCR register defaults */ -+ outb((inb(dev->cir_addr + IT8708_C0TCR) & ~(IT85_TXMPM | IT85_TXMPW)) -+ | IT85_TXRLE | IT85_TXENDF | IT85_TXMPM_DEFAULT | -+ IT85_TXMPW_DEFAULT, dev->cir_addr + IT8708_C0TCR); -+ -+ /* program the carrier parameters */ -+ ite_set_carrier_params(dev); -+} -+ -+ -+ -+ -+/* supported models and their parameters */ -+static const struct ite_dev_params ite_dev_descs[] = { -+ { /* 0: ITE8704, ITE8713 */ -+ .model = "ITE8704/ITE8713 CIR transceiver", -+ .io_region_size = IT87_IOREG_LENGTH, -+ .hw_tx_capable = true, -+ .sample_period = (u32)(1000000000ULL / 115200), -+ .tx_carrier_freq = 38000, -+ .tx_duty_cycle = 33, -+ .rx_low_carrier_freq = 0, -+ .rx_high_carrier_freq = 0, -+ -+ /* operations */ -+ .get_irq_causes = it87_get_irq_causes, -+ .enable_rx = it87_enable_rx, -+ .idle_rx = it87_idle_rx, -+ .disable_rx = it87_idle_rx, -+ .get_rx_bytes = it87_get_rx_bytes, -+ .enable_tx_interrupt = it87_enable_tx_interrupt, -+ .disable_tx_interrupt = it87_disable_tx_interrupt, -+ .get_tx_free_slots = it87_get_tx_free_slots, -+ .put_tx_byte = it87_put_tx_byte, -+ .disable = it87_disable, -+ .init_hardware = it87_init_hardware, -+ .set_carrier_params = it87_set_carrier_params, -+ }, -+ { /* 1: ITE8708 */ -+ .model = "ITE8708 CIR transceiver", -+ .io_region_size = IT8708_IOREG_LENGTH, -+ .hw_tx_capable = true, -+ .sample_period = (u32)(1000000000ULL / 115200), -+ .tx_carrier_freq = 38000, -+ .tx_duty_cycle = 33, -+ .rx_low_carrier_freq = 0, -+ .rx_high_carrier_freq = 0, -+ -+ /* operations */ -+ .get_irq_causes = it8708_get_irq_causes, -+ .enable_rx = it8708_enable_rx, -+ .idle_rx = it8708_idle_rx, -+ .disable_rx = it8708_idle_rx, -+ .get_rx_bytes = it8708_get_rx_bytes, -+ .enable_tx_interrupt = it8708_enable_tx_interrupt, -+ .disable_tx_interrupt = it8708_disable_tx_interrupt, -+ .get_tx_free_slots = it8708_get_tx_free_slots, -+ .put_tx_byte = it8708_put_tx_byte, -+ .disable = it8708_disable, -+ .init_hardware = it8708_init_hardware, -+ .set_carrier_params = it8708_set_carrier_params, -+ }, -+}; -+ -+/* HW-independent code functions */ -+ -+/* check whether carrier frequency is high frequency */ -+static inline bool ite_is_high_carrier_freq(unsigned int freq) -+{ -+ return freq >= ITE_HCF_MIN_CARRIER_FREQ; -+} -+ -+/* get the bits required to program the carrier frequency in CFQ bits, -+ * unshifted */ -+static u8 ite_get_carrier_freq_bits(unsigned int freq) -+{ -+ if (ite_is_high_carrier_freq(freq)) { -+ if (freq < 425000) -+ return ITE_CFQ_400; -+ else if (freq < 465000) -+ return ITE_CFQ_450; -+ else if (freq < 490000) -+ return ITE_CFQ_480; -+ else -+ return ITE_CFQ_500; -+ } else { -+ /* trim to limits */ -+ if (freq < ITE_LCF_MIN_CARRIER_FREQ) -+ freq = ITE_LCF_MIN_CARRIER_FREQ; -+ if (freq > ITE_LCF_MAX_CARRIER_FREQ) -+ freq = ITE_LCF_MAX_CARRIER_FREQ; -+ -+ /* convert to kHz and subtract the base freq */ -+ freq = DIV_ROUND_CLOSEST(freq - ITE_LCF_MIN_CARRIER_FREQ, -+ 1000); -+ -+ return (u8) freq; -+ } -+} -+ -+/* get the bits required to program the pulse with in TXMPW */ -+static u8 ite_get_pulse_width_bits(unsigned int freq, int duty_cycle) -+{ -+ unsigned long period_ns, on_ns; -+ -+ /* sanitize freq into range */ -+ if (freq < ITE_LCF_MIN_CARRIER_FREQ) -+ freq = ITE_LCF_MIN_CARRIER_FREQ; -+ if (freq > ITE_HCF_MAX_CARRIER_FREQ) -+ freq = ITE_HCF_MAX_CARRIER_FREQ; -+ -+ period_ns = 1000000000UL / freq; -+ on_ns = period_ns * duty_cycle / 100; -+ -+ if (ite_is_high_carrier_freq(freq)) { -+ if (on_ns < 750) -+ return ITE_TXMPW_A; -+ else if (on_ns < 850) -+ return ITE_TXMPW_B; -+ else if (on_ns < 950) -+ return ITE_TXMPW_C; -+ else if (on_ns < 1080) -+ return ITE_TXMPW_D; -+ else -+ return ITE_TXMPW_E; -+ } else { -+ if (on_ns < 6500) -+ return ITE_TXMPW_A; -+ else if (on_ns < 7850) -+ return ITE_TXMPW_B; -+ else if (on_ns < 9650) -+ return ITE_TXMPW_C; -+ else if (on_ns < 11950) -+ return ITE_TXMPW_D; -+ else -+ return ITE_TXMPW_E; -+ } -+} -+ -+/* set all the rx/tx carrier parameters; this must be called with the device -+ * spinlock held */ -+static void ite_set_carrier_params(struct ite_dev *dev) -+{ -+ unsigned int freq, low_freq, high_freq; -+ int allowance; -+ bool use_demodulator; -+ bool for_tx = dev->transmitting; -+ -+ ite_dbg("%s called", __func__); -+ -+ if (for_tx) { -+ /* we don't need no stinking calculations */ -+ freq = dev->params.tx_carrier_freq; -+ allowance = ITE_RXDCR_DEFAULT; -+ use_demodulator = false; -+ } else { -+ low_freq = dev->params.rx_low_carrier_freq; -+ high_freq = dev->params.rx_high_carrier_freq; -+ -+ if (low_freq == 0) { -+ /* don't demodulate */ -+ freq = ITE_DEFAULT_CARRIER_FREQ; -+ allowance = ITE_RXDCR_DEFAULT; -+ use_demodulator = false; -+ } else { -+ /* calculate the middle freq */ -+ freq = (low_freq + high_freq) / 2; -+ -+ /* calculate the allowance */ -+ allowance = DIV_ROUND_CLOSEST( -+ 10000 * (high_freq - low_freq), -+ ITE_RXDCR_PER_10000_STEP * -+ (high_freq + low_freq)); -+ -+ if (allowance < 1) -+ allowance = 1; -+ if (allowance > ITE_RXDCR_MAX) -+ allowance = ITE_RXDCR_MAX; -+ } -+ } -+ -+ /* set the carrier parameters in a device-dependent way */ -+ dev->params.set_carrier_params(dev, ite_is_high_carrier_freq(freq), -+ use_demodulator, ite_get_carrier_freq_bits(freq), allowance, -+ ite_get_pulse_width_bits(freq, dev->params.tx_duty_cycle)); -+} -+ -+/* decode raw bytes as received by the hardware, and push them to the ir-core -+ * layer */ -+static void ite_decode_bytes(struct ite_dev *dev, const u8 *data, int -+ length) -+{ -+ u32 sample_period; -+ unsigned long *ldata; -+ unsigned int next_one, next_zero, size; -+ DEFINE_IR_RAW_EVENT(ev); -+ -+ if (length == 0) -+ return; -+ -+ sample_period = dev->params.sample_period; -+ ldata = (unsigned long *) data; -+ size = length << 3; -+ next_one = generic_find_next_le_bit(ldata, size, 0); -+ if (next_one > 0) { -+ ev.pulse = true; -+ ev.duration = ITE_BITS_TO_NS(next_one, sample_period); -+ ir_raw_event_store_with_filter(dev->rdev, &ev); -+ } -+ -+ while (next_one < size) { -+ next_zero = generic_find_next_zero_le_bit(ldata, -+ size, next_one + 1); -+ ev.pulse = false; -+ ev.duration = ITE_BITS_TO_NS(next_zero - next_one, -+ sample_period); -+ ir_raw_event_store_with_filter(dev->rdev, &ev); -+ -+ if (next_zero < size) { -+ next_one = generic_find_next_le_bit(ldata, -+ size, next_zero + 1); -+ ev.pulse = true; -+ ev.duration = ITE_BITS_TO_NS(next_one - next_zero, -+ sample_period); -+ ir_raw_event_store_with_filter(dev->rdev, &ev); -+ } else -+ next_one = size; -+ } -+ -+ ir_raw_event_handle(dev->rdev); -+ -+ ite_dbg_verbose("decoded %d bytes.", length); -+} -+ -+/* interrupt service routine for incoming and outgoing CIR data */ -+static irqreturn_t ite_cir_isr(int irq, void *data) -+{ -+ struct ite_dev *dev = data; -+ unsigned long flags; -+ irqreturn_t ret = IRQ_RETVAL(IRQ_NONE); -+ u8 rx_buf[ITE_RX_FIFO_LEN]; -+ int rx_bytes; -+ int iflags; -+ -+ ite_dbg_verbose("%s firing", __func__); -+ -+ /* grab the spinlock */ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* read the interrupt flags */ -+ iflags = dev->params.get_irq_causes(dev); -+ -+ /* check for the receive interrupt */ -+ if (iflags & (ITE_IRQ_RX_FIFO | ITE_IRQ_RX_FIFO_OVERRUN)) { -+ /* read the FIFO bytes */ -+ rx_bytes = dev->params.get_rx_bytes(dev, rx_buf, -+ ITE_RX_FIFO_LEN); -+ -+ if (rx_bytes > 0) { -+ /* drop the spinlock, since the ir-core layer -+ * may call us back again through -+ * ite_s_idle() */ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ /* decode the data we've just received */ -+ ite_decode_bytes(dev, rx_buf, rx_bytes); -+ -+ /* reacquire the spinlock */ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* mark the interrupt as serviced */ -+ ret = IRQ_RETVAL(IRQ_HANDLED); -+ } -+ } else if (iflags & ITE_IRQ_TX_FIFO) { -+ /* FIFO space available interrupt */ -+ ite_dbg_verbose("got interrupt for TX FIFO"); -+ -+ /* wake any sleeping transmitter */ -+ wake_up_interruptible(&dev->tx_queue); -+ -+ /* mark the interrupt as serviced */ -+ ret = IRQ_RETVAL(IRQ_HANDLED); -+ } -+ -+ /* drop the spinlock */ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ ite_dbg_verbose("%s done returning %d", __func__, (int) ret); -+ -+ return ret; -+} -+ -+ -+/* set the rx carrier freq range, guess it's in Hz... */ -+static int ite_set_rx_carrier_range(struct rc_dev *rcdev, u32 carrier_low, u32 -+ carrier_high) -+{ -+ unsigned long flags; -+ struct ite_dev *dev = rcdev->priv; -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ dev->params.rx_low_carrier_freq = carrier_low; -+ dev->params.rx_high_carrier_freq = carrier_high; -+ ite_set_carrier_params(dev); -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ return 0; -+} -+ -+ -+/* set the tx carrier freq, guess it's in Hz... */ -+static int ite_set_tx_carrier(struct rc_dev *rcdev, u32 carrier) -+{ -+ unsigned long flags; -+ struct ite_dev *dev = rcdev->priv; -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ dev->params.tx_carrier_freq = carrier; -+ ite_set_carrier_params(dev); -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ return 0; -+} -+ -+/* set the tx duty cycle by controlling the pulse width */ -+static int ite_set_tx_duty_cycle(struct rc_dev *rcdev, u32 duty_cycle) -+{ -+ unsigned long flags; -+ struct ite_dev *dev = rcdev->priv; -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ dev->params.tx_duty_cycle = duty_cycle; -+ ite_set_carrier_params(dev); -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ return 0; -+} -+ -+/* transmit out IR pulses; what you get here is a batch of alternating -+ * pulse/space/pulse/space lengths that we should write out completely through -+ * the FIFO, blocking on a full FIFO */ -+static int ite_tx_ir(struct rc_dev *rcdev, int *txbuf, u32 n) -+{ -+ unsigned long flags; -+ struct ite_dev *dev = rcdev->priv; -+ bool is_pulse = false; -+ int remaining_us, fifo_avail, fifo_remaining, last_idx = 0; -+ int max_rle_us, next_rle_us; -+ int ret = n; -+ u8 last_sent[ITE_TX_FIFO_LEN]; -+ u8 val; -+ -+ ite_dbg("%s called", __func__); -+ -+ /* clear the array just in case */ -+ memset(last_sent, 0, ARRAY_SIZE(last_sent)); -+ -+ /* n comes in bytes; convert to ints */ -+ n /= sizeof(int); -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* let everybody know we're now transmitting */ -+ dev->transmitting = true; -+ -+ /* and set the carrier values for transmission */ -+ ite_set_carrier_params(dev); -+ -+ /* calculate how much time we can send in one byte */ -+ max_rle_us = (ITE_BAUDRATE_DIVISOR * dev->params.sample_period * -+ ITE_TX_MAX_RLE) / 1000; -+ -+ /* disable the receiver */ -+ dev->params.disable_rx(dev); -+ -+ /* this is where we'll begin filling in the FIFO, until it's full. -+ * then we'll just activate the interrupt, wait for it to wake us up -+ * again, disable it, continue filling the FIFO... until everything -+ * has been pushed out */ -+ fifo_avail = dev->params.get_tx_free_slots(dev); -+ -+ while (n > 0 && dev->in_use) { -+ /* transmit the next sample */ -+ is_pulse = !is_pulse; -+ remaining_us = *(txbuf++); -+ n--; -+ -+ /* repeat while the pulse is non-zero length */ -+ while (remaining_us > 0 && dev->in_use) { -+ if (remaining_us > max_rle_us) -+ next_rle_us = max_rle_us; -+ else -+ next_rle_us = remaining_us; -+ remaining_us -= next_rle_us; -+ -+ /* check what's the length we have to pump out */ -+ val = (ITE_TX_MAX_RLE * next_rle_us) / max_rle_us; -+ -+ /* put it into the sent buffer */ -+ last_sent[last_idx++] = val; -+ last_idx &= (ITE_TX_FIFO_LEN); -+ -+ /* encode it for 7 bits */ -+ val = (val - 1) & ITE_TX_RLE_MASK; -+ -+ /* take into account pulse/space prefix */ -+ if (is_pulse) -+ val |= ITE_TX_PULSE; -+ else -+ val |= ITE_TX_SPACE; -+ -+ /* if we get to 0 available, read again, just in case -+ * some other slot got freed */ -+ if (fifo_avail <= 0) { -+ fifo_avail = -+ dev->params.get_tx_free_slots(dev); -+ } -+ -+ /* if it's still full */ -+ if (fifo_avail <= 0) { -+ /* enable the tx interrupt */ -+ dev->params.enable_tx_interrupt(dev); -+ -+ /* drop the spinlock */ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ /* wait for the FIFO to empty enough */ -+ wait_event_interruptible(dev->tx_queue, -+ (fifo_avail = -+ dev->params.get_tx_free_slots(dev)) -+ >= 8); -+ -+ /* get the spinlock again */ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* disable the tx interrupt again. */ -+ dev->params.disable_tx_interrupt(dev); -+ } -+ -+ /* now send the byte through the FIFO */ -+ dev->params.put_tx_byte(dev, val); -+ fifo_avail--; -+ } -+ } -+ -+ /* wait and don't return until the whole FIFO has been sent out; -+ * otherwise we could configure the RX carrier params instead of the -+ * TX ones while the transmission is still being performed! */ -+ fifo_remaining = ITE_TX_FIFO_LEN - -+ dev->params.get_tx_free_slots(dev); -+ remaining_us = 0; -+ while (fifo_remaining > 0) { -+ fifo_remaining--; -+ last_idx--; -+ last_idx &= (ITE_TX_FIFO_LEN - 1); -+ remaining_us += last_sent[last_idx]; -+ } -+ remaining_us = (remaining_us * max_rle_us) / (ITE_TX_MAX_RLE); -+ -+ /* drop the spinlock while we sleep */ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ /* sleep remaining_us microseconds */ -+ mdelay(DIV_ROUND_UP(remaining_us, 1000)); -+ -+ /* reacquire the spinlock */ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* now we're not transmitting anymore */ -+ dev->transmitting = false; -+ -+ /* and set the carrier values for reception */ -+ ite_set_carrier_params(dev); -+ -+ /* reenable the receiver */ -+ if (dev->in_use) -+ dev->params.enable_rx(dev); -+ -+ /* notify transmission end */ -+ wake_up_interruptible(&dev->tx_ended); -+ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ return ret; -+} -+ -+/* idle the receiver if needed */ -+static void ite_s_idle(struct rc_dev *rcdev, bool enable) -+{ -+ unsigned long flags; -+ struct ite_dev *dev = rcdev->priv; -+ -+ ite_dbg("%s called", __func__); -+ -+ if (enable) { -+ spin_lock_irqsave(&dev->lock, flags); -+ dev->params.idle_rx(dev); -+ spin_unlock_irqrestore(&dev->lock, flags); -+ } -+} -+ -+/* activate the device for use */ -+static int ite_open(struct rc_dev *rcdev) -+{ -+ struct ite_dev *dev = rcdev->priv; -+ unsigned long flags; -+ -+ ite_dbg("%s called", __func__); -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ dev->in_use = true; -+ -+ /* enable the receiver */ -+ dev->params.enable_rx(dev); -+ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ return 0; -+} -+ -+/* deactivate the device for use */ -+static void ite_close(struct rc_dev *rcdev) -+{ -+ struct ite_dev *dev = rcdev->priv; -+ unsigned long flags; -+ -+ ite_dbg("%s called", __func__); -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ dev->in_use = false; -+ -+ /* wait for any transmission to end */ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ wait_event_interruptible(dev->tx_ended, !dev->transmitting); -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ dev->params.disable(dev); -+ -+ spin_unlock_irqrestore(&dev->lock, flags); -+} -+ -+/* allocate memory, probe hardware, and initialize everything */ -+static int ite_probe(struct pnp_dev *pdev, const struct pnp_device_id -+ *dev_id) -+{ -+ const struct ite_dev_params *dev_desc = NULL; -+ struct ite_dev *itdev = NULL; -+ struct rc_dev *rdev = NULL; -+ int ret = -ENOMEM; -+ int model_no; -+ -+ ite_dbg("%s called", __func__); -+ -+ itdev = kzalloc(sizeof(struct ite_dev), GFP_KERNEL); -+ if (!itdev) -+ return ret; -+ -+ /* input device for IR remote (and tx) */ -+ rdev = rc_allocate_device(); -+ if (!rdev) -+ goto failure; -+ -+ ret = -ENODEV; -+ -+ -+ /* get the model number */ -+ model_no = (int) dev_id->driver_data; -+ ite_pr(KERN_NOTICE, "Auto-detected model: %s\n", -+ ite_dev_descs[model_no].model); -+ -+ if (model_number >= 0 && model_number -+ < ARRAY_SIZE(ite_dev_descs)) { -+ model_no = model_number; -+ ite_pr(KERN_NOTICE, "The model has been fixed by a module \ -+parameter."); -+ } -+ -+ ite_pr(KERN_NOTICE, "Using model: %s\n", -+ ite_dev_descs[model_no].model); -+ -+ /* get the description for the device */ -+ dev_desc = &ite_dev_descs[model_no]; -+ -+ -+ /* validate pnp resources */ -+ if (!pnp_port_valid(pdev, 0) || -+ pnp_port_len(pdev, 0) != dev_desc->io_region_size) { -+ dev_err(&pdev->dev, "IR PNP Port not valid!\n"); -+ goto failure; -+ } -+ -+ if (!pnp_irq_valid(pdev, 0)) { -+ dev_err(&pdev->dev, "PNP IRQ not valid!\n"); -+ goto failure; -+ } -+ -+ /* store resource values */ -+ itdev->cir_addr = pnp_port_start(pdev, 0); -+ itdev->cir_irq = pnp_irq(pdev, 0); -+ -+ /* initialize spinlocks */ -+ spin_lock_init(&itdev->lock); -+ -+ /* initialize raw event */ -+ init_ir_raw_event(&itdev->rawir); -+ -+ ret = -EBUSY; -+ /* now claim resources */ -+ if (!request_region(itdev->cir_addr, -+ dev_desc->io_region_size, ITE_DRIVER_NAME)) -+ goto failure; -+ -+ if (request_irq(itdev->cir_irq, ite_cir_isr, IRQF_SHARED, -+ ITE_DRIVER_NAME, (void *)itdev)) -+ goto failure; -+ -+ /* set driver data into the pnp device */ -+ pnp_set_drvdata(pdev, itdev); -+ itdev->pdev = pdev; -+ -+ /* initialize waitqueues for transmission */ -+ init_waitqueue_head(&itdev->tx_queue); -+ init_waitqueue_head(&itdev->tx_ended); -+ -+ /* copy model-specific parameters */ -+ itdev->params = *dev_desc; -+ -+ /* apply any overrides */ -+ if (sample_period > 0) -+ itdev->params.sample_period = sample_period; -+ -+ if (tx_carrier_freq > 0) -+ itdev->params.tx_carrier_freq = tx_carrier_freq; -+ -+ if (tx_duty_cycle > 0 && tx_duty_cycle <= 100) -+ itdev->params.tx_duty_cycle = tx_duty_cycle; -+ -+ if (rx_low_carrier_freq > 0) -+ itdev->params.rx_low_carrier_freq = rx_low_carrier_freq; -+ -+ if (rx_high_carrier_freq > 0) -+ itdev->params.rx_high_carrier_freq = rx_high_carrier_freq; -+ -+ /* print out parameters */ -+ ite_pr(KERN_NOTICE, "TX-capable: %d\n", (int) -+ itdev->params.hw_tx_capable); -+ ite_pr(KERN_NOTICE, "Sample period (ns): %ld\n", (long) -+ itdev->params.sample_period); -+ ite_pr(KERN_NOTICE, "TX carrier frequency (Hz): %d\n", (int) -+ itdev->params.tx_carrier_freq); -+ ite_pr(KERN_NOTICE, "TX duty cycle (%%): %d\n", (int) -+ itdev->params.tx_duty_cycle); -+ ite_pr(KERN_NOTICE, "RX low carrier frequency (Hz): %d\n", (int) -+ itdev->params.rx_low_carrier_freq); -+ ite_pr(KERN_NOTICE, "RX high carrier frequency (Hz): %d\n", (int) -+ itdev->params.rx_high_carrier_freq); -+ -+ /* set up hardware initial state */ -+ itdev->params.init_hardware(itdev); -+ -+ /* set up ir-core props */ -+ rdev->priv = itdev; -+ rdev->driver_type = RC_DRIVER_IR_RAW; -+ rdev->allowed_protos = RC_TYPE_ALL; -+ rdev->open = ite_open; -+ rdev->close = ite_close; -+ rdev->s_idle = ite_s_idle; -+ rdev->s_rx_carrier_range = ite_set_rx_carrier_range; -+ rdev->min_timeout = ITE_MIN_IDLE_TIMEOUT; -+ rdev->max_timeout = ITE_MAX_IDLE_TIMEOUT; -+ rdev->timeout = ITE_IDLE_TIMEOUT; -+ rdev->rx_resolution = rdev->tx_resolution = ITE_BAUDRATE_DIVISOR * -+ itdev->params.sample_period; -+ -+ /* set up transmitter related values if needed */ -+ if (itdev->params.hw_tx_capable) { -+ rdev->tx_ir = ite_tx_ir; -+ rdev->s_tx_carrier = ite_set_tx_carrier; -+ rdev->s_tx_duty_cycle = ite_set_tx_duty_cycle; -+ } -+ -+ rdev->input_name = dev_desc->model; -+ rdev->input_id.bustype = BUS_HOST; -+ rdev->input_id.vendor = PCI_VENDOR_ID_ITE; -+ rdev->input_id.product = 0; -+ rdev->input_id.version = 0; -+ rdev->driver_name = ITE_DRIVER_NAME; -+ rdev->map_name = RC_MAP_RC6_MCE; -+ -+ ret = rc_register_device(rdev); -+ if (ret) -+ goto failure; -+ -+ itdev->rdev = rdev; -+ ite_pr(KERN_NOTICE, "driver has been successfully loaded\n"); -+ -+ return 0; -+ -+failure: -+ if (itdev->cir_irq) -+ free_irq(itdev->cir_irq, itdev); -+ if (itdev->cir_addr) -+ release_region(itdev->cir_addr, itdev->params.io_region_size); -+ -+ rc_free_device(rdev); -+ kfree(itdev); -+ -+ return ret; -+} -+ -+static void __devexit ite_remove(struct pnp_dev *pdev) -+{ -+ struct ite_dev *dev = pnp_get_drvdata(pdev); -+ unsigned long flags; -+ -+ ite_dbg("%s called", __func__); -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* disable hardware */ -+ dev->params.disable(dev); -+ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ /* free resources */ -+ free_irq(dev->cir_irq, dev); -+ release_region(dev->cir_addr, dev->params.io_region_size); -+ -+ rc_unregister_device(dev->rdev); -+ -+ kfree(dev); -+} -+ -+static int ite_suspend(struct pnp_dev *pdev, pm_message_t state) -+{ -+ struct ite_dev *dev = pnp_get_drvdata(pdev); -+ unsigned long flags; -+ -+ ite_dbg("%s called", __func__); -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* disable all interrupts */ -+ dev->params.disable(dev); -+ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ return 0; -+} -+ -+static int ite_resume(struct pnp_dev *pdev) -+{ -+ int ret = 0; -+ struct ite_dev *dev = pnp_get_drvdata(pdev); -+ unsigned long flags; -+ -+ ite_dbg("%s called", __func__); -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ if (dev->transmitting) { -+ /* wake up the transmitter */ -+ wake_up_interruptible(&dev->tx_queue); -+ } else { -+ /* enable the receiver */ -+ dev->params.enable_rx(dev); -+ } -+ -+ spin_unlock_irqrestore(&dev->lock, flags); -+ -+ return ret; -+} -+ -+static void ite_shutdown(struct pnp_dev *pdev) -+{ -+ struct ite_dev *dev = pnp_get_drvdata(pdev); -+ unsigned long flags; -+ -+ ite_dbg("%s called", __func__); -+ -+ spin_lock_irqsave(&dev->lock, flags); -+ -+ /* disable all interrupts */ -+ dev->params.disable(dev); -+ -+ spin_unlock_irqrestore(&dev->lock, flags); -+} -+ -+static const struct pnp_device_id ite_ids[] = { -+ { "ITE8704", 0 }, /* Default model */ -+ { "ITE8713", 0 }, /* CIR found in EEEBox 1501U */ -+ { "ITE8708", 1 }, /* Bridged IT8512 */ -+ { "", 0 }, -+}; -+ -+static struct pnp_driver ite_driver = { -+ .name = ITE_DRIVER_NAME, -+ .id_table = ite_ids, -+ .probe = ite_probe, -+ .remove = __devexit_p(ite_remove), -+ .suspend = ite_suspend, -+ .resume = ite_resume, -+ .shutdown = ite_shutdown, -+}; -+ -+int ite_init(void) -+{ -+ return pnp_register_driver(&ite_driver); -+} -+ -+void ite_exit(void) -+{ -+ pnp_unregister_driver(&ite_driver); -+} -+ -+MODULE_DEVICE_TABLE(pnp, ite_ids); -+MODULE_DESCRIPTION("ITE Tech Inc. IT8712F/ITE8512F CIR driver"); -+ -+MODULE_AUTHOR("Juan J. Garcia de Soria "); -+MODULE_LICENSE("GPL"); -+ -+module_init(ite_init); -+module_exit(ite_exit); -diff -Naur linux-2.6.38-rc5/drivers/media/rc/ite-cir.h linux-2.6.38-rc5.patch/drivers/media/rc/ite-cir.h ---- linux-2.6.38-rc5/drivers/media/rc/ite-cir.h 1970-01-01 01:00:00.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/media/rc/ite-cir.h 2011-02-22 03:19:26.755636229 +0100 -@@ -0,0 +1,446 @@ -+/* -+ * Driver for ITE Tech Inc. IT8712F/IT8512F CIR -+ * -+ * Copyright (C) 2010 Juan J. Garcia de Soria -+ * -+ * Based on nuvoton-cir and lirc_it87 drivers. -+ * -+ * 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -+ * USA -+ */ -+ -+/* platform driver name to register */ -+#define ITE_DRIVER_NAME "ite-cir" -+ -+/* logging macros */ -+#define ite_pr(level, text, ...) \ -+ printk(level KBUILD_MODNAME ": " text, ## __VA_ARGS__) -+ -+#define ite_dbg(text, ...) \ -+ if (debug) \ -+ printk(KERN_DEBUG \ -+ KBUILD_MODNAME ": " text "\n" , ## __VA_ARGS__) -+ -+#define ite_dbg_verbose(text, ...) \ -+ if (debug > 1) \ -+ printk(KERN_DEBUG \ -+ KBUILD_MODNAME ": " text "\n" , ## __VA_ARGS__) -+ -+/* FIFO sizes */ -+#define ITE_TX_FIFO_LEN 32 -+#define ITE_RX_FIFO_LEN 32 -+ -+/* interrupt types */ -+#define ITE_IRQ_TX_FIFO 1 -+#define ITE_IRQ_RX_FIFO 2 -+#define ITE_IRQ_RX_FIFO_OVERRUN 4 -+ -+/* forward declaration */ -+struct ite_dev; -+ -+/* struct for storing the parameters of different recognized devices */ -+struct ite_dev_params { -+ /* model of the device */ -+ const char *model; -+ -+ /* size of the I/O region */ -+ int io_region_size; -+ -+ /* true if the hardware supports transmission */ -+ bool hw_tx_capable; -+ -+ /* base sampling period, in ns */ -+ u32 sample_period; -+ -+ /* rx low carrier frequency, in Hz, 0 means no demodulation */ -+ unsigned int rx_low_carrier_freq; -+ -+ /* tx high carrier frequency, in Hz, 0 means no demodulation */ -+ unsigned int rx_high_carrier_freq; -+ -+ /* tx carrier frequency, in Hz */ -+ unsigned int tx_carrier_freq; -+ -+ /* duty cycle, 0-100 */ -+ int tx_duty_cycle; -+ -+ /* hw-specific operation function pointers; most of these must be -+ * called while holding the spin lock, except for the TX FIFO length -+ * one */ -+ -+ /* get pending interrupt causes */ -+ int (*get_irq_causes)(struct ite_dev *dev); -+ -+ /* enable rx */ -+ void (*enable_rx)(struct ite_dev *dev); -+ -+ /* make rx enter the idle state; keep listening for a pulse, but stop -+ * streaming space bytes */ -+ void (*idle_rx)(struct ite_dev *dev); -+ -+ /* disable rx completely */ -+ void (*disable_rx)(struct ite_dev *dev); -+ -+ /* read bytes from RX FIFO; return read count */ -+ int (*get_rx_bytes)(struct ite_dev *dev, u8 *buf, int buf_size); -+ -+ /* enable tx FIFO space available interrupt */ -+ void (*enable_tx_interrupt)(struct ite_dev *dev); -+ -+ /* disable tx FIFO space available interrupt */ -+ void (*disable_tx_interrupt)(struct ite_dev *dev); -+ -+ /* get number of available TX FIFO slots */ -+ int (*get_tx_free_slots)(struct ite_dev *dev); -+ -+ /* put a byte to the TX FIFO */ -+ void (*put_tx_byte)(struct ite_dev *dev, u8 value); -+ -+ /* disable hardware completely */ -+ void (*disable)(struct ite_dev *dev); -+ -+ /* initialize the hardware */ -+ void (*init_hardware)(struct ite_dev *dev); -+ -+ /* set the carrier parameters */ -+ void (*set_carrier_params)(struct ite_dev *dev, bool high_freq, -+ bool use_demodulator, u8 carrier_freq_bits, -+ u8 allowance_bits, u8 pulse_width_bits); -+}; -+ -+/* ITE CIR device structure */ -+struct ite_dev { -+ struct pnp_dev *pdev; -+ struct rc_dev *rdev; -+ struct ir_raw_event rawir; -+ -+ /* sync data */ -+ spinlock_t lock; -+ bool in_use, transmitting; -+ -+ /* transmit support */ -+ int tx_fifo_allowance; -+ wait_queue_head_t tx_queue, tx_ended; -+ -+ /* hardware I/O settings */ -+ unsigned long cir_addr; -+ int cir_irq; -+ -+ /* overridable copy of model parameters */ -+ struct ite_dev_params params; -+}; -+ -+ -+/* common values for all kinds of hardware */ -+ -+/* baud rate divisor default */ -+#define ITE_BAUDRATE_DIVISOR 1 -+ -+/* low-speed carrier frequency limits (Hz) */ -+#define ITE_LCF_MIN_CARRIER_FREQ 27000 -+#define ITE_LCF_MAX_CARRIER_FREQ 58000 -+ -+/* high-speed carrier frequency limits (Hz) */ -+#define ITE_HCF_MIN_CARRIER_FREQ 400000 -+#define ITE_HCF_MAX_CARRIER_FREQ 500000 -+ -+/* default carrier freq for when demodulator is off (Hz) */ -+#define ITE_DEFAULT_CARRIER_FREQ 38000 -+ -+/* default idling timeout in ns (0.2 seconds) */ -+#define ITE_IDLE_TIMEOUT 200000000UL -+ -+/* limit timeout values */ -+#define ITE_MIN_IDLE_TIMEOUT 100000000UL -+#define ITE_MAX_IDLE_TIMEOUT 1000000000UL -+ -+/* convert bits to us */ -+#define ITE_BITS_TO_NS(bits, sample_period) \ -+((u32) ((bits) * ITE_BAUDRATE_DIVISOR * sample_period)) -+ -+/* -+ * n in IT87_RDCR produces a tolerance of +/- n * 6.25% around the center -+ * carrier frequency... -+ * -+ * From two limit frequencies, L (low) and H (high), we can get both the -+ * center frequency F = (L + H) / 2 and the variation from the center -+ * frequency A = (H - L) / (H + L). We can use this in order to honor the -+ * s_rx_carrier_range() call in ir-core. We'll suppose that any request -+ * setting L=0 means we must shut down the demodulator. -+ */ -+#define ITE_RXDCR_PER_10000_STEP 625 -+ -+/* high speed carrier freq values */ -+#define ITE_CFQ_400 0x03 -+#define ITE_CFQ_450 0x08 -+#define ITE_CFQ_480 0x0b -+#define ITE_CFQ_500 0x0d -+ -+/* values for pulse widths */ -+#define ITE_TXMPW_A 0x02 -+#define ITE_TXMPW_B 0x03 -+#define ITE_TXMPW_C 0x04 -+#define ITE_TXMPW_D 0x05 -+#define ITE_TXMPW_E 0x06 -+ -+/* values for demodulator carrier range allowance */ -+#define ITE_RXDCR_DEFAULT 0x01 /* default carrier range */ -+#define ITE_RXDCR_MAX 0x07 /* default carrier range */ -+ -+/* DR TX bits */ -+#define ITE_TX_PULSE 0x00 -+#define ITE_TX_SPACE 0x80 -+#define ITE_TX_MAX_RLE 0x80 -+#define ITE_TX_RLE_MASK 0x7F -+ -+ -+/* -+ * IT8712F -+ * -+ * hardware data obtained from: -+ * -+ * IT8712F -+ * Environment Control – Low Pin Count Input / Output -+ * (EC - LPC I/O) -+ * Preliminary Specification V0. 81 -+ */ -+ -+/* register offsets */ -+#define IT87_DR 0x00 /* data register */ -+#define IT87_IER 0x01 /* interrupt enable register */ -+#define IT87_RCR 0x02 /* receiver control register */ -+#define IT87_TCR1 0x03 /* transmitter control register 1 */ -+#define IT87_TCR2 0x04 /* transmitter control register 2 */ -+#define IT87_TSR 0x05 /* transmitter status register */ -+#define IT87_RSR 0x06 /* receiver status register */ -+#define IT87_BDLR 0x05 /* baud rate divisor low byte register */ -+#define IT87_BDHR 0x06 /* baud rate divisor high byte register */ -+#define IT87_IIR 0x07 /* interrupt identification register */ -+ -+#define IT87_IOREG_LENGTH 0x08 /* length of register file */ -+ -+/* IER bits */ -+#define IT87_TLDLIE 0x01 /* transmitter low data interrupt enable */ -+#define IT87_RDAIE 0x02 /* receiver data available interrupt enable */ -+#define IT87_RFOIE 0x04 /* receiver FIFO overrun interrupt enable */ -+#define IT87_IEC 0x08 /* interrupt enable control */ -+#define IT87_BR 0x10 /* baud rate register enable */ -+#define IT87_RESET 0x20 /* reset */ -+ -+/* RCR bits */ -+#define IT87_RXDCR 0x07 /* receiver demodulation carrier range mask */ -+#define IT87_RXACT 0x08 /* receiver active */ -+#define IT87_RXEND 0x10 /* receiver demodulation enable */ -+#define IT87_RXEN 0x20 /* receiver enable */ -+#define IT87_HCFS 0x40 /* high-speed carrier frequency select */ -+#define IT87_RDWOS 0x80 /* receiver data without sync */ -+ -+/* TCR1 bits */ -+#define IT87_TXMPM 0x03 /* transmitter modulation pulse mode mask */ -+#define IT87_TXMPM_DEFAULT 0x00 /* modulation pulse mode default */ -+#define IT87_TXENDF 0x04 /* transmitter deferral */ -+#define IT87_TXRLE 0x08 /* transmitter run length enable */ -+#define IT87_FIFOTL 0x30 /* FIFO level threshold mask */ -+#define IT87_FIFOTL_DEFAULT 0x20 /* FIFO level threshold default -+ 0x00 -> 1, 0x10 -> 7, 0x20 -> 17, -+ 0x30 -> 25 */ -+#define IT87_ILE 0x40 /* internal loopback enable */ -+#define IT87_FIFOCLR 0x80 /* FIFO clear bit */ -+ -+/* TCR2 bits */ -+#define IT87_TXMPW 0x07 /* transmitter modulation pulse width mask */ -+#define IT87_TXMPW_DEFAULT 0x04 /* default modulation pulse width */ -+#define IT87_CFQ 0xf8 /* carrier frequency mask */ -+#define IT87_CFQ_SHIFT 3 /* carrier frequency bit shift */ -+ -+/* TSR bits */ -+#define IT87_TXBFC 0x3f /* transmitter FIFO byte count mask */ -+ -+/* RSR bits */ -+#define IT87_RXBFC 0x3f /* receiver FIFO byte count mask */ -+#define IT87_RXFTO 0x80 /* receiver FIFO time-out */ -+ -+/* IIR bits */ -+#define IT87_IP 0x01 /* interrupt pending */ -+#define IT87_II 0x06 /* interrupt identification mask */ -+#define IT87_II_NOINT 0x00 /* no interrupt */ -+#define IT87_II_TXLDL 0x02 /* transmitter low data level */ -+#define IT87_II_RXDS 0x04 /* receiver data stored */ -+#define IT87_II_RXFO 0x06 /* receiver FIFO overrun */ -+ -+ -+/* -+ * IT8512E/F -+ * -+ * Hardware data obtained from: -+ * -+ * IT8512E/F -+ * Embedded Controller -+ * Preliminary Specification V0.4.1 -+ * -+ * Note that the CIR registers are not directly available to the host, because -+ * they only are accessible to the integrated microcontroller. Thus, in order -+ * use it, some kind of bridging is required. As the bridging may depend on -+ * the controller firmware in use, we are going to use the PNP ID in order to -+ * determine the strategy and ports available. See after these generic -+ * IT8512E/F register definitions for register definitions for those -+ * strategies. -+ */ -+ -+/* register offsets */ -+#define IT85_C0DR 0x00 /* data register */ -+#define IT85_C0MSTCR 0x01 /* master control register */ -+#define IT85_C0IER 0x02 /* interrupt enable register */ -+#define IT85_C0IIR 0x03 /* interrupt identification register */ -+#define IT85_C0CFR 0x04 /* carrier frequency register */ -+#define IT85_C0RCR 0x05 /* receiver control register */ -+#define IT85_C0TCR 0x06 /* transmitter control register */ -+#define IT85_C0SCK 0x07 /* slow clock control register */ -+#define IT85_C0BDLR 0x08 /* baud rate divisor low byte register */ -+#define IT85_C0BDHR 0x09 /* baud rate divisor high byte register */ -+#define IT85_C0TFSR 0x0a /* transmitter FIFO status register */ -+#define IT85_C0RFSR 0x0b /* receiver FIFO status register */ -+#define IT85_C0WCL 0x0d /* wakeup code length register */ -+#define IT85_C0WCR 0x0e /* wakeup code read/write register */ -+#define IT85_C0WPS 0x0f /* wakeup power control/status register */ -+ -+#define IT85_IOREG_LENGTH 0x10 /* length of register file */ -+ -+/* C0MSTCR bits */ -+#define IT85_RESET 0x01 /* reset */ -+#define IT85_FIFOCLR 0x02 /* FIFO clear bit */ -+#define IT85_FIFOTL 0x0c /* FIFO level threshold mask */ -+#define IT85_FIFOTL_DEFAULT 0x08 /* FIFO level threshold default -+ 0x00 -> 1, 0x04 -> 7, 0x08 -> 17, -+ 0x0c -> 25 */ -+#define IT85_ILE 0x10 /* internal loopback enable */ -+#define IT85_ILSEL 0x20 /* internal loopback select */ -+ -+/* C0IER bits */ -+#define IT85_TLDLIE 0x01 /* TX low data level interrupt enable */ -+#define IT85_RDAIE 0x02 /* RX data available interrupt enable */ -+#define IT85_RFOIE 0x04 /* RX FIFO overrun interrupt enable */ -+#define IT85_IEC 0x80 /* interrupt enable function control */ -+ -+/* C0IIR bits */ -+#define IT85_TLDLI 0x01 /* transmitter low data level interrupt */ -+#define IT85_RDAI 0x02 /* receiver data available interrupt */ -+#define IT85_RFOI 0x04 /* receiver FIFO overrun interrupt */ -+#define IT85_NIP 0x80 /* no interrupt pending */ -+ -+/* C0CFR bits */ -+#define IT85_CFQ 0x1f /* carrier frequency mask */ -+#define IT85_HCFS 0x20 /* high speed carrier frequency select */ -+ -+/* C0RCR bits */ -+#define IT85_RXDCR 0x07 /* receiver demodulation carrier range mask */ -+#define IT85_RXACT 0x08 /* receiver active */ -+#define IT85_RXEND 0x10 /* receiver demodulation enable */ -+#define IT85_RDWOS 0x20 /* receiver data without sync */ -+#define IT85_RXEN 0x80 /* receiver enable */ -+ -+/* C0TCR bits */ -+#define IT85_TXMPW 0x07 /* transmitter modulation pulse width mask */ -+#define IT85_TXMPW_DEFAULT 0x04 /* default modulation pulse width */ -+#define IT85_TXMPM 0x18 /* transmitter modulation pulse mode mask */ -+#define IT85_TXMPM_DEFAULT 0x00 /* modulation pulse mode default */ -+#define IT85_TXENDF 0x20 /* transmitter deferral */ -+#define IT85_TXRLE 0x40 /* transmitter run length enable */ -+ -+/* C0SCK bits */ -+#define IT85_SCKS 0x01 /* slow clock select */ -+#define IT85_TXDCKG 0x02 /* TXD clock gating */ -+#define IT85_DLL1P8E 0x04 /* DLL 1.8432M enable */ -+#define IT85_DLLTE 0x08 /* DLL test enable */ -+#define IT85_BRCM 0x70 /* baud rate count mode */ -+#define IT85_DLLOCK 0x80 /* DLL lock */ -+ -+/* C0TFSR bits */ -+#define IT85_TXFBC 0x3f /* transmitter FIFO count mask */ -+ -+/* C0RFSR bits */ -+#define IT85_RXFBC 0x3f /* receiver FIFO count mask */ -+#define IT85_RXFTO 0x80 /* receiver FIFO time-out */ -+ -+/* C0WCL bits */ -+#define IT85_WCL 0x3f /* wakeup code length mask */ -+ -+/* C0WPS bits */ -+#define IT85_CIRPOSIE 0x01 /* power on/off status interrupt enable */ -+#define IT85_CIRPOIS 0x02 /* power on/off interrupt status */ -+#define IT85_CIRPOII 0x04 /* power on/off interrupt identification */ -+#define IT85_RCRST 0x10 /* wakeup code reading counter reset bit */ -+#define IT85_WCRST 0x20 /* wakeup code writing counter reset bit */ -+ -+ -+/* -+ * ITE8708 -+ * -+ * Hardware data obtained from hacked driver for IT8512 in this forum post: -+ * -+ * http://ubuntuforums.org/showthread.php?t=1028640 -+ * -+ * Although there's no official documentation for that driver, analysis would -+ * suggest that it maps the 16 registers of IT8512 onto two 8-register banks, -+ * selectable by a single bank-select bit that's mapped onto both banks. The -+ * IT8512 registers are mapped in a different order, so that the first bank -+ * maps the ones that are used more often, and two registers that share a -+ * reserved high-order bit are placed at the same offset in both banks in -+ * order to reuse the reserved bit as the bank select bit. -+ */ -+ -+/* register offsets */ -+ -+/* mapped onto both banks */ -+#define IT8708_BANKSEL 0x07 /* bank select register */ -+#define IT8708_HRAE 0x80 /* high registers access enable */ -+ -+/* mapped onto the low bank */ -+#define IT8708_C0DR 0x00 /* data register */ -+#define IT8708_C0MSTCR 0x01 /* master control register */ -+#define IT8708_C0IER 0x02 /* interrupt enable register */ -+#define IT8708_C0IIR 0x03 /* interrupt identification register */ -+#define IT8708_C0RFSR 0x04 /* receiver FIFO status register */ -+#define IT8708_C0RCR 0x05 /* receiver control register */ -+#define IT8708_C0TFSR 0x06 /* transmitter FIFO status register */ -+#define IT8708_C0TCR 0x07 /* transmitter control register */ -+ -+/* mapped onto the high bank */ -+#define IT8708_C0BDLR 0x01 /* baud rate divisor low byte register */ -+#define IT8708_C0BDHR 0x02 /* baud rate divisor high byte register */ -+#define IT8708_C0CFR 0x04 /* carrier frequency register */ -+ -+/* registers whose bank mapping we don't know, since they weren't being used -+ * in the hacked driver... most probably they belong to the high bank too, -+ * since they fit in the holes the other registers leave */ -+#define IT8708_C0SCK 0x03 /* slow clock control register */ -+#define IT8708_C0WCL 0x05 /* wakeup code length register */ -+#define IT8708_C0WCR 0x06 /* wakeup code read/write register */ -+#define IT8708_C0WPS 0x07 /* wakeup power control/status register */ -+ -+#define IT8708_IOREG_LENGTH 0x08 /* length of register file */ -+ -+/* two more registers that are defined in the hacked driver, but can't be -+ * found in the data sheets; no idea what they are or how they are accessed, -+ * since the hacked driver doesn't seem to use them */ -+#define IT8708_CSCRR 0x00 -+#define IT8708_CGPINTR 0x01 -+ -+/* CSCRR bits */ -+#define IT8708_CSCRR_SCRB 0x3f -+#define IT8708_CSCRR_PM 0x80 -+ -+/* CGPINTR bits */ -+#define IT8708_CGPINT 0x01 -diff -Naur linux-2.6.38-rc5/drivers/media/rc/Kconfig linux-2.6.38-rc5.patch/drivers/media/rc/Kconfig ---- linux-2.6.38-rc5/drivers/media/rc/Kconfig 2011-02-16 04:23:45.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/media/rc/Kconfig 2011-02-22 03:24:59.239412519 +0100 -@@ -148,6 +148,19 @@ - To compile this driver as a module, choose M here: the - module will be called nuvoton-cir. - -+config IR_ITE_CIR -+ tristate "ITE Tech Inc. IT8712/IT8512 Consumer Infrared Transceiver" -+ depends on PNP -+ depends on RC_CORE -+ ---help--- -+ Say Y here to enable support for integrated infrared receivers -+ /transceivers made by ITE Tech Inc. These are found in -+ several ASUS devices, like the ASUS Digimatrix or the ASUS -+ EEEBox 1501U. -+ -+ To compile this driver as a module, choose M here: the -+ module will be called ite-cir. -+ - config IR_STREAMZAP - tristate "Streamzap PC Remote IR Receiver" - depends on USB_ARCH_HAS_HCD -diff -Naur linux-2.6.38-rc5/drivers/media/rc/Makefile linux-2.6.38-rc5.patch/drivers/media/rc/Makefile ---- linux-2.6.38-rc5/drivers/media/rc/Makefile 2011-02-16 04:23:45.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/media/rc/Makefile 2011-02-22 03:24:09.659341983 +0100 -@@ -19,4 +19,5 @@ - obj-$(CONFIG_IR_ENE) += ene_ir.o - obj-$(CONFIG_IR_STREAMZAP) += streamzap.o - obj-$(CONFIG_IR_WINBOND_CIR) += winbond-cir.o -+obj-$(CONFIG_IR_ITE_CIR) += ite-cir.o - obj-$(CONFIG_RC_LOOPBACK) += rc-loopback.o -diff -Naur linux-2.6.38-rc5/drivers/staging/lirc/Kconfig linux-2.6.38-rc5.patch/drivers/staging/lirc/Kconfig ---- linux-2.6.38-rc5/drivers/staging/lirc/Kconfig 2011-02-16 04:23:45.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/staging/lirc/Kconfig 2011-02-22 03:22:22.436351160 +0100 -@@ -32,12 +32,6 @@ - - Current generation iMON devices use the input layer imon driver. - --config LIRC_IT87 -- tristate "ITE IT87XX CIR Port Receiver" -- depends on LIRC && PNP -- help -- Driver for the ITE IT87xx IR Receiver -- - config LIRC_ITE8709 - tristate "ITE8709 CIR Port Receiver" - depends on LIRC && PNP -diff -Naur linux-2.6.38-rc5/drivers/staging/lirc/lirc_it87.c linux-2.6.38-rc5.patch/drivers/staging/lirc/lirc_it87.c ---- linux-2.6.38-rc5/drivers/staging/lirc/lirc_it87.c 2011-02-16 04:23:45.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/staging/lirc/lirc_it87.c 1970-01-01 01:00:00.000000000 +0100 -@@ -1,1027 +0,0 @@ --/* -- * LIRC driver for ITE IT8712/IT8705 CIR port -- * -- * Copyright (C) 2001 Hans-Gunter Lutke Uphues -- * -- * 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 -- * USA -- * -- * ITE IT8705 and IT8712(not tested) and IT8720 CIR-port support for lirc based -- * via cut and paste from lirc_sir.c (C) 2000 Milan Pikula -- * -- * Attention: Sendmode only tested with debugging logs -- * -- * 2001/02/27 Christoph Bartelmus : -- * reimplemented read function -- * 2005/06/05 Andrew Calkin implemented support for Asus Digimatrix, -- * based on work of the following member of the Outertrack Digimatrix -- * Forum: Art103 -- * 2009/12/24 James Edwards implemeted support -- * for ITE8704/ITE8718, on my machine, the DSDT reports 8704, but the -- * chip identifies as 18. -- */ -- --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include --#include -- --#include --#include -- --#include --#include -- --#include "lirc_it87.h" -- --#ifdef LIRC_IT87_DIGIMATRIX --static int digimatrix = 1; --static int it87_freq = 36; /* kHz */ --static int irq = 9; --#else --static int digimatrix; --static int it87_freq = 38; /* kHz */ --static int irq = IT87_CIR_DEFAULT_IRQ; --#endif -- --static unsigned long it87_bits_in_byte_out; --static unsigned long it87_send_counter; --static unsigned char it87_RXEN_mask = IT87_CIR_RCR_RXEN; -- --#define RBUF_LEN 1024 -- --#define LIRC_DRIVER_NAME "lirc_it87" -- --/* timeout for sequences in jiffies (=5/100s) */ --/* must be longer than TIME_CONST */ --#define IT87_TIMEOUT (HZ*5/100) -- --/* module parameters */ --static int debug; --#define dprintk(fmt, args...) \ -- do { \ -- if (debug) \ -- printk(KERN_DEBUG LIRC_DRIVER_NAME ": " \ -- fmt, ## args); \ -- } while (0) -- --static int io = IT87_CIR_DEFAULT_IOBASE; --/* receiver demodulator default: off */ --static int it87_enable_demodulator; -- --static int timer_enabled; --static DEFINE_SPINLOCK(timer_lock); --static struct timer_list timerlist; --/* time of last signal change detected */ --static struct timeval last_tv = {0, 0}; --/* time of last UART data ready interrupt */ --static struct timeval last_intr_tv = {0, 0}; --static int last_value; -- --static DECLARE_WAIT_QUEUE_HEAD(lirc_read_queue); -- --static DEFINE_SPINLOCK(hardware_lock); --static DEFINE_SPINLOCK(dev_lock); --static bool device_open; -- --static int rx_buf[RBUF_LEN]; --unsigned int rx_tail, rx_head; -- --static struct pnp_driver it87_pnp_driver; -- --/* SECTION: Prototypes */ -- --/* Communication with user-space */ --static int lirc_open(struct inode *inode, struct file *file); --static int lirc_close(struct inode *inode, struct file *file); --static unsigned int lirc_poll(struct file *file, poll_table *wait); --static ssize_t lirc_read(struct file *file, char *buf, -- size_t count, loff_t *ppos); --static ssize_t lirc_write(struct file *file, const char *buf, -- size_t n, loff_t *pos); --static long lirc_ioctl(struct file *filep, unsigned int cmd, unsigned long arg); --static void add_read_queue(int flag, unsigned long val); --static int init_chrdev(void); --static void drop_chrdev(void); --/* Hardware */ --static irqreturn_t it87_interrupt(int irq, void *dev_id); --static void send_space(unsigned long len); --static void send_pulse(unsigned long len); --static void init_send(void); --static void terminate_send(unsigned long len); --static int init_hardware(void); --static void drop_hardware(void); --/* Initialisation */ --static int init_port(void); --static void drop_port(void); -- -- --/* SECTION: Communication with user-space */ -- --static int lirc_open(struct inode *inode, struct file *file) --{ -- spin_lock(&dev_lock); -- if (device_open) { -- spin_unlock(&dev_lock); -- return -EBUSY; -- } -- device_open = true; -- spin_unlock(&dev_lock); -- return 0; --} -- -- --static int lirc_close(struct inode *inode, struct file *file) --{ -- spin_lock(&dev_lock); -- device_open = false; -- spin_unlock(&dev_lock); -- return 0; --} -- -- --static unsigned int lirc_poll(struct file *file, poll_table *wait) --{ -- poll_wait(file, &lirc_read_queue, wait); -- if (rx_head != rx_tail) -- return POLLIN | POLLRDNORM; -- return 0; --} -- -- --static ssize_t lirc_read(struct file *file, char *buf, -- size_t count, loff_t *ppos) --{ -- int n = 0; -- int retval = 0; -- -- while (n < count) { -- if (file->f_flags & O_NONBLOCK && rx_head == rx_tail) { -- retval = -EAGAIN; -- break; -- } -- retval = wait_event_interruptible(lirc_read_queue, -- rx_head != rx_tail); -- if (retval) -- break; -- -- if (copy_to_user((void *) buf + n, (void *) (rx_buf + rx_head), -- sizeof(int))) { -- retval = -EFAULT; -- break; -- } -- rx_head = (rx_head + 1) & (RBUF_LEN - 1); -- n += sizeof(int); -- } -- if (n) -- return n; -- return retval; --} -- -- --static ssize_t lirc_write(struct file *file, const char *buf, -- size_t n, loff_t *pos) --{ -- int i = 0; -- int *tx_buf; -- -- if (n % sizeof(int)) -- return -EINVAL; -- tx_buf = memdup_user(buf, n); -- if (IS_ERR(tx_buf)) -- return PTR_ERR(tx_buf); -- n /= sizeof(int); -- init_send(); -- while (1) { -- if (i >= n) -- break; -- if (tx_buf[i]) -- send_pulse(tx_buf[i]); -- i++; -- if (i >= n) -- break; -- if (tx_buf[i]) -- send_space(tx_buf[i]); -- i++; -- } -- terminate_send(tx_buf[i - 1]); -- kfree(tx_buf); -- return n; --} -- -- --static long lirc_ioctl(struct file *filep, unsigned int cmd, unsigned long arg) --{ -- int retval = 0; -- __u32 value = 0; -- unsigned long hw_flags; -- -- if (cmd == LIRC_GET_FEATURES) -- value = LIRC_CAN_SEND_PULSE | -- LIRC_CAN_SET_SEND_CARRIER | -- LIRC_CAN_REC_MODE2; -- else if (cmd == LIRC_GET_SEND_MODE) -- value = LIRC_MODE_PULSE; -- else if (cmd == LIRC_GET_REC_MODE) -- value = LIRC_MODE_MODE2; -- -- switch (cmd) { -- case LIRC_GET_FEATURES: -- case LIRC_GET_SEND_MODE: -- case LIRC_GET_REC_MODE: -- retval = put_user(value, (__u32 *) arg); -- break; -- -- case LIRC_SET_SEND_MODE: -- case LIRC_SET_REC_MODE: -- retval = get_user(value, (__u32 *) arg); -- break; -- -- case LIRC_SET_SEND_CARRIER: -- retval = get_user(value, (__u32 *) arg); -- if (retval) -- return retval; -- value /= 1000; -- if (value > IT87_CIR_FREQ_MAX || -- value < IT87_CIR_FREQ_MIN) -- return -EINVAL; -- -- it87_freq = value; -- -- spin_lock_irqsave(&hardware_lock, hw_flags); -- outb(((inb(io + IT87_CIR_TCR2) & IT87_CIR_TCR2_TXMPW) | -- (it87_freq - IT87_CIR_FREQ_MIN) << 3), -- io + IT87_CIR_TCR2); -- spin_unlock_irqrestore(&hardware_lock, hw_flags); -- dprintk("demodulation frequency: %d kHz\n", it87_freq); -- -- break; -- -- default: -- retval = -EINVAL; -- } -- -- if (retval) -- return retval; -- -- if (cmd == LIRC_SET_REC_MODE) { -- if (value != LIRC_MODE_MODE2) -- retval = -ENOSYS; -- } else if (cmd == LIRC_SET_SEND_MODE) { -- if (value != LIRC_MODE_PULSE) -- retval = -ENOSYS; -- } -- return retval; --} -- --static void add_read_queue(int flag, unsigned long val) --{ -- unsigned int new_rx_tail; -- int newval; -- -- dprintk("add flag %d with val %lu\n", flag, val); -- -- newval = val & PULSE_MASK; -- -- /* -- * statistically, pulses are ~TIME_CONST/2 too long. we could -- * maybe make this more exact, but this is good enough -- */ -- if (flag) { -- /* pulse */ -- if (newval > TIME_CONST / 2) -- newval -= TIME_CONST / 2; -- else /* should not ever happen */ -- newval = 1; -- newval |= PULSE_BIT; -- } else -- newval += TIME_CONST / 2; -- new_rx_tail = (rx_tail + 1) & (RBUF_LEN - 1); -- if (new_rx_tail == rx_head) { -- dprintk("Buffer overrun.\n"); -- return; -- } -- rx_buf[rx_tail] = newval; -- rx_tail = new_rx_tail; -- wake_up_interruptible(&lirc_read_queue); --} -- -- --static const struct file_operations lirc_fops = { -- .owner = THIS_MODULE, -- .read = lirc_read, -- .write = lirc_write, -- .poll = lirc_poll, -- .unlocked_ioctl = lirc_ioctl, --#ifdef CONFIG_COMPAT -- .compat_ioctl = lirc_ioctl, --#endif -- .open = lirc_open, -- .release = lirc_close, -- .llseek = noop_llseek, --}; -- --static int set_use_inc(void *data) --{ -- return 0; --} -- --static void set_use_dec(void *data) --{ --} -- --static struct lirc_driver driver = { -- .name = LIRC_DRIVER_NAME, -- .minor = -1, -- .code_length = 1, -- .sample_rate = 0, -- .data = NULL, -- .add_to_buf = NULL, -- .set_use_inc = set_use_inc, -- .set_use_dec = set_use_dec, -- .fops = &lirc_fops, -- .dev = NULL, -- .owner = THIS_MODULE, --}; -- -- --static int init_chrdev(void) --{ -- driver.minor = lirc_register_driver(&driver); -- -- if (driver.minor < 0) { -- printk(KERN_ERR LIRC_DRIVER_NAME ": init_chrdev() failed.\n"); -- return -EIO; -- } -- return 0; --} -- -- --static void drop_chrdev(void) --{ -- lirc_unregister_driver(driver.minor); --} -- -- --/* SECTION: Hardware */ --static long delta(struct timeval *tv1, struct timeval *tv2) --{ -- unsigned long deltv; -- -- deltv = tv2->tv_sec - tv1->tv_sec; -- if (deltv > 15) -- deltv = 0xFFFFFF; -- else -- deltv = deltv*1000000 + tv2->tv_usec - tv1->tv_usec; -- return deltv; --} -- --static void it87_timeout(unsigned long data) --{ -- unsigned long flags; -- -- /* avoid interference with interrupt */ -- spin_lock_irqsave(&timer_lock, flags); -- -- if (digimatrix) { -- /* We have timed out. Disable the RX mechanism. */ -- -- outb((inb(io + IT87_CIR_RCR) & ~IT87_CIR_RCR_RXEN) | -- IT87_CIR_RCR_RXACT, io + IT87_CIR_RCR); -- if (it87_RXEN_mask) -- outb(inb(io + IT87_CIR_RCR) | IT87_CIR_RCR_RXEN, -- io + IT87_CIR_RCR); -- dprintk(" TIMEOUT\n"); -- timer_enabled = 0; -- -- /* fifo clear */ -- outb(inb(io + IT87_CIR_TCR1) | IT87_CIR_TCR1_FIFOCLR, -- io+IT87_CIR_TCR1); -- -- } else { -- /* -- * if last received signal was a pulse, but receiving stopped -- * within the 9 bit frame, we need to finish this pulse and -- * simulate a signal change to from pulse to space. Otherwise -- * upper layers will receive two sequences next time. -- */ -- -- if (last_value) { -- unsigned long pulse_end; -- -- /* determine 'virtual' pulse end: */ -- pulse_end = delta(&last_tv, &last_intr_tv); -- dprintk("timeout add %d for %lu usec\n", -- last_value, pulse_end); -- add_read_queue(last_value, pulse_end); -- last_value = 0; -- last_tv = last_intr_tv; -- } -- } -- spin_unlock_irqrestore(&timer_lock, flags); --} -- --static irqreturn_t it87_interrupt(int irq, void *dev_id) --{ -- unsigned char data; -- struct timeval curr_tv; -- static unsigned long deltv; -- unsigned long deltintrtv; -- unsigned long flags, hw_flags; -- int iir, lsr; -- int fifo = 0; -- static char lastbit; -- char bit; -- -- /* Bit duration in microseconds */ -- const unsigned long bit_duration = 1000000ul / -- (115200 / IT87_CIR_BAUDRATE_DIVISOR); -- -- -- iir = inb(io + IT87_CIR_IIR); -- -- switch (iir & IT87_CIR_IIR_IID) { -- case 0x4: -- case 0x6: -- lsr = inb(io + IT87_CIR_RSR) & (IT87_CIR_RSR_RXFTO | -- IT87_CIR_RSR_RXFBC); -- fifo = lsr & IT87_CIR_RSR_RXFBC; -- dprintk("iir: 0x%x fifo: 0x%x\n", iir, lsr); -- -- /* avoid interference with timer */ -- spin_lock_irqsave(&timer_lock, flags); -- spin_lock_irqsave(&hardware_lock, hw_flags); -- if (digimatrix) { -- static unsigned long acc_pulse; -- static unsigned long acc_space; -- -- do { -- data = inb(io + IT87_CIR_DR); -- data = ~data; -- fifo--; -- if (data != 0x00) { -- if (timer_enabled) -- del_timer(&timerlist); -- /* -- * start timer for end of -- * sequence detection -- */ -- timerlist.expires = jiffies + -- IT87_TIMEOUT; -- add_timer(&timerlist); -- timer_enabled = 1; -- } -- /* Loop through */ -- for (bit = 0; bit < 8; ++bit) { -- if ((data >> bit) & 1) { -- ++acc_pulse; -- if (lastbit == 0) { -- add_read_queue(0, -- acc_space * -- bit_duration); -- acc_space = 0; -- } -- } else { -- ++acc_space; -- if (lastbit == 1) { -- add_read_queue(1, -- acc_pulse * -- bit_duration); -- acc_pulse = 0; -- } -- } -- lastbit = (data >> bit) & 1; -- } -- -- } while (fifo != 0); -- } else { /* Normal Operation */ -- do { -- del_timer(&timerlist); -- data = inb(io + IT87_CIR_DR); -- -- dprintk("data=%02x\n", data); -- do_gettimeofday(&curr_tv); -- deltv = delta(&last_tv, &curr_tv); -- deltintrtv = delta(&last_intr_tv, &curr_tv); -- -- dprintk("t %lu , d %d\n", -- deltintrtv, (int)data); -- -- /* -- * if nothing came in last 2 cycles, -- * it was gap -- */ -- if (deltintrtv > TIME_CONST * 2) { -- if (last_value) { -- dprintk("GAP\n"); -- -- /* simulate signal change */ -- add_read_queue(last_value, -- deltv - -- deltintrtv); -- last_value = 0; -- last_tv.tv_sec = -- last_intr_tv.tv_sec; -- last_tv.tv_usec = -- last_intr_tv.tv_usec; -- deltv = deltintrtv; -- } -- } -- data = 1; -- if (data ^ last_value) { -- /* -- * deltintrtv > 2*TIME_CONST, -- * remember ? the other case is -- * timeout -- */ -- add_read_queue(last_value, -- deltv-TIME_CONST); -- last_value = data; -- last_tv = curr_tv; -- if (last_tv.tv_usec >= TIME_CONST) -- last_tv.tv_usec -= TIME_CONST; -- else { -- last_tv.tv_sec--; -- last_tv.tv_usec += 1000000 - -- TIME_CONST; -- } -- } -- last_intr_tv = curr_tv; -- if (data) { -- /* -- * start timer for end of -- * sequence detection -- */ -- timerlist.expires = -- jiffies + IT87_TIMEOUT; -- add_timer(&timerlist); -- } -- outb((inb(io + IT87_CIR_RCR) & -- ~IT87_CIR_RCR_RXEN) | -- IT87_CIR_RCR_RXACT, -- io + IT87_CIR_RCR); -- if (it87_RXEN_mask) -- outb(inb(io + IT87_CIR_RCR) | -- IT87_CIR_RCR_RXEN, -- io + IT87_CIR_RCR); -- fifo--; -- } while (fifo != 0); -- } -- spin_unlock_irqrestore(&hardware_lock, hw_flags); -- spin_unlock_irqrestore(&timer_lock, flags); -- -- return IRQ_RETVAL(IRQ_HANDLED); -- -- default: -- /* not our irq */ -- dprintk("unknown IRQ (shouldn't happen) !!\n"); -- return IRQ_RETVAL(IRQ_NONE); -- } --} -- -- --static void send_it87(unsigned long len, unsigned long stime, -- unsigned char send_byte, unsigned int count_bits) --{ -- long count = len / stime; -- long time_left = 0; -- static unsigned char byte_out; -- unsigned long hw_flags; -- -- dprintk("%s: len=%ld, sb=%d\n", __func__, len, send_byte); -- -- time_left = (long)len - (long)count * (long)stime; -- count += ((2 * time_left) / stime); -- while (count) { -- long i = 0; -- for (i = 0; i < count_bits; i++) { -- byte_out = (byte_out << 1) | (send_byte & 1); -- it87_bits_in_byte_out++; -- } -- if (it87_bits_in_byte_out == 8) { -- dprintk("out=0x%x, tsr_txfbc: 0x%x\n", -- byte_out, -- inb(io + IT87_CIR_TSR) & -- IT87_CIR_TSR_TXFBC); -- -- while ((inb(io + IT87_CIR_TSR) & -- IT87_CIR_TSR_TXFBC) >= IT87_CIR_FIFO_SIZE) -- ; -- -- spin_lock_irqsave(&hardware_lock, hw_flags); -- outb(byte_out, io + IT87_CIR_DR); -- spin_unlock_irqrestore(&hardware_lock, hw_flags); -- -- it87_bits_in_byte_out = 0; -- it87_send_counter++; -- byte_out = 0; -- } -- count--; -- } --} -- -- --/*TODO: maybe exchange space and pulse because it8705 only modulates 0-bits */ -- --static void send_space(unsigned long len) --{ -- send_it87(len, TIME_CONST, IT87_CIR_SPACE, IT87_CIR_BAUDRATE_DIVISOR); --} -- --static void send_pulse(unsigned long len) --{ -- send_it87(len, TIME_CONST, IT87_CIR_PULSE, IT87_CIR_BAUDRATE_DIVISOR); --} -- -- --static void init_send() --{ -- unsigned long flags; -- -- spin_lock_irqsave(&hardware_lock, flags); -- /* RXEN=0: receiver disable */ -- it87_RXEN_mask = 0; -- outb(inb(io + IT87_CIR_RCR) & ~IT87_CIR_RCR_RXEN, -- io + IT87_CIR_RCR); -- spin_unlock_irqrestore(&hardware_lock, flags); -- it87_bits_in_byte_out = 0; -- it87_send_counter = 0; --} -- -- --static void terminate_send(unsigned long len) --{ -- unsigned long flags; -- unsigned long last = 0; -- -- last = it87_send_counter; -- /* make sure all necessary data has been sent */ -- while (last == it87_send_counter) -- send_space(len); -- /* wait until all data sent */ -- while ((inb(io + IT87_CIR_TSR) & IT87_CIR_TSR_TXFBC) != 0) -- ; -- /* then re-enable receiver */ -- spin_lock_irqsave(&hardware_lock, flags); -- it87_RXEN_mask = IT87_CIR_RCR_RXEN; -- outb(inb(io + IT87_CIR_RCR) | IT87_CIR_RCR_RXEN, -- io + IT87_CIR_RCR); -- spin_unlock_irqrestore(&hardware_lock, flags); --} -- -- --static int init_hardware(void) --{ -- unsigned long flags; -- unsigned char it87_rcr = 0; -- -- spin_lock_irqsave(&hardware_lock, flags); -- /* init cir-port */ -- /* enable r/w-access to Baudrate-Register */ -- outb(IT87_CIR_IER_BR, io + IT87_CIR_IER); -- outb(IT87_CIR_BAUDRATE_DIVISOR % 0x100, io+IT87_CIR_BDLR); -- outb(IT87_CIR_BAUDRATE_DIVISOR / 0x100, io+IT87_CIR_BDHR); -- /* Baudrate Register off, define IRQs: Input only */ -- if (digimatrix) { -- outb(IT87_CIR_IER_IEC | IT87_CIR_IER_RFOIE, io + IT87_CIR_IER); -- /* RX: HCFS=0, RXDCR = 001b (33,75..38,25 kHz), RXEN=1 */ -- } else { -- outb(IT87_CIR_IER_IEC | IT87_CIR_IER_RDAIE, io + IT87_CIR_IER); -- /* RX: HCFS=0, RXDCR = 001b (35,6..40,3 kHz), RXEN=1 */ -- } -- it87_rcr = (IT87_CIR_RCR_RXEN & it87_RXEN_mask) | 0x1; -- if (it87_enable_demodulator) -- it87_rcr |= IT87_CIR_RCR_RXEND; -- outb(it87_rcr, io + IT87_CIR_RCR); -- if (digimatrix) { -- /* Set FIFO depth to 1 byte, and disable TX */ -- outb(inb(io + IT87_CIR_TCR1) | 0x00, -- io + IT87_CIR_TCR1); -- -- /* -- * TX: it87_freq (36kHz), 'reserved' sensitivity -- * setting (0x00) -- */ -- outb(((it87_freq - IT87_CIR_FREQ_MIN) << 3) | 0x00, -- io + IT87_CIR_TCR2); -- } else { -- /* TX: 38kHz, 13,3us (pulse-width) */ -- outb(((it87_freq - IT87_CIR_FREQ_MIN) << 3) | 0x06, -- io + IT87_CIR_TCR2); -- } -- spin_unlock_irqrestore(&hardware_lock, flags); -- return 0; --} -- -- --static void drop_hardware(void) --{ -- unsigned long flags; -- -- spin_lock_irqsave(&hardware_lock, flags); -- disable_irq(irq); -- /* receiver disable */ -- it87_RXEN_mask = 0; -- outb(0x1, io + IT87_CIR_RCR); -- /* turn off irqs */ -- outb(0, io + IT87_CIR_IER); -- /* fifo clear */ -- outb(IT87_CIR_TCR1_FIFOCLR, io+IT87_CIR_TCR1); -- /* reset */ -- outb(IT87_CIR_IER_RESET, io+IT87_CIR_IER); -- enable_irq(irq); -- spin_unlock_irqrestore(&hardware_lock, flags); --} -- -- --static unsigned char it87_read(unsigned char port) --{ -- outb(port, IT87_ADRPORT); -- return inb(IT87_DATAPORT); --} -- -- --static void it87_write(unsigned char port, unsigned char data) --{ -- outb(port, IT87_ADRPORT); -- outb(data, IT87_DATAPORT); --} -- -- --/* SECTION: Initialisation */ -- --static int init_port(void) --{ -- unsigned long hw_flags; -- int retval = 0; -- -- unsigned char init_bytes[4] = IT87_INIT; -- unsigned char it87_chipid = 0; -- unsigned char ldn = 0; -- unsigned int it87_io = 0; -- unsigned int it87_irq = 0; -- -- /* Enter MB PnP Mode */ -- outb(init_bytes[0], IT87_ADRPORT); -- outb(init_bytes[1], IT87_ADRPORT); -- outb(init_bytes[2], IT87_ADRPORT); -- outb(init_bytes[3], IT87_ADRPORT); -- -- /* 8712 or 8705 ? */ -- it87_chipid = it87_read(IT87_CHIP_ID1); -- if (it87_chipid != 0x87) { -- retval = -ENXIO; -- return retval; -- } -- it87_chipid = it87_read(IT87_CHIP_ID2); -- if ((it87_chipid != 0x05) && -- (it87_chipid != 0x12) && -- (it87_chipid != 0x18) && -- (it87_chipid != 0x20)) { -- printk(KERN_INFO LIRC_DRIVER_NAME -- ": no IT8704/05/12/18/20 found (claimed IT87%02x), " -- "exiting..\n", it87_chipid); -- retval = -ENXIO; -- return retval; -- } -- printk(KERN_INFO LIRC_DRIVER_NAME -- ": found IT87%02x.\n", -- it87_chipid); -- -- /* get I/O-Port and IRQ */ -- if (it87_chipid == 0x12 || it87_chipid == 0x18) -- ldn = IT8712_CIR_LDN; -- else -- ldn = IT8705_CIR_LDN; -- it87_write(IT87_LDN, ldn); -- -- it87_io = it87_read(IT87_CIR_BASE_MSB) * 256 + -- it87_read(IT87_CIR_BASE_LSB); -- if (it87_io == 0) { -- if (io == 0) -- io = IT87_CIR_DEFAULT_IOBASE; -- printk(KERN_INFO LIRC_DRIVER_NAME -- ": set default io 0x%x\n", -- io); -- it87_write(IT87_CIR_BASE_MSB, io / 0x100); -- it87_write(IT87_CIR_BASE_LSB, io % 0x100); -- } else -- io = it87_io; -- -- it87_irq = it87_read(IT87_CIR_IRQ); -- if (digimatrix || it87_irq == 0) { -- if (irq == 0) -- irq = IT87_CIR_DEFAULT_IRQ; -- printk(KERN_INFO LIRC_DRIVER_NAME -- ": set default irq 0x%x\n", -- irq); -- it87_write(IT87_CIR_IRQ, irq); -- } else -- irq = it87_irq; -- -- spin_lock_irqsave(&hardware_lock, hw_flags); -- /* reset */ -- outb(IT87_CIR_IER_RESET, io+IT87_CIR_IER); -- /* fifo clear */ -- outb(IT87_CIR_TCR1_FIFOCLR | -- /* IT87_CIR_TCR1_ILE | */ -- IT87_CIR_TCR1_TXRLE | -- IT87_CIR_TCR1_TXENDF, io+IT87_CIR_TCR1); -- spin_unlock_irqrestore(&hardware_lock, hw_flags); -- -- /* get I/O port access and IRQ line */ -- if (request_region(io, 8, LIRC_DRIVER_NAME) == NULL) { -- printk(KERN_ERR LIRC_DRIVER_NAME -- ": i/o port 0x%.4x already in use.\n", io); -- /* Leaving MB PnP Mode */ -- it87_write(IT87_CFGCTRL, 0x2); -- return -EBUSY; -- } -- -- /* activate CIR-Device */ -- it87_write(IT87_CIR_ACT, 0x1); -- -- /* Leaving MB PnP Mode */ -- it87_write(IT87_CFGCTRL, 0x2); -- -- retval = request_irq(irq, it87_interrupt, 0 /*IRQF_DISABLED*/, -- LIRC_DRIVER_NAME, NULL); -- if (retval < 0) { -- printk(KERN_ERR LIRC_DRIVER_NAME -- ": IRQ %d already in use.\n", -- irq); -- release_region(io, 8); -- return retval; -- } -- -- printk(KERN_INFO LIRC_DRIVER_NAME -- ": I/O port 0x%.4x, IRQ %d.\n", io, irq); -- -- init_timer(&timerlist); -- timerlist.function = it87_timeout; -- timerlist.data = 0xabadcafe; -- -- return 0; --} -- -- --static void drop_port(void) --{ --#if 0 -- unsigned char init_bytes[4] = IT87_INIT; -- -- /* Enter MB PnP Mode */ -- outb(init_bytes[0], IT87_ADRPORT); -- outb(init_bytes[1], IT87_ADRPORT); -- outb(init_bytes[2], IT87_ADRPORT); -- outb(init_bytes[3], IT87_ADRPORT); -- -- /* deactivate CIR-Device */ -- it87_write(IT87_CIR_ACT, 0x0); -- -- /* Leaving MB PnP Mode */ -- it87_write(IT87_CFGCTRL, 0x2); --#endif -- -- del_timer_sync(&timerlist); -- free_irq(irq, NULL); -- release_region(io, 8); --} -- -- --static int init_lirc_it87(void) --{ -- int retval; -- -- init_waitqueue_head(&lirc_read_queue); -- retval = init_port(); -- if (retval < 0) -- return retval; -- init_hardware(); -- printk(KERN_INFO LIRC_DRIVER_NAME ": Installed.\n"); -- return 0; --} -- --static int it87_probe(struct pnp_dev *pnp_dev, -- const struct pnp_device_id *dev_id) --{ -- int retval; -- -- driver.dev = &pnp_dev->dev; -- -- retval = init_chrdev(); -- if (retval < 0) -- return retval; -- -- retval = init_lirc_it87(); -- if (retval) -- goto init_lirc_it87_failed; -- -- return 0; -- --init_lirc_it87_failed: -- drop_chrdev(); -- -- return retval; --} -- --static int __init lirc_it87_init(void) --{ -- return pnp_register_driver(&it87_pnp_driver); --} -- -- --static void __exit lirc_it87_exit(void) --{ -- drop_hardware(); -- drop_chrdev(); -- drop_port(); -- pnp_unregister_driver(&it87_pnp_driver); -- printk(KERN_INFO LIRC_DRIVER_NAME ": Uninstalled.\n"); --} -- --/* SECTION: PNP for ITE8704/13/18 */ -- --static const struct pnp_device_id pnp_dev_table[] = { -- {"ITE8704", 0}, -- {"ITE8713", 0}, -- {} --}; -- --MODULE_DEVICE_TABLE(pnp, pnp_dev_table); -- --static struct pnp_driver it87_pnp_driver = { -- .name = LIRC_DRIVER_NAME, -- .id_table = pnp_dev_table, -- .probe = it87_probe, --}; -- --module_init(lirc_it87_init); --module_exit(lirc_it87_exit); -- --MODULE_DESCRIPTION("LIRC driver for ITE IT8704/05/12/18/20 CIR port"); --MODULE_AUTHOR("Hans-Gunter Lutke Uphues"); --MODULE_LICENSE("GPL"); -- --module_param(io, int, S_IRUGO); --MODULE_PARM_DESC(io, "I/O base address (default: 0x310)"); -- --module_param(irq, int, S_IRUGO); --#ifdef LIRC_IT87_DIGIMATRIX --MODULE_PARM_DESC(irq, "Interrupt (1,3-12) (default: 9)"); --#else --MODULE_PARM_DESC(irq, "Interrupt (1,3-12) (default: 7)"); --#endif -- --module_param(it87_enable_demodulator, bool, S_IRUGO); --MODULE_PARM_DESC(it87_enable_demodulator, -- "Receiver demodulator enable/disable (1/0), default: 0"); -- --module_param(debug, bool, S_IRUGO | S_IWUSR); --MODULE_PARM_DESC(debug, "Enable debugging messages"); -- --module_param(digimatrix, bool, S_IRUGO | S_IWUSR); --#ifdef LIRC_IT87_DIGIMATRIX --MODULE_PARM_DESC(digimatrix, -- "Asus Digimatrix it87 compat. enable/disable (1/0), default: 1"); --#else --MODULE_PARM_DESC(digimatrix, -- "Asus Digimatrix it87 compat. enable/disable (1/0), default: 0"); --#endif -- -- --module_param(it87_freq, int, S_IRUGO); --#ifdef LIRC_IT87_DIGIMATRIX --MODULE_PARM_DESC(it87_freq, -- "Carrier demodulator frequency (kHz), (default: 36)"); --#else --MODULE_PARM_DESC(it87_freq, -- "Carrier demodulator frequency (kHz), (default: 38)"); --#endif -diff -Naur linux-2.6.38-rc5/drivers/staging/lirc/lirc_it87.h linux-2.6.38-rc5.patch/drivers/staging/lirc/lirc_it87.h ---- linux-2.6.38-rc5/drivers/staging/lirc/lirc_it87.h 2011-02-16 04:23:45.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/staging/lirc/lirc_it87.h 1970-01-01 01:00:00.000000000 +0100 -@@ -1,116 +0,0 @@ --/* lirc_it87.h */ --/* SECTION: Definitions */ -- --/********************************* ITE IT87xx ************************/ -- --/* based on the following documentation from ITE: -- a) IT8712F Preliminary CIR Programming Guide V0.1 -- b) IT8705F Simple LPC I/O Preliminary Specification V0.3 -- c) IT8712F EC-LPC I/O Preliminary Specification V0.5 --*/ -- --/* IT8712/05 Ports: */ --#define IT87_ADRPORT 0x2e --#define IT87_DATAPORT 0x2f --#define IT87_INIT {0x87, 0x01, 0x55, 0x55} -- --/* alternate Ports: */ --/* --#define IT87_ADRPORT 0x4e --#define IT87_DATAPORT 0x4f --#define IT87_INIT {0x87, 0x01, 0x55, 0xaa} -- */ -- --/* IT8712/05 Registers */ --#define IT87_CFGCTRL 0x2 --#define IT87_LDN 0x7 --#define IT87_CHIP_ID1 0x20 --#define IT87_CHIP_ID2 0x21 --#define IT87_CFG_VERSION 0x22 --#define IT87_SWSUSPEND 0x23 -- --#define IT8712_CIR_LDN 0xa --#define IT8705_CIR_LDN 0x7 -- --/* CIR Configuration Registers: */ --#define IT87_CIR_ACT 0x30 --#define IT87_CIR_BASE_MSB 0x60 --#define IT87_CIR_BASE_LSB 0x61 --#define IT87_CIR_IRQ 0x70 --#define IT87_CIR_CONFIG 0xf0 -- --/* List of IT87_CIR registers: offset to BaseAddr */ --#define IT87_CIR_DR 0 --#define IT87_CIR_IER 1 --#define IT87_CIR_RCR 2 --#define IT87_CIR_TCR1 3 --#define IT87_CIR_TCR2 4 --#define IT87_CIR_TSR 5 --#define IT87_CIR_RSR 6 --#define IT87_CIR_BDLR 5 --#define IT87_CIR_BDHR 6 --#define IT87_CIR_IIR 7 -- --/* Bit Definition */ --/* IER: */ --#define IT87_CIR_IER_TM_EN 0x80 --#define IT87_CIR_IER_RESEVED 0x40 --#define IT87_CIR_IER_RESET 0x20 --#define IT87_CIR_IER_BR 0x10 --#define IT87_CIR_IER_IEC 0x8 --#define IT87_CIR_IER_RFOIE 0x4 --#define IT87_CIR_IER_RDAIE 0x2 --#define IT87_CIR_IER_TLDLIE 0x1 -- --/* RCR: */ --#define IT87_CIR_RCR_RDWOS 0x80 --#define IT87_CIR_RCR_HCFS 0x40 --#define IT87_CIR_RCR_RXEN 0x20 --#define IT87_CIR_RCR_RXEND 0x10 --#define IT87_CIR_RCR_RXACT 0x8 --#define IT87_CIR_RCR_RXDCR 0x7 -- --/* TCR1: */ --#define IT87_CIR_TCR1_FIFOCLR 0x80 --#define IT87_CIR_TCR1_ILE 0x40 --#define IT87_CIR_TCR1_FIFOTL 0x30 --#define IT87_CIR_TCR1_TXRLE 0x8 --#define IT87_CIR_TCR1_TXENDF 0x4 --#define IT87_CIR_TCR1_TXMPM 0x3 -- --/* TCR2: */ --#define IT87_CIR_TCR2_CFQ 0xf8 --#define IT87_CIR_TCR2_TXMPW 0x7 -- --/* TSR: */ --#define IT87_CIR_TSR_RESERVED 0xc0 --#define IT87_CIR_TSR_TXFBC 0x3f -- --/* RSR: */ --#define IT87_CIR_RSR_RXFTO 0x80 --#define IT87_CIR_RSR_RESERVED 0x40 --#define IT87_CIR_RSR_RXFBC 0x3f -- --/* IIR: */ --#define IT87_CIR_IIR_RESERVED 0xf8 --#define IT87_CIR_IIR_IID 0x6 --#define IT87_CIR_IIR_IIP 0x1 -- --/* TM: */ --#define IT87_CIR_TM_IL_SEL 0x80 --#define IT87_CIR_TM_RESERVED 0x40 --#define IT87_CIR_TM_TM_REG 0x3f -- --#define IT87_CIR_FIFO_SIZE 32 -- --/* Baudratedivisor for IT87: power of 2: only 1,2,4 or 8) */ --#define IT87_CIR_BAUDRATE_DIVISOR 0x1 --#define IT87_CIR_DEFAULT_IOBASE 0x310 --#define IT87_CIR_DEFAULT_IRQ 0x7 --#define IT87_CIR_SPACE 0x00 --#define IT87_CIR_PULSE 0xff --#define IT87_CIR_FREQ_MIN 27 --#define IT87_CIR_FREQ_MAX 58 --#define TIME_CONST (IT87_CIR_BAUDRATE_DIVISOR * 8000000ul / 115200ul) -- --/********************************* ITE IT87xx ************************/ -diff -Naur linux-2.6.38-rc5/drivers/staging/lirc/Makefile linux-2.6.38-rc5.patch/drivers/staging/lirc/Makefile ---- linux-2.6.38-rc5/drivers/staging/lirc/Makefile 2011-02-16 04:23:45.000000000 +0100 -+++ linux-2.6.38-rc5.patch/drivers/staging/lirc/Makefile 2011-02-22 03:19:26.756636211 +0100 -@@ -6,7 +6,6 @@ - obj-$(CONFIG_LIRC_BT829) += lirc_bt829.o - obj-$(CONFIG_LIRC_IGORPLUGUSB) += lirc_igorplugusb.o - obj-$(CONFIG_LIRC_IMON) += lirc_imon.o --obj-$(CONFIG_LIRC_IT87) += lirc_it87.o - obj-$(CONFIG_LIRC_ITE8709) += lirc_ite8709.o - obj-$(CONFIG_LIRC_PARALLEL) += lirc_parallel.o - obj-$(CONFIG_LIRC_SASEM) += lirc_sasem.o diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-000_crosscompile.patch b/packages/linux/patches/linux-2.6.39-next-20110324-000_crosscompile.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-000_crosscompile.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-000_crosscompile.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-002_bash_only_feature.patch b/packages/linux/patches/linux-2.6.39-next-20110324-002_bash_only_feature.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-002_bash_only_feature.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-002_bash_only_feature.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-003-no_dev_console.patch b/packages/linux/patches/linux-2.6.39-next-20110324-003-no_dev_console.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-003-no_dev_console.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-003-no_dev_console.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-004_lower_undefined_mode_timeout.patch b/packages/linux/patches/linux-2.6.39-next-20110324-004_lower_undefined_mode_timeout.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-004_lower_undefined_mode_timeout.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-004_lower_undefined_mode_timeout.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-005_kconfig_no_timestamp.patch b/packages/linux/patches/linux-2.6.39-next-20110324-005_kconfig_no_timestamp.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-005_kconfig_no_timestamp.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-005_kconfig_no_timestamp.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-006_enable_utf8.patch b/packages/linux/patches/linux-2.6.39-next-20110324-006_enable_utf8.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-006_enable_utf8.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-006_enable_utf8.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-007_die_floppy_die.patch b/packages/linux/patches/linux-2.6.39-next-20110324-007_die_floppy_die.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-007_die_floppy_die.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-007_die_floppy_die.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-008-hda_intel_prealloc_4mb_dmabuffer.patch b/packages/linux/patches/linux-2.6.39-next-20110324-008-hda_intel_prealloc_4mb_dmabuffer.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-008-hda_intel_prealloc_4mb_dmabuffer.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-008-hda_intel_prealloc_4mb_dmabuffer.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-009_disable_i8042_check_on_apple_mac.patch b/packages/linux/patches/linux-2.6.39-next-20110324-009_disable_i8042_check_on_apple_mac.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-009_disable_i8042_check_on_apple_mac.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-009_disable_i8042_check_on_apple_mac.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-052-aureal_remote_quirk-0.1.patch b/packages/linux/patches/linux-2.6.39-next-20110324-052-aureal_remote_quirk-0.1.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-052-aureal_remote_quirk-0.1.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-052-aureal_remote_quirk-0.1.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-053_ati-remote_all_keys_and_keychange-0.1.patch b/packages/linux/patches/linux-2.6.39-next-20110324-053_ati-remote_all_keys_and_keychange-0.1.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-053_ati-remote_all_keys_and_keychange-0.1.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-053_ati-remote_all_keys_and_keychange-0.1.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-062-Pioneer_DVR-216D_failed_xfermode-0.1.patch b/packages/linux/patches/linux-2.6.39-next-20110324-062-Pioneer_DVR-216D_failed_xfermode-0.1.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-062-Pioneer_DVR-216D_failed_xfermode-0.1.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-062-Pioneer_DVR-216D_failed_xfermode-0.1.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-321-linux_omap_dss2_fix_SMC_instructions.patch b/packages/linux/patches/linux-2.6.39-next-20110324-321-linux_omap_dss2_fix_SMC_instructions.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-321-linux_omap_dss2_fix_SMC_instructions.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-321-linux_omap_dss2_fix_SMC_instructions.patch diff --git a/packages/linux/patches/linux-2.6.39-next-20110321-716_mm-zero_swappiness.patch b/packages/linux/patches/linux-2.6.39-next-20110324-716_mm-zero_swappiness.patch similarity index 100% rename from packages/linux/patches/linux-2.6.39-next-20110321-716_mm-zero_swappiness.patch rename to packages/linux/patches/linux-2.6.39-next-20110324-716_mm-zero_swappiness.patch From d6c91a01cbab542249d7c1c2e17d9ab27ba9928f Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Thu, 24 Mar 2011 18:11:44 +0100 Subject: [PATCH 11/83] linux: set initramfs install dir to $(kernel_path)/initramfs Signed-off-by: Stephan Raue --- packages/linux/build | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/linux/build b/packages/linux/build index 84ad3d5c16..ed0d622184 100755 --- a/packages/linux/build +++ b/packages/linux/build @@ -22,7 +22,7 @@ . config/options $1 -export INSTALL=$(kernel_path) +export INSTALL=$(kernel_path)/initramfs $SCRIPTS/install busybox-initramfs if [ "$BOOTLOADER" = "u-boot" ]; then From 6f34e15c7de285bde795f8241f35c1664401e6e5 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Thu, 24 Mar 2011 18:13:14 +0100 Subject: [PATCH 12/83] plymouth-lite: install to /sbin, install splash to /splash, cleanup Signed-off-by: Stephan Raue --- packages/sysutils/plymouth-lite/install | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/packages/sysutils/plymouth-lite/install b/packages/sysutils/plymouth-lite/install index 6b3bd14531..df85e99e69 100755 --- a/packages/sysutils/plymouth-lite/install +++ b/packages/sysutils/plymouth-lite/install @@ -22,16 +22,12 @@ . config/options $1 -if [ "$2" = initramfs ]; then - mkdir -p $INSTALL/initramfs/bin - cp $PKG_BUILD/ply-image $INSTALL/initramfs/bin +mkdir -p $INSTALL/sbin + cp $PKG_BUILD/ply-image $INSTALL/sbin - mkdir -p $INSTALL/initramfs - if [ -f $PROJECT_DIR/$PROJECT/splash/splash.png ]; then - cp $PROJECT_DIR/$PROJECT/splash/splash.png $INSTALL/initramfs/ - else - cp $PKG_DIR/splash/splash.png $INSTALL/initramfs/ - fi - - exit 0 -fi +mkdir -p $INSTALL/splash + if [ -f $PROJECT_DIR/$PROJECT/splash/splash.png ]; then + cp $PROJECT_DIR/$PROJECT/splash/splash.png $INSTALL/splash + else + cp $PKG_DIR/splash/splash.png $INSTALL/splash + fi From 6323e4723354d110202598e5d1cc40919ed653f0 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Thu, 24 Mar 2011 18:14:44 +0100 Subject: [PATCH 13/83] busybox-initramfs: fix file locations Signed-off-by: Stephan Raue --- packages/sysutils/busybox-initramfs/scripts/init | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/sysutils/busybox-initramfs/scripts/init b/packages/sysutils/busybox-initramfs/scripts/init index b65596183a..8953a4eef4 100755 --- a/packages/sysutils/busybox-initramfs/scripts/init +++ b/packages/sysutils/busybox-initramfs/scripts/init @@ -66,8 +66,8 @@ REBOOT="0" if [ "$SPLASH" = "no" ]; then break else - if [ -f "/bin/ply-image" -a -f "/splash.png" ]; then - /bin/ply-image /splash.png + if [ -f "/sbin/ply-image" -a -f "/splash/splash.png" ]; then + /sbin/ply-image /splash/splash.png fi fi } From 9272f769ba35201fc7d37defaa69c68eea079b23 Mon Sep 17 00:00:00 2001 From: Stephan Raue Date: Thu, 24 Mar 2011 19:49:31 +0100 Subject: [PATCH 14/83] xbmc: update splash images Signed-off-by: Stephan Raue --- packages/mediacenter/xbmc/splash/splash.png | Bin 132669 -> 72336 bytes packages/mediacenter/xbmc/splash/splash1.png | Bin 298487 -> 95223 bytes packages/mediacenter/xbmc/splash/splash2.png | Bin 264342 -> 0 bytes packages/mediacenter/xbmc/splash/splash3.png | Bin 353305 -> 0 bytes packages/mediacenter/xbmc/splash/splash4.png | Bin 662486 -> 0 bytes 5 files changed, 0 insertions(+), 0 deletions(-) delete mode 100644 packages/mediacenter/xbmc/splash/splash2.png delete mode 100644 packages/mediacenter/xbmc/splash/splash3.png delete mode 100644 packages/mediacenter/xbmc/splash/splash4.png diff --git a/packages/mediacenter/xbmc/splash/splash.png b/packages/mediacenter/xbmc/splash/splash.png index 7a4fe389f089beb649b07c6cd3be036eaab85155..6b2897b0a1f049ba9438384654b6d4f016a44a9c 100644 GIT binary patch literal 72336 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