mirror of
https://github.com/LibreELEC/LibreELEC.tv.git
synced 2025-07-28 13:16:41 +00:00
Merge pull request #2923 from HiassofT/le9-rc6-toggle
linux: replace ancient rc6 decode hack with proper fix
This commit is contained in:
commit
7ead46163b
@ -1,30 +0,0 @@
|
|||||||
diff --git a/drivers/media/rc/ir-rc6-decoder.c b/drivers/media/rc/ir-rc6-decoder.c
|
|
||||||
index 5d0d2fe..3d8cc1a 100644
|
|
||||||
--- a/drivers/media/rc/ir-rc6-decoder.c
|
|
||||||
+++ b/drivers/media/rc/ir-rc6-decoder.c
|
|
||||||
@@ -39,7 +39,6 @@
|
|
||||||
#define RC6_STARTBIT_MASK 0x08 /* for the header bits */
|
|
||||||
#define RC6_6A_MCE_TOGGLE_MASK 0x8000 /* for the body bits */
|
|
||||||
#define RC6_6A_LCC_MASK 0xffff0000 /* RC6-6A-32 long customer code mask */
|
|
||||||
-#define RC6_6A_MCE_CC 0x800f0000 /* MCE customer code */
|
|
||||||
#ifndef CHAR_BIT
|
|
||||||
#define CHAR_BIT 8 /* Normally in <limits.h> */
|
|
||||||
#endif
|
|
||||||
@@ -252,14 +251,9 @@ static int ir_rc6_decode(struct rc_dev *dev, struct ir_raw_event ev)
|
|
||||||
toggle = 0;
|
|
||||||
break;
|
|
||||||
case 32:
|
|
||||||
- if ((scancode & RC6_6A_LCC_MASK) == RC6_6A_MCE_CC) {
|
|
||||||
- protocol = RC_PROTO_RC6_MCE;
|
|
||||||
- toggle = !!(scancode & RC6_6A_MCE_TOGGLE_MASK);
|
|
||||||
- scancode &= ~RC6_6A_MCE_TOGGLE_MASK;
|
|
||||||
- } else {
|
|
||||||
- protocol = RC_PROTO_RC6_6A_32;
|
|
||||||
- toggle = 0;
|
|
||||||
- }
|
|
||||||
+ protocol = RC_PROTO_RC6_MCE;
|
|
||||||
+ toggle = !!(scancode & RC6_6A_MCE_TOGGLE_MASK);
|
|
||||||
+ scancode &= ~RC6_6A_MCE_TOGGLE_MASK;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
IR_dprintk(1, "RC6(6A) unsupported length\n");
|
|
@ -0,0 +1,52 @@
|
|||||||
|
From 3f1f8303b6e0be751d7a7c55031c8ab840ed5c1a Mon Sep 17 00:00:00 2001
|
||||||
|
From: Matthias Reichl <hias@horus.com>
|
||||||
|
Date: Fri, 24 Aug 2018 23:31:51 +0200
|
||||||
|
Subject: [PATCH] media: rc: ir-rc6-decoder: enable toggle bit for Kathrein
|
||||||
|
RCU-676 remote
|
||||||
|
|
||||||
|
The Kathrein RCU-676 remote uses the 32-bit rc6 protocol and toggles
|
||||||
|
bit 15 (0x8000) on repeated button presses, like MCE remotes.
|
||||||
|
|
||||||
|
Add it's customer code 0x80460000 to the 32-bit rc6 toggle
|
||||||
|
handling code to get proper scancodes and toggle reports.
|
||||||
|
|
||||||
|
Signed-off-by: Matthias Reichl <hias@horus.com>
|
||||||
|
---
|
||||||
|
drivers/media/rc/ir-rc6-decoder.c | 9 +++++++--
|
||||||
|
1 file changed, 7 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/drivers/media/rc/ir-rc6-decoder.c b/drivers/media/rc/ir-rc6-decoder.c
|
||||||
|
index 68487ce9f79b..d96aed1343e4 100644
|
||||||
|
--- a/drivers/media/rc/ir-rc6-decoder.c
|
||||||
|
+++ b/drivers/media/rc/ir-rc6-decoder.c
|
||||||
|
@@ -40,6 +40,7 @@
|
||||||
|
#define RC6_6A_MCE_TOGGLE_MASK 0x8000 /* for the body bits */
|
||||||
|
#define RC6_6A_LCC_MASK 0xffff0000 /* RC6-6A-32 long customer code mask */
|
||||||
|
#define RC6_6A_MCE_CC 0x800f0000 /* MCE customer code */
|
||||||
|
+#define RC6_6A_KATHREIN_CC 0x80460000 /* Kathrein RCU-676 customer code */
|
||||||
|
#ifndef CHAR_BIT
|
||||||
|
#define CHAR_BIT 8 /* Normally in <limits.h> */
|
||||||
|
#endif
|
||||||
|
@@ -242,13 +243,17 @@ static int ir_rc6_decode(struct rc_dev *dev, struct ir_raw_event ev)
|
||||||
|
toggle = 0;
|
||||||
|
break;
|
||||||
|
case 32:
|
||||||
|
- if ((scancode & RC6_6A_LCC_MASK) == RC6_6A_MCE_CC) {
|
||||||
|
+ switch (scancode & RC6_6A_LCC_MASK) {
|
||||||
|
+ case RC6_6A_MCE_CC:
|
||||||
|
+ case RC6_6A_KATHREIN_CC:
|
||||||
|
protocol = RC_PROTO_RC6_MCE;
|
||||||
|
toggle = !!(scancode & RC6_6A_MCE_TOGGLE_MASK);
|
||||||
|
scancode &= ~RC6_6A_MCE_TOGGLE_MASK;
|
||||||
|
- } else {
|
||||||
|
+ break;
|
||||||
|
+ default:
|
||||||
|
protocol = RC_PROTO_RC6_6A_32;
|
||||||
|
toggle = 0;
|
||||||
|
+ break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
--
|
||||||
|
2.11.0
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user