aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/rc
diff options
context:
space:
mode:
authorJames Hogan <james.hogan@imgtec.com>2014-02-28 18:28:57 -0500
committerMauro Carvalho Chehab <m.chehab@samsung.com>2014-03-11 14:47:10 -0400
commit693365337891df8677c3faf193a35a73097ed141 (patch)
tree1a47d0d0bb4af6e829b6be6d5da5861b455c0696 /drivers/media/rc
parent635abb7054f204e036bc6afe41b1f50825294867 (diff)
[media] rc: img-ir: add JVC decoder module
Add an img-ir module for decoding the JVC infrared protocol. Signed-off-by: James Hogan <james.hogan@imgtec.com> Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
Diffstat (limited to 'drivers/media/rc')
-rw-r--r--drivers/media/rc/img-ir/Kconfig7
-rw-r--r--drivers/media/rc/img-ir/Makefile1
-rw-r--r--drivers/media/rc/img-ir/img-ir-hw.c4
-rw-r--r--drivers/media/rc/img-ir/img-ir-jvc.c92
4 files changed, 104 insertions, 0 deletions
diff --git a/drivers/media/rc/img-ir/Kconfig b/drivers/media/rc/img-ir/Kconfig
index 28498a294daa..96006fbfb0d6 100644
--- a/drivers/media/rc/img-ir/Kconfig
+++ b/drivers/media/rc/img-ir/Kconfig
@@ -31,3 +31,10 @@ config IR_IMG_NEC
31 help 31 help
32 Say Y here to enable support for the NEC, extended NEC, and 32-bit 32 Say Y here to enable support for the NEC, extended NEC, and 32-bit
33 NEC protocols in the ImgTec infrared decoder block. 33 NEC protocols in the ImgTec infrared decoder block.
34
35config IR_IMG_JVC
36 bool "JVC protocol support"
37 depends on IR_IMG_HW
38 help
39 Say Y here to enable support for the JVC protocol in the ImgTec
40 infrared decoder block.
diff --git a/drivers/media/rc/img-ir/Makefile b/drivers/media/rc/img-ir/Makefile
index c4091973b35d..c5f8f06c89eb 100644
--- a/drivers/media/rc/img-ir/Makefile
+++ b/drivers/media/rc/img-ir/Makefile
@@ -2,6 +2,7 @@ img-ir-y := img-ir-core.o
2img-ir-$(CONFIG_IR_IMG_RAW) += img-ir-raw.o 2img-ir-$(CONFIG_IR_IMG_RAW) += img-ir-raw.o
3img-ir-$(CONFIG_IR_IMG_HW) += img-ir-hw.o 3img-ir-$(CONFIG_IR_IMG_HW) += img-ir-hw.o
4img-ir-$(CONFIG_IR_IMG_NEC) += img-ir-nec.o 4img-ir-$(CONFIG_IR_IMG_NEC) += img-ir-nec.o
5img-ir-$(CONFIG_IR_IMG_JVC) += img-ir-jvc.o
5img-ir-objs := $(img-ir-y) 6img-ir-objs := $(img-ir-y)
6 7
7obj-$(CONFIG_IR_IMG) += img-ir.o 8obj-$(CONFIG_IR_IMG) += img-ir.o
diff --git a/drivers/media/rc/img-ir/img-ir-hw.c b/drivers/media/rc/img-ir/img-ir-hw.c
index 139f2c70e382..81c50e3f88d9 100644
--- a/drivers/media/rc/img-ir/img-ir-hw.c
+++ b/drivers/media/rc/img-ir/img-ir-hw.c
@@ -21,12 +21,16 @@
21static DEFINE_SPINLOCK(img_ir_decoders_lock); 21static DEFINE_SPINLOCK(img_ir_decoders_lock);
22 22
23extern struct img_ir_decoder img_ir_nec; 23extern struct img_ir_decoder img_ir_nec;
24extern struct img_ir_decoder img_ir_jvc;
24 25
25static bool img_ir_decoders_preprocessed; 26static bool img_ir_decoders_preprocessed;
26static struct img_ir_decoder *img_ir_decoders[] = { 27static struct img_ir_decoder *img_ir_decoders[] = {
27#ifdef CONFIG_IR_IMG_NEC 28#ifdef CONFIG_IR_IMG_NEC
28 &img_ir_nec, 29 &img_ir_nec,
29#endif 30#endif
31#ifdef CONFIG_IR_IMG_JVC
32 &img_ir_jvc,
33#endif
30 NULL 34 NULL
31}; 35};
32 36
diff --git a/drivers/media/rc/img-ir/img-ir-jvc.c b/drivers/media/rc/img-ir/img-ir-jvc.c
new file mode 100644
index 000000000000..ae55867f6c5c
--- /dev/null
+++ b/drivers/media/rc/img-ir/img-ir-jvc.c
@@ -0,0 +1,92 @@
1/*
2 * ImgTec IR Decoder setup for JVC protocol.
3 *
4 * Copyright 2012-2014 Imagination Technologies Ltd.
5 */
6
7#include "img-ir-hw.h"
8
9/* Convert JVC data to a scancode */
10static int img_ir_jvc_scancode(int len, u64 raw, int *scancode, u64 protocols)
11{
12 unsigned int cust, data;
13
14 if (len != 16)
15 return -EINVAL;
16
17 cust = (raw >> 0) & 0xff;
18 data = (raw >> 8) & 0xff;
19
20 *scancode = cust << 8 | data;
21 return IMG_IR_SCANCODE;
22}
23
24/* Convert JVC scancode to JVC data filter */
25static int img_ir_jvc_filter(const struct rc_scancode_filter *in,
26 struct img_ir_filter *out, u64 protocols)
27{
28 unsigned int cust, data;
29 unsigned int cust_m, data_m;
30
31 cust = (in->data >> 8) & 0xff;
32 cust_m = (in->mask >> 8) & 0xff;
33 data = (in->data >> 0) & 0xff;
34 data_m = (in->mask >> 0) & 0xff;
35
36 out->data = cust | data << 8;
37 out->mask = cust_m | data_m << 8;
38
39 return 0;
40}
41
42/*
43 * JVC decoder
44 * See also http://www.sbprojects.com/knowledge/ir/jvc.php
45 * http://support.jvc.com/consumer/support/documents/RemoteCodes.pdf
46 */
47struct img_ir_decoder img_ir_jvc = {
48 .type = RC_BIT_JVC,
49 .control = {
50 .decoden = 1,
51 .code_type = IMG_IR_CODETYPE_PULSEDIST,
52 .decodend2 = 1,
53 },
54 /* main timings */
55 .unit = 527500, /* 527.5 us */
56 .timings = {
57 /* leader symbol */
58 .ldr = {
59 .pulse = { 16 /* 8.44 ms */ },
60 .space = { 8 /* 4.22 ms */ },
61 },
62 /* 0 symbol */
63 .s00 = {
64 .pulse = { 1 /* 527.5 us +-60 us */ },
65 .space = { 1 /* 527.5 us */ },
66 },
67 /* 1 symbol */
68 .s01 = {
69 .pulse = { 1 /* 527.5 us +-60 us */ },
70 .space = { 3 /* 1.5825 ms +-40 us */ },
71 },
72 /* 0 symbol (no leader) */
73 .s00 = {
74 .pulse = { 1 /* 527.5 us +-60 us */ },
75 .space = { 1 /* 527.5 us */ },
76 },
77 /* 1 symbol (no leader) */
78 .s01 = {
79 .pulse = { 1 /* 527.5 us +-60 us */ },
80 .space = { 3 /* 1.5825 ms +-40 us */ },
81 },
82 /* free time */
83 .ft = {
84 .minlen = 16,
85 .maxlen = 16,
86 .ft_min = 10, /* 5.275 ms */
87 },
88 },
89 /* scancode logic */
90 .scancode = img_ir_jvc_scancode,
91 .filter = img_ir_jvc_filter,
92};