[media] saa7134: Add support for Compro VideoMate Vista M1F

Signed-off-by: Pavel Osnova <pvosnova@gmail.com>
Signed-off-by: Ramiro Morales <ramiro@rmorales.net>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
Ramiro Morales 2010-12-26 18:13:30 -03:00 committed by Mauro Carvalho Chehab
parent 44c6e2a7c2
commit b7a0f2e793
7 changed files with 139 additions and 0 deletions

View file

@ -180,3 +180,4 @@
179 -> Beholder BeholdTV A7 [5ace:7090]
180 -> Avermedia PCI M733A [1461:4155,1461:4255]
181 -> TechoTrend TT-budget T-3000 [13c2:2804]
183 -> Compro VideoMate Vista M1F [185b:c900]

View file

@ -81,6 +81,7 @@ obj-$(CONFIG_RC_MAP) += rc-adstech-dvb-t-pci.o \
rc-trekstor.o \
rc-tt-1500.o \
rc-twinhan1027.o \
rc-videomate-m1f.o \
rc-videomate-s350.o \
rc-videomate-tv-pvr.o \
rc-winfast.o \

View file

@ -0,0 +1,92 @@
/* videomate-m1f.h - Keytable for videomate_m1f Remote Controller
*
* keymap imported from ir-keymaps.c
*
* Copyright (c) 2010 by Pavel Osnova <pvosnova@gmail.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*/
#include <media/rc-map.h>
static struct rc_map_table videomate_m1f[] = {
{ 0x01, KEY_POWER },
{ 0x31, KEY_TUNER },
{ 0x33, KEY_VIDEO },
{ 0x2f, KEY_RADIO },
{ 0x30, KEY_CAMERA },
{ 0x2d, KEY_NEW }, /* TV record button */
{ 0x17, KEY_CYCLEWINDOWS },
{ 0x2c, KEY_ANGLE },
{ 0x2b, KEY_LANGUAGE },
{ 0x32, KEY_SEARCH }, /* '...' button */
{ 0x11, KEY_UP },
{ 0x13, KEY_LEFT },
{ 0x15, KEY_OK },
{ 0x14, KEY_RIGHT },
{ 0x12, KEY_DOWN },
{ 0x16, KEY_BACKSPACE },
{ 0x02, KEY_ZOOM }, /* WIN key */
{ 0x04, KEY_INFO },
{ 0x05, KEY_VOLUMEUP },
{ 0x03, KEY_MUTE },
{ 0x07, KEY_CHANNELUP },
{ 0x06, KEY_VOLUMEDOWN },
{ 0x08, KEY_CHANNELDOWN },
{ 0x0c, KEY_RECORD },
{ 0x0e, KEY_STOP },
{ 0x0a, KEY_BACK },
{ 0x0b, KEY_PLAY },
{ 0x09, KEY_FORWARD },
{ 0x10, KEY_PREVIOUS },
{ 0x0d, KEY_PAUSE },
{ 0x0f, KEY_NEXT },
{ 0x1e, KEY_1 },
{ 0x1f, KEY_2 },
{ 0x20, KEY_3 },
{ 0x21, KEY_4 },
{ 0x22, KEY_5 },
{ 0x23, KEY_6 },
{ 0x24, KEY_7 },
{ 0x25, KEY_8 },
{ 0x26, KEY_9 },
{ 0x2a, KEY_NUMERIC_STAR }, /* * key */
{ 0x1d, KEY_0 },
{ 0x29, KEY_SUBTITLE }, /* # key */
{ 0x27, KEY_CLEAR },
{ 0x34, KEY_SCREEN },
{ 0x28, KEY_ENTER },
{ 0x19, KEY_RED },
{ 0x1a, KEY_GREEN },
{ 0x1b, KEY_YELLOW },
{ 0x1c, KEY_BLUE },
{ 0x18, KEY_TEXT },
};
static struct rc_map_list videomate_m1f_map = {
.map = {
.scan = videomate_m1f,
.size = ARRAY_SIZE(videomate_m1f),
.rc_type = RC_TYPE_UNKNOWN, /* Legacy IR type */
.name = RC_MAP_VIDEOMATE_M1F,
}
};
static int __init init_rc_map_videomate_m1f(void)
{
return rc_map_register(&videomate_m1f_map);
}
static void __exit exit_rc_map_videomate_m1f(void)
{
rc_map_unregister(&videomate_m1f_map);
}
module_init(init_rc_map_videomate_m1f)
module_exit(exit_rc_map_videomate_m1f)
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Pavel Osnova <pvosnova@gmail.com>");

View file

@ -5538,6 +5538,37 @@ struct saa7134_board saa7134_boards[] = {
.amux = LINE2,
} },
},
[SAA7134_BOARD_VIDEOMATE_M1F] = {
/* Pavel Osnova <pvosnova@gmail.com> */
.name = "Compro VideoMate Vista M1F",
.audio_clock = 0x00187de7,
.tuner_type = TUNER_LG_PAL_NEW_TAPC,
.radio_type = TUNER_TEA5767,
.tuner_addr = ADDR_UNSET,
.radio_addr = 0x60,
.inputs = { {
.name = name_tv,
.vmux = 1,
.amux = TV,
.tv = 1,
}, {
.name = name_comp1,
.vmux = 3,
.amux = LINE2,
}, {
.name = name_svideo,
.vmux = 8,
.amux = LINE2,
} },
.radio = {
.name = name_radio,
.amux = LINE1,
},
.mute = {
.name = name_mute,
.amux = TV,
},
},
};
@ -6730,6 +6761,12 @@ struct pci_device_id saa7134_pci_tbl[] = {
.subvendor = 0x5ace, /* Beholder Intl. Ltd. */
.subdevice = 0x7090,
.driver_data = SAA7134_BOARD_BEHOLD_A7,
}, {
.vendor = PCI_VENDOR_ID_PHILIPS,
.device = PCI_DEVICE_ID_PHILIPS_SAA7135,
.subvendor = 0x185b,
.subdevice = 0xc900,
.driver_data = SAA7134_BOARD_VIDEOMATE_M1F,
}, {
/* --- boards without eeprom + subsystem ID --- */
.vendor = PCI_VENDOR_ID_PHILIPS,
@ -7046,6 +7083,7 @@ int saa7134_board_init1(struct saa7134_dev *dev)
case SAA7134_BOARD_VIDEOMATE_TV_PVR:
case SAA7134_BOARD_VIDEOMATE_GOLD_PLUS:
case SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII:
case SAA7134_BOARD_VIDEOMATE_M1F:
case SAA7134_BOARD_VIDEOMATE_DVBT_300:
case SAA7134_BOARD_VIDEOMATE_DVBT_200:
case SAA7134_BOARD_VIDEOMATE_DVBT_200A:

View file

@ -721,6 +721,11 @@ int saa7134_input_init1(struct saa7134_dev *dev)
mask_keyup = 0x020000;
polling = 50; /* ms */
break;
case SAA7134_BOARD_VIDEOMATE_M1F:
ir_codes = RC_MAP_VIDEOMATE_M1F;
mask_keycode = 0x0ff00;
mask_keyup = 0x040000;
break;
}
if (NULL == ir_codes) {
printk("%s: Oops: IR config error [card=%d]\n",

View file

@ -326,6 +326,7 @@ struct saa7134_card_ir {
#define SAA7134_BOARD_AVERMEDIA_M733A 180
#define SAA7134_BOARD_TECHNOTREND_BUDGET_T3000 181
#define SAA7134_BOARD_KWORLD_PCI_SBTVD_FULLSEG 182
#define SAA7134_BOARD_VIDEOMATE_M1F 183
#define SAA7134_MAXBOARDS 32
#define SAA7134_INPUT_MAX 8

View file

@ -138,6 +138,7 @@ void rc_map_init(void);
#define RC_MAP_TREKSTOR "rc-trekstor"
#define RC_MAP_TT_1500 "rc-tt-1500"
#define RC_MAP_TWINHAN_VP1027_DVBS "rc-twinhan1027"
#define RC_MAP_VIDEOMATE_M1F "rc-videomate-m1f"
#define RC_MAP_VIDEOMATE_S350 "rc-videomate-s350"
#define RC_MAP_VIDEOMATE_TV_PVR "rc-videomate-tv-pvr"
#define RC_MAP_WINFAST "rc-winfast"