[PATCH] v4l: 782: ir-kbd-i2c.c updates

- fixed probe function
- em2820 remote layout
- disabled em2820 pinnacle ir support
- whitespace cleanups

Signed-off-by: Markus Rechberger <mrechberger@gmail.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@brturbo.com.br>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
Markus Rechberger 2005-11-08 21:37:30 -08:00 committed by Linus Torvalds
parent 55b8b2d173
commit 2f4710b1b1
1 changed files with 122 additions and 92 deletions

View File

@ -43,100 +43,100 @@
#include <media/ir-common.h> #include <media/ir-common.h>
static IR_KEYTAB_TYPE ir_codes_em2820[IR_KEYTAB_SIZE] = { static IR_KEYTAB_TYPE ir_codes_em2820[IR_KEYTAB_SIZE] = {
[ 0 ] = KEY_CHANNEL, [ 0x00 ] = KEY_CHANNEL,
[ 1 ] = KEY_SELECT, [ 0x01 ] = KEY_SELECT,
[ 2 ] = KEY_MUTE, [ 0x02 ] = KEY_MUTE,
[ 3 ] = KEY_POWER, [ 0x03 ] = KEY_POWER,
[ 4 ] = KEY_KP1, [ 0x04 ] = KEY_KP1,
[ 5 ] = KEY_KP2, [ 0x05 ] = KEY_KP2,
[ 6 ] = KEY_KP3, [ 0x06 ] = KEY_KP3,
[ 7 ] = KEY_CHANNELUP, [ 0x07 ] = KEY_CHANNELUP,
[ 8 ] = KEY_KP4, [ 0x08 ] = KEY_KP4,
[ 9 ] = KEY_KP5, [ 0x09 ] = KEY_KP5,
[ 10 ] = KEY_KP6, [ 0x0a ] = KEY_KP6,
[ 11 ] = KEY_CHANNELDOWN, [ 0x0b ] = KEY_CHANNELDOWN,
[ 12 ] = KEY_KP7, [ 0x0c ] = KEY_KP7,
[ 13 ] = KEY_KP8, [ 0x0d ] = KEY_KP8,
[ 14 ] = KEY_KP9, [ 0x0e ] = KEY_KP9,
[ 15 ] = KEY_VOLUMEUP, [ 0x0f ] = KEY_VOLUMEUP,
[ 16 ] = KEY_KP0, [ 0x10 ] = KEY_KP0,
[ 17 ] = KEY_MENU, [ 0x11 ] = KEY_MENU,
[ 18 ] = KEY_PRINT, [ 0x12 ] = KEY_PRINT,
[ 19 ] = KEY_VOLUMEDOWN, [ 0x13 ] = KEY_VOLUMEDOWN,
[ 21 ] = KEY_PAUSE, [ 0x15 ] = KEY_PAUSE,
[ 23 ] = KEY_RECORD, [ 0x17 ] = KEY_RECORD,
[ 24 ] = KEY_REWIND, [ 0x18 ] = KEY_REWIND,
[ 25 ] = KEY_PLAY, [ 0x19 ] = KEY_PLAY,
[ 27 ] = KEY_BACKSPACE, [ 0x1b ] = KEY_BACKSPACE,
[ 29 ] = KEY_STOP, [ 0x1d ] = KEY_STOP,
[ 31 ] = KEY_ZOOM, [ 0x40 ] = KEY_ZOOM,
}; };
/* Mark Phalan <phalanm@o2.ie> */ /* Mark Phalan <phalanm@o2.ie> */
static IR_KEYTAB_TYPE ir_codes_pv951[IR_KEYTAB_SIZE] = { static IR_KEYTAB_TYPE ir_codes_pv951[IR_KEYTAB_SIZE] = {
[ 0 ] = KEY_KP0, [ 0x00 ] = KEY_KP0,
[ 1 ] = KEY_KP1, [ 0x01 ] = KEY_KP1,
[ 2 ] = KEY_KP2, [ 0x02 ] = KEY_KP2,
[ 3 ] = KEY_KP3, [ 0x03 ] = KEY_KP3,
[ 4 ] = KEY_KP4, [ 0x04 ] = KEY_KP4,
[ 5 ] = KEY_KP5, [ 0x05 ] = KEY_KP5,
[ 6 ] = KEY_KP6, [ 0x06 ] = KEY_KP6,
[ 7 ] = KEY_KP7, [ 0x07 ] = KEY_KP7,
[ 8 ] = KEY_KP8, [ 0x08 ] = KEY_KP8,
[ 9 ] = KEY_KP9, [ 0x09 ] = KEY_KP9,
[ 18 ] = KEY_POWER, [ 0x12 ] = KEY_POWER,
[ 16 ] = KEY_MUTE, [ 0x10 ] = KEY_MUTE,
[ 31 ] = KEY_VOLUMEDOWN, [ 0x1f ] = KEY_VOLUMEDOWN,
[ 27 ] = KEY_VOLUMEUP, [ 0x1b ] = KEY_VOLUMEUP,
[ 26 ] = KEY_CHANNELUP, [ 0x1a ] = KEY_CHANNELUP,
[ 30 ] = KEY_CHANNELDOWN, [ 0x1e ] = KEY_CHANNELDOWN,
[ 14 ] = KEY_PAGEUP, [ 0x0e ] = KEY_PAGEUP,
[ 29 ] = KEY_PAGEDOWN, [ 0x1d ] = KEY_PAGEDOWN,
[ 19 ] = KEY_SOUND, [ 0x13 ] = KEY_SOUND,
[ 24 ] = KEY_KPPLUSMINUS, /* CH +/- */ [ 0x18 ] = KEY_KPPLUSMINUS, /* CH +/- */
[ 22 ] = KEY_SUBTITLE, /* CC */ [ 0x16 ] = KEY_SUBTITLE, /* CC */
[ 13 ] = KEY_TEXT, /* TTX */ [ 0x0d ] = KEY_TEXT, /* TTX */
[ 11 ] = KEY_TV, /* AIR/CBL */ [ 0x0b ] = KEY_TV, /* AIR/CBL */
[ 17 ] = KEY_PC, /* PC/TV */ [ 0x11 ] = KEY_PC, /* PC/TV */
[ 23 ] = KEY_OK, /* CH RTN */ [ 0x17 ] = KEY_OK, /* CH RTN */
[ 25 ] = KEY_MODE, /* FUNC */ [ 0x19 ] = KEY_MODE, /* FUNC */
[ 12 ] = KEY_SEARCH, /* AUTOSCAN */ [ 0x0c ] = KEY_SEARCH, /* AUTOSCAN */
/* Not sure what to do with these ones! */ /* Not sure what to do with these ones! */
[ 15 ] = KEY_SELECT, /* SOURCE */ [ 0x0f ] = KEY_SELECT, /* SOURCE */
[ 10 ] = KEY_KPPLUS, /* +100 */ [ 0x0a ] = KEY_KPPLUS, /* +100 */
[ 20 ] = KEY_KPEQUAL, /* SYNC */ [ 0x14 ] = KEY_KPEQUAL, /* SYNC */
[ 28 ] = KEY_MEDIA, /* PC/TV */ [ 0x1c ] = KEY_MEDIA, /* PC/TV */
}; };
static IR_KEYTAB_TYPE ir_codes_purpletv[IR_KEYTAB_SIZE] = { static IR_KEYTAB_TYPE ir_codes_purpletv[IR_KEYTAB_SIZE] = {
[ 0x3 ] = KEY_POWER, [ 0x03 ] = KEY_POWER,
[ 0x6f ] = KEY_MUTE, [ 0x6f ] = KEY_MUTE,
[ 0x10 ] = KEY_BACKSPACE, /* Recall */ [ 0x10 ] = KEY_BACKSPACE, /* Recall */
[ 0x11 ] = KEY_KP0, [ 0x11 ] = KEY_KP0,
[ 0x4 ] = KEY_KP1, [ 0x04 ] = KEY_KP1,
[ 0x5 ] = KEY_KP2, [ 0x05 ] = KEY_KP2,
[ 0x6 ] = KEY_KP3, [ 0x06 ] = KEY_KP3,
[ 0x8 ] = KEY_KP4, [ 0x08 ] = KEY_KP4,
[ 0x9 ] = KEY_KP5, [ 0x09 ] = KEY_KP5,
[ 0xa ] = KEY_KP6, [ 0x0a ] = KEY_KP6,
[ 0xc ] = KEY_KP7, [ 0x0c ] = KEY_KP7,
[ 0xd ] = KEY_KP8, [ 0x0d ] = KEY_KP8,
[ 0xe ] = KEY_KP9, [ 0x0e ] = KEY_KP9,
[ 0x12 ] = KEY_KPDOT, /* 100+ */ [ 0x12 ] = KEY_KPDOT, /* 100+ */
[ 0x7 ] = KEY_VOLUMEUP, [ 0x07 ] = KEY_VOLUMEUP,
[ 0xb ] = KEY_VOLUMEDOWN, [ 0x0b ] = KEY_VOLUMEDOWN,
[ 0x1a ] = KEY_KPPLUS, [ 0x1a ] = KEY_KPPLUS,
[ 0x18 ] = KEY_KPMINUS, [ 0x18 ] = KEY_KPMINUS,
[ 0x15 ] = KEY_UP, [ 0x15 ] = KEY_UP,
[ 0x1d ] = KEY_DOWN, [ 0x1d ] = KEY_DOWN,
[ 0xf ] = KEY_CHANNELUP, [ 0x0f ] = KEY_CHANNELUP,
[ 0x13 ] = KEY_CHANNELDOWN, [ 0x13 ] = KEY_CHANNELDOWN,
[ 0x48 ] = KEY_ZOOM, [ 0x48 ] = KEY_ZOOM,
@ -174,6 +174,9 @@ module_param(debug, int, 0644); /* debug level (0,1,2) */
#define dprintk(level, fmt, arg...) if (debug >= level) \ #define dprintk(level, fmt, arg...) if (debug >= level) \
printk(KERN_DEBUG DEVNAME ": " fmt , ## arg) printk(KERN_DEBUG DEVNAME ": " fmt , ## arg)
#define IR_PINNACLE_REMOTE 0x01
#define IR_TERRATEC_REMOTE 0x02
/* ----------------------------------------------------------------------- */ /* ----------------------------------------------------------------------- */
static int get_key_haup(struct IR *ir, u32 *ir_key, u32 *ir_raw) static int get_key_haup(struct IR *ir, u32 *ir_key, u32 *ir_raw)
@ -287,6 +290,7 @@ static int get_key_purpletv(struct IR *ir, u32 *ir_key, u32 *ir_raw)
*ir_raw = b; *ir_raw = b;
return 1; return 1;
} }
/* ----------------------------------------------------------------------- */ /* ----------------------------------------------------------------------- */
static void ir_key_poll(struct IR *ir) static void ir_key_poll(struct IR *ir)
@ -386,24 +390,36 @@ static int ir_attach(struct i2c_adapter *adap, int addr,
ir_type = IR_TYPE_RC5; ir_type = IR_TYPE_RC5;
ir_codes = ir_codes_rc5_tv; ir_codes = ir_codes_rc5_tv;
break; break;
case 0x60:
name = "em2820";
ir->get_key = get_key_knc1;
ir->c.addr = addr>>1;
ir_type = IR_TYPE_OTHER;
ir_codes = ir_codes_em2820;
break;
case 0x30: case 0x30:
name = "KNC One"; switch(kind){
ir->get_key = get_key_knc1; case IR_TERRATEC_REMOTE:
ir_type = IR_TYPE_OTHER; name = "Terratec IR";
ir_codes = ir_codes_empty; ir->get_key = get_key_knc1;
ir_type = IR_TYPE_OTHER;
ir_codes = ir_codes_em2820;
break;
default:
name = "KNC One";
ir->get_key = get_key_knc1;
ir_type = IR_TYPE_OTHER;
ir_codes = ir_codes_em2820;
}
break; break;
case 0x47:
case 0x7a: case 0x7a:
name = "Purple TV"; switch(kind){
ir->get_key = get_key_purpletv; case IR_PINNACLE_REMOTE:
ir_type = IR_TYPE_OTHER; name = "Pinnacle IR Remote";
ir_codes = ir_codes_purpletv; ir->get_key = get_key_purpletv;
ir_type = IR_TYPE_OTHER;
ir_codes = ir_codes_em2820;
break;
default:
name = "Purple TV";
ir->get_key = get_key_purpletv;
ir_type = IR_TYPE_OTHER;
ir_codes = ir_codes_empty;
}
break; break;
default: default:
/* shouldn't happen */ /* shouldn't happen */
@ -468,9 +484,11 @@ static int ir_probe(struct i2c_adapter *adap)
static const int probe_bttv[] = { 0x1a, 0x18, 0x4b, 0x64, 0x30, -1}; static const int probe_bttv[] = { 0x1a, 0x18, 0x4b, 0x64, 0x30, -1};
static const int probe_saa7134[] = { 0x7a, -1 }; static const int probe_saa7134[] = { 0x7a, -1 };
static const int probe_em2820[] = { 0x60, -1 }; static const int probe_em2820[] = { 0x47, 0x30, -1 };
const int *probe = NULL; const int *probe = NULL;
struct i2c_client c; char buf; int i,rc; int attached = 0;
struct i2c_client c; unsigned char buf; int i,rc;
switch (adap->id) { switch (adap->id) {
case I2C_HW_B_BT848: case I2C_HW_B_BT848:
@ -488,15 +506,27 @@ static int ir_probe(struct i2c_adapter *adap)
memset(&c,0,sizeof(c)); memset(&c,0,sizeof(c));
c.adapter = adap; c.adapter = adap;
for (i = 0; -1 != probe[i]; i++) { for (i = 0; -1 != probe[i] && attached != 1; i++) {
c.addr = probe[i]; c.addr = probe[i];
rc = i2c_master_recv(&c,&buf,1); rc = i2c_master_recv(&c,&buf,1);
dprintk(1,"probe 0x%02x @ %s: %s\n", dprintk(1,"probe 0x%02x @ %s: %s\n",
probe[i], adap->name, probe[i], adap->name,
(1 == rc) ? "yes" : "no"); (1 == rc) ? "yes" : "no");
if (1 == rc) { switch(adap->id){
ir_attach(adap,probe[i],0,0); case I2C_HW_B_BT848:
break; case I2C_HW_SAA7134:
if (1 == rc) {
ir_attach(adap,probe[i],0,0);
attached=1;
break;
}
case I2C_HW_B_EM2820:
/* windows logs are needed for fixing the pinnacle device */
if (1 == rc && 0xff == buf){
ir_attach(adap,probe[i],0,IR_TERRATEC_REMOTE);
attached=1;
}
break;
} }
} }
return 0; return 0;