亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ir-kbd-gpio.c

?? 這是一個市場上常見電視卡的驅動程序源代碼
?? C
字號:
/*
 * Copyright (c) 2003 Gerd Knorr
 * Copyright (c) 2003 Pavel Machek
 *
 * 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.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 */

#include <linux/module.h>
#include <linux/init.h>
#include <linux/input.h>
#include <linux/delay.h>
#include <linux/interrupt.h>
#include <linux/input.h>
#include <linux/pci.h>

#include <media/ir-common.h>

#include "bttv.h"

/* ---------------------------------------------------------------------- */

static IR_KEYTAB_TYPE ir_codes_avermedia[IR_KEYTAB_SIZE] = {
	[ 17 ] = KEY_KP0, 
	[ 20 ] = KEY_KP1, 
	[ 12 ] = KEY_KP2, 
	[ 28 ] = KEY_KP3, 
	[ 18 ] = KEY_KP4, 
	[ 10 ] = KEY_KP5, 
	[ 26 ] = KEY_KP6, 
	[ 22 ] = KEY_KP7, 
	[ 14 ] = KEY_KP8, 
	[ 30 ] = KEY_KP9, 

	[ 24 ] = KEY_EJECTCD,     // Unmarked on my controller
	[  0 ] = KEY_POWER, 
	[  9 ] = BTN_LEFT,        // DISPLAY/L
	[ 25 ] = BTN_RIGHT,       // LOOP/R
	[  5 ] = KEY_MUTE, 
	[ 19 ] = KEY_RECORD, 
	[ 11 ] = KEY_PAUSE, 
	[ 27 ] = KEY_STOP, 
	[ 15 ] = KEY_VOLUMEDOWN, 
	[ 31 ] = KEY_VOLUMEUP, 

	[ 16 ] = KEY_TUNER,       // TV/FM
	[  8 ] = KEY_CD, 
	[  4 ] = KEY_VIDEO, 
	[  2 ] = KEY_AUDIO, 
	[  6 ] = KEY_ZOOM,        // full screen
	[  1 ] = KEY_INFO,        // preview 
	[ 21 ] = KEY_SEARCH,      // autoscan
	[ 13 ] = KEY_STOP,        // freeze 
	[ 29 ] = KEY_RECORD,      // capture 
	[  3 ] = KEY_PLAY,        // unmarked
	[ 24 ] = KEY_RED,         // unmarked
	[  7 ] = KEY_GREEN,       // unmarked

#if 0
	[ 16 ] = KEY_YELLOW,      // unmarked
	[  8 ] = KEY_CHANNELDOWN, 
	[ 24 ] = KEY_CHANNELUP, 
	[  0 ] = KEY_BLUE,        // unmarked
#endif
};

static IR_KEYTAB_TYPE winfast_codes[IR_KEYTAB_SIZE] = {
	[  5 ] = KEY_KP1,
	[  6 ] = KEY_KP2,
	[  7 ] = KEY_KP3,
	[  9 ] = KEY_KP4,
	[ 10 ] = KEY_KP5,
	[ 11 ] = KEY_KP6,
	[ 13 ] = KEY_KP7,
	[ 14 ] = KEY_KP8,
	[ 15 ] = KEY_KP9,
	[ 18 ] = KEY_KP0,

	[  0 ] = KEY_POWER,
//      [ 27 ] = MTS button
	[  2 ] = KEY_TUNER,     // TV/FM
	[ 30 ] = KEY_VIDEO,
//      [ 22 ] = display button
	[  4 ] = KEY_VOLUMEUP,
	[  8 ] = KEY_VOLUMEDOWN,
	[ 12 ] = KEY_CHANNELUP,
	[ 16 ] = KEY_CHANNELDOWN,
	[  3 ] = KEY_ZOOM,      // fullscreen
	[ 31 ] = KEY_SUBTITLE,  // closed caption/teletext
	[ 32 ] = KEY_SLEEP,
//      [ 41 ] = boss key
	[ 20 ] = KEY_MUTE,
	[ 43 ] = KEY_RED,
	[ 44 ] = KEY_GREEN,
	[ 45 ] = KEY_YELLOW,
	[ 46 ] = KEY_BLUE,
	[ 24 ] = KEY_KPPLUS,    //fine tune +
	[ 25 ] = KEY_KPMINUS,   //fine tune -
//      [ 42 ] = picture in picture
        [ 33 ] = KEY_KPDOT,
	[ 19 ] = KEY_KPENTER,
//      [ 17 ] = recall
	[ 34 ] = KEY_BACK,
	[ 35 ] = KEY_PLAYPAUSE,
	[ 36 ] = KEY_NEXT,
//      [ 37 ] = time shifting
	[ 38 ] = KEY_STOP,
	[ 39 ] = KEY_RECORD
//      [ 40 ] = snapshot
};

static IR_KEYTAB_TYPE ir_codes_pixelview[IR_KEYTAB_SIZE] = {
	[  2 ] = KEY_KP0,
	[  1 ] = KEY_KP1,
	[ 11 ] = KEY_KP2,
	[ 27 ] = KEY_KP3,
	[  5 ] = KEY_KP4,
	[  9 ] = KEY_KP5,
	[ 21 ] = KEY_KP6,
	[  6 ] = KEY_KP7,
	[ 10 ] = KEY_KP8,
	[ 18 ] = KEY_KP9,
	
	[  3 ] = KEY_TUNER,       // TV/FM
	[  7 ] = KEY_SEARCH,      // scan
	[ 28 ] = KEY_ZOOM,        // full screen
	[ 30 ] = KEY_POWER,
	[ 23 ] = KEY_VOLUMEDOWN,
	[ 31 ] = KEY_VOLUMEUP,
	[ 20 ] = KEY_CHANNELDOWN,
	[ 22 ] = KEY_CHANNELUP,
	[ 24 ] = KEY_MUTE,
	
	[  0 ] = KEY_LIST,        // source
	[ 19 ] = KEY_INFO,        // loop
	[ 16 ] = KEY_LAST,        // +100
	[ 13 ] = KEY_CLEAR,       // reset
	[ 12 ] = BTN_RIGHT,       // fun++
	[  4 ] = BTN_LEFT,        // fun--
	[ 14 ] = KEY_GOTO,        // function
	[ 15 ] = KEY_STOP,         // freeze
};

/* ---------------------------------------------------------------------- */

struct IR {
	struct bttv_sub_device  *sub;
	struct input_dev        input;
	struct ir_input_state   ir;
	char                    name[32];
	char                    phys[32];
	u32                     mask_keycode;
	u32                     mask_keydown;
	u32                     mask_keyup;

	int                     polling;
	u32                     last_gpio;
	struct work_struct      work;
	struct timer_list       timer;
};

static int debug = 0;    /* debug level (0,1,2) */
MODULE_PARM(debug,"i");

#define DEVNAME "ir-kbd-gpio"
#define dprintk(fmt, arg...)	if (debug) \
	printk(KERN_DEBUG DEVNAME ": " fmt , ## arg)

static void ir_irq(struct bttv_sub_device *sub);
static int ir_probe(struct device *dev);
static int ir_remove(struct device *dev);

static struct bttv_sub_driver driver = {
	.drv.name	= DEVNAME,
	.drv.probe	= ir_probe,
	.drv.remove	= ir_remove,
	.gpio_irq       = ir_irq,
};

/* ---------------------------------------------------------------------- */

static void ir_handle_key(struct IR *ir)
{
	u32 gpio,data;

	/* read gpio value */
	gpio = bttv_gpio_read(ir->sub->core);
	if (ir->polling) {
		if (ir->last_gpio == gpio)
			return;
		ir->last_gpio = gpio;
	}
	
	/* extract data */
	data = ir_extract_bits(gpio, ir->mask_keycode);
	dprintk(DEVNAME ": irq gpio=0x%x code=%d | %s%s%s\n",
		gpio, data,
		ir->polling               ? "poll"  : "irq",
		(gpio & ir->mask_keydown) ? " down" : "",
		(gpio & ir->mask_keyup)   ? " up"   : "");

	if (ir->mask_keydown) {
		/* bit set on keydown */
		if (gpio & ir->mask_keydown) {
			ir_input_keydown(&ir->input,&ir->ir,data,data);
		} else {
			ir_input_nokey(&ir->input,&ir->ir);
		}

	} else if (ir->mask_keyup) {
		/* bit cleared on keydown */
		if (0 == (gpio & ir->mask_keyup)) {
			ir_input_keydown(&ir->input,&ir->ir,data,data);
		} else {
			ir_input_nokey(&ir->input,&ir->ir);
		}

	} else {
		/* can't disturgissh keydown/up :-/ */
		ir_input_keydown(&ir->input,&ir->ir,data,data);
		ir_input_nokey(&ir->input,&ir->ir);
	}
}

static void ir_irq(struct bttv_sub_device *sub)
{
	struct IR *ir = dev_get_drvdata(&sub->dev);

	if (!ir->polling)
		ir_handle_key(ir);
}

static void ir_timer(unsigned long data)
{
	struct IR *ir = (struct IR*)data;

	schedule_work(&ir->work);
}

static void ir_work(void *data)
{
	struct IR *ir = data;
	unsigned long timeout;

	ir_handle_key(ir);
	timeout = jiffies + (ir->polling * HZ / 1000);
	mod_timer(&ir->timer, timeout);
}

/* ---------------------------------------------------------------------- */

static int ir_probe(struct device *dev)
{
	struct bttv_sub_device *sub = to_bttv_sub_dev(dev);
	struct IR *ir;
	IR_KEYTAB_TYPE *ir_codes = NULL;
	int ir_type = IR_TYPE_OTHER;

	ir = kmalloc(sizeof(*ir),GFP_KERNEL);
	if (NULL == ir)
		return -ENOMEM;
	memset(ir,0,sizeof(*ir));

	/* detect & configure */
	switch (sub->core->type) {
	case BTTV_AVERMEDIA:
	case BTTV_AVPHONE98:
		ir_codes         = ir_codes_avermedia;
		ir->mask_keycode = 0xf80000;
		ir->mask_keydown = 0x010000;
		break;
	case BTTV_WINFAST2000:
		ir_codes         = winfast_codes;
		ir->mask_keycode = 0x8f8;
		break;
	case BTTV_PV_BT878P_9B:
	case BTTV_PV_BT878P_PLUS:
		ir_codes         = ir_codes_pixelview;
		ir->mask_keycode = 0x001f00;
		ir->mask_keyup   = 0x008000;
		ir->polling      = 500; // ms
                break;
	}
	if (NULL == ir_codes) {
		kfree(ir);
		return -ENODEV;
	}

	/* init hardware-specific stuff */
	bttv_gpio_inout(sub->core, ir->mask_keycode | ir->mask_keydown, 0);
	ir->sub = sub;
	
	/* init input device */
	snprintf(ir->name, sizeof(ir->name), "bttv IR (card=%d)",
		 sub->core->type);
	snprintf(ir->phys, sizeof(ir->phys), "pci-%s/ir0",
		 pci_name(sub->core->pci));

	ir_input_init(&ir->input, &ir->ir, ir_type, ir_codes);
	ir->input.name = ir->name;
#if LINUX_VERSION_CODE > KERNEL_VERSION(2,5,0)
	ir->input.phys = ir->phys;
	ir->input.id.bustype = BUS_PCI;
	ir->input.id.version = 1;
	if (sub->core->pci->subsystem_vendor) {
		ir->input.id.vendor  = sub->core->pci->subsystem_vendor;
		ir->input.id.product = sub->core->pci->subsystem_device;
	} else {
		ir->input.id.vendor  = sub->core->pci->vendor;
		ir->input.id.product = sub->core->pci->device;
	}
#endif

	if (ir->polling) {
		INIT_WORK(&ir->work, ir_work, ir);
		init_timer(&ir->timer);
		ir->timer.function = ir_timer;
		ir->timer.data     = (unsigned long)ir;
		schedule_work(&ir->work);
	}

	/* all done */
	dev_set_drvdata(dev,ir);
	input_register_device(&ir->input);
	printk(DEVNAME ": %s detected at %s\n",ir->input.name,ir->input.phys);

	return 0;
}

static int ir_remove(struct device *dev)
{
	struct IR *ir = dev_get_drvdata(dev);

	if (ir->polling) {
		del_timer(&ir->timer);
		flush_scheduled_work();
	}

	input_unregister_device(&ir->input);
	kfree(ir);
	return 0;
}

/* ---------------------------------------------------------------------- */

MODULE_AUTHOR("Gerd Knorr, Pavel Machek");
MODULE_DESCRIPTION("input driver for bt8x8 gpio IR remote controls");
MODULE_LICENSE("GPL");

static int ir_init(void)
{
	return bttv_sub_register(&driver, "remote");
}

static void ir_fini(void)
{
	bttv_sub_unregister(&driver);
}

module_init(ir_init);
module_exit(ir_fini);


/*
 * Local variables:
 * c-basic-offset: 8
 * End:
 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区精品在线观看| 99在线热播精品免费| 国产91精品露脸国语对白| 在线观看成人免费视频| 国产女同互慰高潮91漫画| 肉色丝袜一区二区| 91久久久免费一区二区| 国产午夜亚洲精品不卡| 奇米四色…亚洲| 91黄色免费看| 亚洲欧洲av色图| 国产成人午夜高潮毛片| 日韩精品一区二区三区三区免费| 欧美韩国日本一区| 毛片一区二区三区| 欧美日韩三级一区二区| 中文字幕亚洲区| 成人黄动漫网站免费app| 精品国产一区二区三区av性色 | 亚洲视频电影在线| 加勒比av一区二区| 欧美一区二区在线看| 亚洲午夜精品17c| 91色porny| 一区二区三区中文字幕| 99v久久综合狠狠综合久久| 亚洲国产高清不卡| 国产馆精品极品| 久久精品一区八戒影视| 国产专区欧美精品| 久久精品一区二区三区四区| 精品一区二区三区日韩| 在线不卡欧美精品一区二区三区| 欧美一区二区三区免费视频 | 午夜私人影院久久久久| 成人ar影院免费观看视频| 欧美激情一区三区| 成人黄色软件下载| 亚洲乱码国产乱码精品精98午夜 | 国产精品看片你懂得| 国产成人免费视| 中文字幕av免费专区久久| 成人小视频免费观看| 亚洲欧洲一区二区在线播放| 风间由美性色一区二区三区| 3d成人h动漫网站入口| 亚洲免费看黄网站| 一本久久精品一区二区| 亚洲精品视频免费看| 欧美日韩一区国产| 久久精品国产99国产精品| 精品福利一二区| 国产精品一二三在| 亚洲激情五月婷婷| 6080yy午夜一二三区久久| 久久精品国产一区二区| 亚洲国产成人在线| 欧美性感一区二区三区| 免费成人小视频| 国产目拍亚洲精品99久久精品| 亚洲欧美日韩系列| 欧美色网一区二区| 久久99热狠狠色一区二区| 中文字幕av资源一区| 欧美色中文字幕| 国产成都精品91一区二区三| 一区二区三区日韩精品| 日韩一区二区麻豆国产| 99久久99久久精品免费看蜜桃| 欧美一区二区三区日韩| 国产成人综合亚洲网站| 亚洲中国最大av网站| 久久亚洲欧美国产精品乐播 | 99riav久久精品riav| 亚洲一区二区av电影| 日韩欧美国产电影| 一本大道久久a久久精二百| 秋霞电影一区二区| 亚洲色图制服丝袜| 久久这里都是精品| 色吧成人激情小说| 国产成人av电影在线播放| 三级欧美韩日大片在线看| 国产日韩欧美不卡| 91.成人天堂一区| 色婷婷综合久久久久中文一区二区| 久久久亚洲国产美女国产盗摄| 午夜精品久久久久久久久久| 久久色在线观看| 欧美高清视频在线高清观看mv色露露十八 | 欧美日韩亚洲综合一区二区三区| 国产精品久久久久精k8| 欧美精品成人一区二区三区四区| 亚洲成人高清在线| 中文字幕中文字幕中文字幕亚洲无线| 看片的网站亚洲| 亚洲综合偷拍欧美一区色| 久久色视频免费观看| 日韩亚洲电影在线| 欧美在线free| 91亚洲国产成人精品一区二区三| 亚洲人一二三区| 国产精品免费av| 2020日本不卡一区二区视频| 日韩一区二区三区精品视频| 欧美日韩免费在线视频| 色视频成人在线观看免| 成年人网站91| 99久久伊人精品| 99免费精品在线观看| 国产成人一级电影| 国产在线看一区| 国产又粗又猛又爽又黄91精品| 国产清纯白嫩初高生在线观看91| 99在线精品免费| 99麻豆久久久国产精品免费| 国产91丝袜在线18| 国产iv一区二区三区| 国产成人午夜视频| 99久久精品国产精品久久| 成人性色生活片免费看爆迷你毛片| 中文字幕一区二区三中文字幕| 欧美中文字幕一区二区三区亚洲| 天堂一区二区在线免费观看| 午夜国产不卡在线观看视频| 日韩精品亚洲一区| 蜜臀av国产精品久久久久 | 欧美日韩一卡二卡| 911精品国产一区二区在线| 欧美一级艳片视频免费观看| 91精品国产欧美一区二区18| 日韩一级片在线播放| 久久久久久久久免费| 国产精品久久久久一区二区三区| 欧美一区二区日韩一区二区| 日韩欧美色电影| 国产农村妇女毛片精品久久麻豆| 欧美少妇性性性| 日韩精品在线看片z| 欧美激情一区二区| 亚洲一二三四区不卡| 蜜臀av在线播放一区二区三区| 亚洲精品乱码久久久久久| 亚洲国产精品久久艾草纯爱| 天堂影院一区二区| 岛国精品在线观看| 欧美三级日本三级少妇99| 精品国产乱码久久久久久浪潮| 99热精品一区二区| 91超碰这里只有精品国产| 国产日韩一级二级三级| 一区二区在线观看免费视频播放| 久久人人97超碰com| 亚洲另类一区二区| 日韩国产精品久久久| 粉嫩嫩av羞羞动漫久久久 | 精品国产一区二区三区忘忧草| 成人激情免费视频| 欧美日韩精品一区二区三区蜜桃 | 91丝袜国产在线播放| 色综合激情久久| 欧美一级搡bbbb搡bbbb| 国产精品久久久久9999吃药| 蜜臀99久久精品久久久久久软件| 亚洲综合视频网| 福利一区二区在线| 欧美一级久久久久久久大片| 中文字幕中文字幕一区二区| 看片网站欧美日韩| 欧美老肥妇做.爰bbww| 久久蜜桃一区二区| 日韩国产欧美一区二区三区| 91免费视频观看| 国产精品久久久久国产精品日日| 国产精品久久一卡二卡| 日本aⅴ免费视频一区二区三区| 亚洲国产毛片aaaaa无费看| 高清不卡一二三区| 91精品国产综合久久福利软件 | 久久影院电视剧免费观看| 亚洲国产美国国产综合一区二区| 亚洲狠狠爱一区二区三区| 国产成人h网站| 精品日韩av一区二区| 天堂一区二区在线| 欧美三区在线视频| 伊人色综合久久天天人手人婷| 日韩国产成人精品| 99麻豆久久久国产精品免费| 久久精品亚洲精品国产欧美| 久久机这里只有精品| 欧美日韩免费视频| 亚洲国产成人高清精品| 色狠狠av一区二区三区| 亚洲欧美激情视频在线观看一区二区三区| 亚洲日本一区二区三区| 成人精品视频网站| 国产精品福利在线播放| 成人激情免费电影网址| 亚洲视频一二三|