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

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

?? plx9052-24.c

?? 關于linux中pci驅動的一些代碼,實現了一些功能
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*======================================================================    Device driver for PLX9052 PCI-to-PCMCIA bridges.    Version 0.1.5.    (C) 2003 Pavel Roskin <proski@gnu.org>    The contents of this file are subject to the Mozilla Public    License Version 1.1 (the "License"); you may not use this file    except in compliance with the License. You may obtain a copy of    the License at http://www.mozilla.org/MPL/    Software distributed under the License is distributed on an "AS    IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or    implied. See the License for the specific language governing    rights and limitations under the License.    Alternatively, the contents of this file may be used under the    terms of the GNU General Public License version 2 (the "GPL"), in    which case the provisions of the GPL are applicable instead of the    above.  If you wish to allow the use of your version of this file    only under the terms of the GPL and not to allow others to use    your version of this file under the MPL, indicate your decision    by deleting the provisions above and replace them with the notice    and other provisions required by the GPL.  If you do not delete    the provisions above, a recipient may use your version of this    file under either the MPL or the GPL.======================================================================*/#include <linux/module.h>#include <linux/init.h>#include <linux/config.h>#include <linux/types.h>#include <linux/fcntl.h>#include <linux/string.h>#include <linux/kernel.h>#include <linux/errno.h>#include <linux/timer.h>#include <linux/sched.h>#include <linux/slab.h>#include <linux/pci.h>#include <linux/interrupt.h>#include <linux/ioport.h>#include <linux/delay.h>#include <linux/spinlock.h>#include <linux/tqueue.h>#include <linux/version.h>#include <asm/irq.h>#include <asm/io.h>#include <asm/bitops.h>#include <asm/system.h>#include <pcmcia/version.h>#include <pcmcia/cs_types.h>#include <pcmcia/ss.h>#include <pcmcia/cs.h>/*====================================================================*//* Module parameters */MODULE_AUTHOR("Pavel Roskin <proski@gnu.org>");MODULE_DESCRIPTION("PLX9052 PCMCIA socket driver");MODULE_LICENSE("Dual MPL/GPL");/*====================================================================*/#define DEVICE_NAME "plx9052"#define PLX_IOWIN_MIN	0x04	/* Minimal I/O window */#define PLX_IOWIN_MAX	0x1000	/* Maximal I/O window */#define PLX_MEMWIN_MIN	0x10	/* Minimal memory window */#define PLX_MEMWIN_MAX	0x80000	/* Maximal memory window */#define PLX_CIS_START	0x03000000	/* Start of CIS in PLX local memory *//* * PLX9052 has 4 local address spaces. * The driver allocates them dynamically. */#define PLX_AREAS	4	/* Number of local address spaces (areas) */#define PLX_AREA_USED	0x20	/* Area is used */#define PLX_AREA_IO	0x10	/* Area is used for I/O window */#define PLX_AREA_MAP_MASK	0x0f	/* Map number *//* PCI base address for corresponding local address space */#define PLX_PCI_BASE(x)	(PCI_BASE_ADDRESS_2 + (x << 2))/* PLX9052 registers *//* Local address space range (0 <= x < PLX_AREAS) */#define PLX_LASRR(x)	(0x00 + (x << 2))#define PLX_LASRR_IO	1	/* Range is used as I/O space */#define PLX_LAS_MEMMASK	0x0ffffff0	/* Mask for memory address lines */#define PLX_LAS_IOMASK	0x0ffffffc	/* Mask for I/O address lines *//* Local address space base address (0 <= x < PLX_AREAS) */#define PLX_LASBA(x)	(0x14 + (x << 2))#define PLX_LASBA_DISABLE 0	/* Disable address decoding */#define PLX_LASBA_ENABLE  1	/* Enable address decoding *//* Local address space bus region descriptors (0 <= x < PLX_AREAS) */#define PLX_LASBRD(x)	(0x28 + (x << 2))#define PLX_LASBRD_WIDTH_MASK	0x00c00000#define PLX_LASBRD_WIDTH_8	0x00000000#define PLX_LASBRD_WIDTH_16	0x00400000#define PLX_LASBRD_WIDTH_32	0x00800000#define PLX_LASBRD_WS_MASK	0x003fffc0#define PLX_LASBRD_WS0		0x00000000#define PLX_LASBRD_WS1		0x0010a840/* Chip select base address (0 <= x < PLX_AREAS) */#define PLX_CSBASE(x)	(0x3c + (x << 2))#define PLX_CSBASE_ENABLE	1#define PLX_INTCSR	0x4c	/* Interrupt Control and Status Register */#define PLX_INT1_ENABLE	0x40	/* Interrupt 1 Enable bit */#define PLX_INT1_ACTIVE	0x04	/* Interrupt 1 Active bit */#define PLX_CNTRL	0x50	/* Control register */#define PLX_CNTRL_RESET	0x40000000	/* Reset local bus *//* One socket per card, but we may have more than one card */#define PCMCIA_SOCKETS_NO 8#ifdef __IN_PCMCIA_PACKAGE__socket_state_t dead_socket = {	0, SS_DETECT, 0, 0, 0};#endiftypedef struct socket_info_t {	void (*handler) (void *info, u_int events);	void *info;	socket_state_t state;	struct pci_dev *pdev;	/* PCI device */	/* PCI resource 1, PLX9052 registers */	unsigned int plxctl_addr;	unsigned int plxctl_len;	/* should be 0x80 */	/* PCI resource 2, mapped to PCMCIA memory space */	unsigned long mem_phys;	unsigned long mem_len;	/* should be 0x1000 */	u8 *mem_virt;	char area_used[PLX_AREAS];	/* Used local address spaces */	/* Event processing */	u_int event;	spinlock_t event_lock;	struct tq_struct event_work;} socket_info_t;static socket_info_t socket_table[PCMCIA_SOCKETS_NO];static int socket_count;/* Forward declarations */static void plx9052_close(struct pci_dev *pdev);static int plx9052_set_socket(unsigned int sock, socket_state_t * state);/* Check that an area is size-aligned. * Return 0 for good areas, -1 for bad ones.  */static int plx9052_align_check(u32 base, u32 len){	int power = 0;	int l = len;	if (!len)		return -1;	while (l >>= 1)		power++;	if (len != (1 << power))		return -1;	if (base & ((1 << power) - 1))		return -1;	return 0;}static inline void plx9052_outl(socket_info_t *socket, u32 val,				ioaddr_t addr){	outl_p(val, socket->plxctl_addr + addr);}static inline u32 plx9052_inl(socket_info_t *socket, ioaddr_t addr){	return inl_p(socket->plxctl_addr + addr);}static inline void plx9052_enable_irq(socket_info_t *socket){	u32 reg;	reg = plx9052_inl(socket, PLX_INTCSR);	if (!(reg & PLX_INT1_ENABLE)) {		reg |= PLX_INT1_ENABLE;		plx9052_outl(socket, reg, PLX_INTCSR);	}}static inline void plx9052_disable_irq(socket_info_t *socket){	u32 reg;	reg = plx9052_inl(socket, PLX_INTCSR);	if (reg & PLX_INT1_ENABLE) {		reg &= ~PLX_INT1_ENABLE;		plx9052_outl(socket, reg, PLX_INTCSR);	}}static inline int plx9052_irq_active(socket_info_t *socket){	u32 reg;	reg = plx9052_inl(socket, PLX_INTCSR);	return (reg & PLX_INT1_ACTIVE);}/* Hack - determine card presence by the first byte of CIS */static inline int plx9052_card_present(socket_info_t *socket){	return (((volatile u8 *) socket->mem_virt)[0] == 1);}static void plx9052_event(socket_info_t *socket){	u_int event;	if (!socket->handler)		return;	spin_lock_irq(&socket->event_lock);	event = socket->event;	socket->event = 0;	spin_unlock_irq(&socket->event_lock);	if (!event)		return;	/* To make sure it'socket an insertion, wait 1 second before CIS is ready.	 * If the card is currently active, report ejection immediately.  */	if (!(socket->state.flags & SS_OUTPUT_ENA)) {		current->state = TASK_INTERRUPTIBLE;		schedule_timeout(HZ);	}	socket->handler(socket->info, event);	if (!(socket->state.flags & SS_RESET))		plx9052_enable_irq(socket);}static int plx9052_get_area(socket_info_t *socket, int is_io, int map){	int i;	/* Area 0 is used internally for CIS */	for (i = 1; i < PLX_AREAS; i++) {		if (!socket->area_used[i]) {			socket->area_used[i] = PLX_AREA_USED | map			    | (is_io ? PLX_AREA_IO : 0);			return i;		}	}	return -1;}static void plx9052_disable_areas(socket_info_t *socket, int is_io,				  int map){	int i;	int type = PLX_AREA_USED | map | (is_io ? PLX_AREA_IO : 0);	/* Note that there may be more than one area for the map */	for (i = 1; i < PLX_AREAS; i++) {		if (socket->area_used[i] == type) {			socket->area_used[i] = 0;			plx9052_outl(socket, PLX_LASBA_DISABLE,				     PLX_LASBA(i));		}	}}/* program a size-aligned area */static int plx9052_program_area(socket_info_t *socket, int is_io, int map,				unsigned long sysbase,				unsigned long syslen, u32 cardbase,				unsigned int flags){	u32 brd;	u32 mask;	int area;	area = plx9052_get_area(socket, is_io, map);	if (area < 0) {		printk(KERN_ERR "No free areas left\n");		return -EINVAL;	}	pci_write_config_dword(socket->pdev, PLX_PCI_BASE(area),			       sysbase | is_io);	mask = ~(syslen - 1);	if (is_io)		mask = (mask & PLX_LAS_IOMASK) | PLX_LASRR_IO;	else		mask &= PLX_LAS_MEMMASK;	brd = plx9052_inl(socket, PLX_LASBRD(area));	brd &= ~PLX_LASBRD_WIDTH_MASK;	if (flags & MAP_16BIT)		brd |= PLX_LASBRD_WIDTH_16;	brd &= ~PLX_LASBRD_WS_MASK;	if (!(flags & MAP_0WS))		brd |= PLX_LASBRD_WS1;	plx9052_outl(socket, brd, PLX_LASBRD(area));	plx9052_outl(socket, mask, PLX_LASRR(area));	plx9052_outl(socket, cardbase | PLX_LASBA_ENABLE, PLX_LASBA(area));	return 0;}static int plx9052_init(unsigned int sock){	socket_info_t *socket = &socket_table[sock];#if 0	/* Dump all registers */	int i;	for (i = 0; i < 0x20; i++) {		printk("%08x ", plx9052_inl(socket, i << 2));		if ((i & 7) == 7)			printk("\n");	}#endif	/* Area 0 is used to access CIS from the driver */	plx9052_outl(socket, PLX_LASBA_ENABLE | PLX_CIS_START,		     PLX_LASBA(0));	socket->area_used[0] = 1;	plx9052_outl(socket,		     PLX_CIS_START | (PLX_MEMWIN_MAX >> 1) |		     PLX_CSBASE_ENABLE, PLX_CSBASE(0));	plx9052_outl(socket, (PLX_IOWIN_MAX >> 1) | PLX_CSBASE_ENABLE,		     PLX_CSBASE(1));	plx9052_enable_irq(socket);	socket->state.csc_mask |= SS_DETECT;	return 0;}#ifdef __IN_PCMCIA_PACKAGE__static int plx9052_register_callback(unsigned int sock,				     ss_callback_t *call){	socket_info_t *socket = &socket_table[sock];	if (call == NULL) {		socket->handler = NULL;		MOD_DEC_USE_COUNT;	} else {		MOD_INC_USE_COUNT;		socket->handler = call->handler;		socket->info = call->info;	}	return 0;}#elsestatic int plx9052_register_callback(unsigned int sock,				     void (*handler) (void *,						      unsigned int),				     void *info){	socket_info_t *socket = &socket_table[sock];	socket->handler = handler;	socket->info = info;	if (handler == NULL) {		MOD_DEC_USE_COUNT;	} else {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日本在线看| 专区另类欧美日韩| 一区二区三区在线视频免费 | 亚洲 欧美综合在线网络| 欧美在线观看你懂的| 午夜精品123| 国产亚洲制服色| 色婷婷久久久久swag精品| 亚洲韩国精品一区| 久久久91精品国产一区二区三区| 欧美一级国产精品| 99这里只有久久精品视频| 亚洲精品中文在线影院| 日韩欧美国产午夜精品| 爽爽淫人综合网网站| 欧美成人福利视频| 不卡区在线中文字幕| 免播放器亚洲一区| 亚洲欧洲无码一区二区三区| 成人一区在线看| 亚洲人精品一区| 久久奇米777| 欧美日韩在线播| 成人性生交大片免费看视频在线 | 色av一区二区| 国产综合色产在线精品| 亚洲色图欧洲色图婷婷| 亚洲人吸女人奶水| 日韩**一区毛片| 国产精品伦理一区二区| 日韩三级伦理片妻子的秘密按摩| 精品国产露脸精彩对白| 337p亚洲精品色噜噜| av在线不卡观看免费观看| 在线亚洲精品福利网址导航| 日本一区二区三区四区| 日韩一区和二区| 国产精品美女www爽爽爽| 亚洲午夜一二三区视频| 国产v日产∨综合v精品视频| 国产在线视频精品一区| 在线精品视频一区二区三四| 精品久久免费看| 午夜精品福利一区二区蜜股av| 久久99久久久欧美国产| 日本一区二区三区久久久久久久久不 | 国模少妇一区二区三区| 97久久超碰国产精品| 国产一区二区三区蝌蚪| 久久精品99国产精品| 91看片淫黄大片一级在线观看| 国产精品一区二区不卡| 久久精品国产精品亚洲精品 | 1000部国产精品成人观看| 日韩电影网1区2区| av电影在线观看一区| 91精品国产免费久久综合| 激情另类小说区图片区视频区| 成人福利视频在线看| 日韩免费高清av| 亚洲第一激情av| 91猫先生在线| 国产精品久久久久久久久免费丝袜| 欧美国产精品劲爆| 亚洲欧洲国产日韩| 国产电影一区在线| 96av麻豆蜜桃一区二区| 国产欧美精品一区二区色综合朱莉 | 久久嫩草精品久久久精品| 蜜桃久久久久久久| 国产麻豆精品久久一二三| 日韩一级黄色大片| 麻豆国产精品一区二区三区| 欧美一级黄色录像| 日韩二区在线观看| 欧美大胆人体bbbb| 国产一区二区三区国产| 欧美成人乱码一区二区三区| 日本人妖一区二区| 日韩美一区二区三区| 免费人成精品欧美精品| 日韩视频免费观看高清完整版 | 欧美二区三区91| 久久综合狠狠综合久久激情| 国产精品超碰97尤物18| av一区二区久久| 亚洲欧美另类图片小说| 日本精品裸体写真集在线观看 | 成人午夜免费视频| 中文字幕在线免费不卡| 色综合久久综合| 日韩精品电影在线观看| 日韩欧美卡一卡二| 国产98色在线|日韩| 亚洲色图欧美激情| 欧美日韩国产一区| 狠狠色狠狠色综合| 国产精品美女久久久久高潮| 欧洲视频一区二区| 久久66热偷产精品| 亚洲视频你懂的| 欧美一区二区三区在线观看| 国产传媒一区在线| 自拍偷拍欧美精品| 欧美成人三级电影在线| 99久久精品国产一区| 亚洲成人激情社区| 国产精品久久久久久久久免费桃花| 欧美在线视频你懂得| 韩日欧美一区二区三区| 亚洲三级免费电影| 2019国产精品| 欧美日韩日本视频| 国产99精品视频| 日欧美一区二区| 国产精品久久福利| 日韩视频一区二区三区| 色综合久久中文综合久久牛| 国产一区二区三区四区五区入口| 亚洲欧洲色图综合| 久久亚洲影视婷婷| 欧美猛男超大videosgay| 国产精品91一区二区| 日本中文字幕一区二区视频| 国产精品免费看片| 2023国产精品| 日韩欧美不卡一区| 69久久夜色精品国产69蝌蚪网| 91麻豆国产精品久久| 国产精品99久| 精品一区二区三区免费| 午夜在线成人av| 亚洲欧洲日本在线| 欧美激情综合在线| 欧美mv日韩mv国产网站app| 欧美体内she精视频| 日韩国产一区二| 亚洲国产sm捆绑调教视频| 国产精品国产三级国产普通话99| 日韩美女主播在线视频一区二区三区 | 欧美无人高清视频在线观看| 成人精品国产福利| 国产剧情一区在线| 国产精品一二一区| 国产在线麻豆精品观看| 精品一区二区三区视频| 日本在线不卡视频一二三区| 性感美女久久精品| 亚洲成a人片综合在线| 悠悠色在线精品| 亚洲国产精品一区二区www在线| 国产精品每日更新| 亚洲免费看黄网站| 亚洲日本va在线观看| 亚洲精品伦理在线| 亚洲人成人一区二区在线观看| 日本一区二区视频在线观看| 国产欧美日韩视频在线观看| 国产午夜精品一区二区三区四区| 国产日韩影视精品| 1区2区3区欧美| 亚洲同性gay激情无套| 亚洲精品中文字幕在线观看| 亚洲精品中文字幕乱码三区| 亚洲国产精品一区二区久久恐怖片| 亚洲成人777| 免费精品99久久国产综合精品| 奇米一区二区三区| 国产成人夜色高潮福利影视| 成人免费观看男女羞羞视频| 91蜜桃视频在线| 91精品蜜臀在线一区尤物| 51精品视频一区二区三区| 26uuu国产电影一区二区| 久久久久国色av免费看影院| 国产精品美女久久久久久2018| 综合av第一页| 美女久久久精品| 99久久精品免费精品国产| 欧美伊人久久久久久久久影院| 91精品免费观看| 中文字幕欧美激情| 日韩国产精品久久久久久亚洲| 日韩一区和二区| 免费看日韩a级影片| 久草精品在线观看| 99麻豆久久久国产精品免费优播| 欧美色欧美亚洲另类二区| 欧美一级生活片| 中文字幕在线观看一区二区| 亚洲成人综合网站| 国产成人丝袜美腿| 欧美日韩在线播放三区四区| 国产视频在线观看一区二区三区 | 欧美精品日韩一区| 欧美国产成人精品| 日韩精品一区第一页| av激情综合网| 精品国产伦一区二区三区免费| 伊人婷婷欧美激情|