xref: /openbmc/linux/drivers/media/rc/img-ir/img-ir-rc5.c (revision 75bf465f0bc33e9b776a46d6a1b9b990f5fb7c37)
1*2874c5fdSThomas Gleixner // SPDX-License-Identifier: GPL-2.0-or-later
2aa7383dbSSifan Naeem /*
3aa7383dbSSifan Naeem  * ImgTec IR Decoder setup for Philips RC-5 protocol.
4aa7383dbSSifan Naeem  *
5aa7383dbSSifan Naeem  * Copyright 2012-2014 Imagination Technologies Ltd.
6aa7383dbSSifan Naeem  */
7aa7383dbSSifan Naeem 
8aa7383dbSSifan Naeem #include "img-ir-hw.h"
9aa7383dbSSifan Naeem 
10aa7383dbSSifan Naeem /* Convert RC5 data to a scancode */
img_ir_rc5_scancode(int len,u64 raw,u64 enabled_protocols,struct img_ir_scancode_req * request)11aa7383dbSSifan Naeem static int img_ir_rc5_scancode(int len, u64 raw, u64 enabled_protocols,
12aa7383dbSSifan Naeem 				struct img_ir_scancode_req *request)
13aa7383dbSSifan Naeem {
14aa7383dbSSifan Naeem 	unsigned int addr, cmd, tgl, start;
15aa7383dbSSifan Naeem 
16aa7383dbSSifan Naeem 	/* Quirk in the decoder shifts everything by 2 to the left. */
17aa7383dbSSifan Naeem 	raw   >>= 2;
18aa7383dbSSifan Naeem 
19aa7383dbSSifan Naeem 	start	=  (raw >> 13)	& 0x01;
20aa7383dbSSifan Naeem 	tgl	=  (raw >> 11)	& 0x01;
21aa7383dbSSifan Naeem 	addr	=  (raw >>  6)	& 0x1f;
22aa7383dbSSifan Naeem 	cmd	=   raw		& 0x3f;
23aa7383dbSSifan Naeem 	/*
24aa7383dbSSifan Naeem 	 * 12th bit is used to extend the command in extended RC5 and has
25aa7383dbSSifan Naeem 	 * no effect on standard RC5.
26aa7383dbSSifan Naeem 	 */
27aa7383dbSSifan Naeem 	cmd	+= ((raw >> 12) & 0x01) ? 0 : 0x40;
28aa7383dbSSifan Naeem 
29aa7383dbSSifan Naeem 	if (!start)
30aa7383dbSSifan Naeem 		return -EINVAL;
31aa7383dbSSifan Naeem 
326d741bfeSSean Young 	request->protocol = RC_PROTO_RC5;
33aa7383dbSSifan Naeem 	request->scancode = addr << 8 | cmd;
34aa7383dbSSifan Naeem 	request->toggle   = tgl;
35aa7383dbSSifan Naeem 	return IMG_IR_SCANCODE;
36aa7383dbSSifan Naeem }
37aa7383dbSSifan Naeem 
38aa7383dbSSifan Naeem /* Convert RC5 scancode to RC5 data filter */
img_ir_rc5_filter(const struct rc_scancode_filter * in,struct img_ir_filter * out,u64 protocols)39aa7383dbSSifan Naeem static int img_ir_rc5_filter(const struct rc_scancode_filter *in,
40aa7383dbSSifan Naeem 				 struct img_ir_filter *out, u64 protocols)
41aa7383dbSSifan Naeem {
42aa7383dbSSifan Naeem 	/* Not supported by the hw. */
43aa7383dbSSifan Naeem 	return -EINVAL;
44aa7383dbSSifan Naeem }
45aa7383dbSSifan Naeem 
46aa7383dbSSifan Naeem /*
47aa7383dbSSifan Naeem  * RC-5 decoder
48aa7383dbSSifan Naeem  * see http://www.sbprojects.com/knowledge/ir/rc5.php
49aa7383dbSSifan Naeem  */
50aa7383dbSSifan Naeem struct img_ir_decoder img_ir_rc5 = {
516d741bfeSSean Young 	.type      = RC_PROTO_BIT_RC5,
52aa7383dbSSifan Naeem 	.control   = {
53aa7383dbSSifan Naeem 		.bitoriend2	= 1,
54aa7383dbSSifan Naeem 		.code_type	= IMG_IR_CODETYPE_BIPHASE,
55aa7383dbSSifan Naeem 		.decodend2	= 1,
56aa7383dbSSifan Naeem 	},
57aa7383dbSSifan Naeem 	/* main timings */
58aa7383dbSSifan Naeem 	.tolerance	= 16,
59aa7383dbSSifan Naeem 	.unit		= 888888, /* 1/36k*32=888.888microseconds */
60aa7383dbSSifan Naeem 	.timings	= {
61aa7383dbSSifan Naeem 		/* 10 symbol */
62aa7383dbSSifan Naeem 		.s10 = {
63aa7383dbSSifan Naeem 			.pulse	= { 1 },
64aa7383dbSSifan Naeem 			.space	= { 1 },
65aa7383dbSSifan Naeem 		},
66aa7383dbSSifan Naeem 
67aa7383dbSSifan Naeem 		/* 11 symbol */
68aa7383dbSSifan Naeem 		.s11 = {
69aa7383dbSSifan Naeem 			.pulse	= { 1 },
70aa7383dbSSifan Naeem 			.space	= { 1 },
71aa7383dbSSifan Naeem 		},
72aa7383dbSSifan Naeem 
73aa7383dbSSifan Naeem 		/* free time */
74aa7383dbSSifan Naeem 		.ft  = {
75aa7383dbSSifan Naeem 			.minlen = 14,
76aa7383dbSSifan Naeem 			.maxlen = 14,
77aa7383dbSSifan Naeem 			.ft_min = 5,
78aa7383dbSSifan Naeem 		},
79aa7383dbSSifan Naeem 	},
80aa7383dbSSifan Naeem 
81aa7383dbSSifan Naeem 	/* scancode logic */
82aa7383dbSSifan Naeem 	.scancode	= img_ir_rc5_scancode,
83aa7383dbSSifan Naeem 	.filter		= img_ir_rc5_filter,
84aa7383dbSSifan Naeem };
85