blob: 528050e39ad9d539877294f5db2130b771e7d3c7 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002 *
3 * some common structs and functions to handle infrared remotes via
4 * input layer ...
5 *
6 * (c) 2003 Gerd Knorr <kraxel@bytesex.org> [SuSE Labs]
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 */
22
Mauro Carvalho Chehabd5e52652005-11-08 21:37:32 -080023#ifndef _IR_COMMON
24#define _IR_COMMON
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
Mauro Carvalho Chehabd5e52652005-11-08 21:37:32 -080026#include <linux/input.h>
Mauro Carvalho Chehab0b778a52006-12-27 14:04:09 -020027#include <linux/workqueue.h>
Mauro Carvalho Chehab622ecb32008-08-05 10:03:17 -030028#include <linux/interrupt.h>
Mauro Carvalho Chehab446e4a62009-12-11 08:34:07 -030029#include <media/ir-core.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
Hermann Pitton91607232006-12-07 21:45:28 -030031#define RC5_START(x) (((x)>>12)&3)
32#define RC5_TOGGLE(x) (((x)>>11)&1)
33#define RC5_ADDR(x) (((x)>>6)&31)
34#define RC5_INSTR(x) ((x)&63)
35
Linus Torvalds1da177e2005-04-16 15:20:36 -070036struct ir_input_state {
37 /* configuration */
Mauro Carvalho Chehab971e8292009-12-14 13:53:37 -030038 u64 ir_type;
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
40 /* key info */
Mauro Carvalho Chehab8573b742009-11-27 22:40:22 -030041 u32 ir_key; /* ir scancode */
Linus Torvalds1da177e2005-04-16 15:20:36 -070042 u32 keycode; /* linux key code */
43 int keypressed; /* current state */
44};
45
Hermann Pitton91607232006-12-07 21:45:28 -030046/* this was saa7134_ir and bttv_ir, moved here for
47 * rc5 decoding. */
48struct card_ir {
49 struct input_dev *dev;
50 struct ir_input_state ir;
51 char name[32];
52 char phys[32];
Mauro Carvalho Chehab716aab42010-03-31 14:40:35 -030053 int users;
Hermann Pitton91607232006-12-07 21:45:28 -030054
Mauro Carvalho Chehab02108942010-03-20 00:25:37 -030055 u32 running:1;
56 struct ir_dev_props props;
57
Hermann Pitton91607232006-12-07 21:45:28 -030058 /* Usual gpio signalling */
59
60 u32 mask_keycode;
61 u32 mask_keydown;
62 u32 mask_keyup;
63 u32 polling;
64 u32 last_gpio;
65 int shift_by;
66 int start; // What should RC5_START() be
67 int addr; // What RC5_ADDR() should be.
68 int rc5_key_timeout;
69 int rc5_remote_gap;
70 struct work_struct work;
71 struct timer_list timer;
72
73 /* RC5 gpio */
74 u32 rc5_gpio;
75 struct timer_list timer_end; /* timer_end for code completion */
76 struct timer_list timer_keyup; /* timer_end for key release */
77 u32 last_rc5; /* last good rc5 code */
78 u32 last_bit; /* last raw bit seen */
79 u32 code; /* raw code under construction */
80 struct timeval base_time; /* time of last seen code */
81 int active; /* building raw code */
Mauro Carvalho Chehab622ecb32008-08-05 10:03:17 -030082
83 /* NEC decoding */
84 u32 nec_gpio;
85 struct tasklet_struct tlet;
Mauro Carvalho Chehaba3572c32010-03-20 20:59:44 -030086
87 /* IR core raw decoding */
88 u32 raw_decode;
Hermann Pitton91607232006-12-07 21:45:28 -030089};
90
Mauro Carvalho Chehabef53a112009-11-27 22:01:23 -030091/* Routines from ir-functions.c */
92
Mauro Carvalho Chehab055cd552009-11-29 08:19:59 -030093int ir_input_init(struct input_dev *dev, struct ir_input_state *ir,
Mauro Carvalho Chehab971e8292009-12-14 13:53:37 -030094 const u64 ir_type);
Linus Torvalds1da177e2005-04-16 15:20:36 -070095void ir_input_nokey(struct input_dev *dev, struct ir_input_state *ir);
96void ir_input_keydown(struct input_dev *dev, struct ir_input_state *ir,
Mauro Carvalho Chehab8573b742009-11-27 22:40:22 -030097 u32 ir_key);
Linus Torvalds1da177e2005-04-16 15:20:36 -070098u32 ir_extract_bits(u32 data, u32 mask);
99int ir_dump_samples(u32 *samples, int count);
100int ir_decode_biphase(u32 *samples, int count, int low, int high);
Mauro Carvalho Chehab793cf9e2005-09-09 13:03:37 -0700101int ir_decode_pulsedistance(u32 *samples, int count, int low, int high);
Andy Walls1d23a002009-09-27 20:05:23 -0300102u32 ir_rc5_decode(unsigned int code);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103
Hermann Pitton91607232006-12-07 21:45:28 -0300104void ir_rc5_timer_end(unsigned long data);
105void ir_rc5_timer_keyup(unsigned long data);
106
Mauro Carvalho Chehabd5e52652005-11-08 21:37:32 -0800107#endif