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

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

?? pciehp_ctrl.c

?? linux-2.6.15.6
?? C
?? 第 1 頁 / 共 2 頁
字號:
	u8 getstatus;		pushbutton_pending = 0;	if (!p_slot) {		dbg("%s: Error! slot NULL\n", __FUNCTION__);		return;	}	p_slot->hpc_ops->get_power_status(p_slot, &getstatus);	if (getstatus) {		p_slot->state = POWEROFF_STATE;		dbg("%s: disabling bus:device(%x:%x)\n", __FUNCTION__,				p_slot->bus, p_slot->device);		pciehp_disable_slot(p_slot);		p_slot->state = STATIC_STATE;	} else {		p_slot->state = POWERON_STATE;		dbg("%s: adding bus:device(%x:%x)\n", __FUNCTION__,				p_slot->bus, p_slot->device);		if (pciehp_enable_slot(p_slot) && PWR_LED(p_slot->ctrl->ctrlcap)) {			/* Wait for exclusive access to hardware */			down(&p_slot->ctrl->crit_sect);			p_slot->hpc_ops->green_led_off(p_slot);			/* Wait for the command to complete */			wait_for_ctrl_irq (p_slot->ctrl);			/* Done with exclusive hardware access */			up(&p_slot->ctrl->crit_sect);		}		p_slot->state = STATIC_STATE;	}	return;}/** * pciehp_surprise_rm_thread * * Scheduled procedure to handle blocking stuff for the surprise removal * Handles all pending events and exits. * */static void pciehp_surprise_rm_thread(unsigned long slot){	struct slot *p_slot = (struct slot *) slot;	u8 getstatus;		surprise_rm_pending = 0;	if (!p_slot) {		dbg("%s: Error! slot NULL\n", __FUNCTION__);		return;	}	p_slot->hpc_ops->get_adapter_status(p_slot, &getstatus);	if (!getstatus) {		p_slot->state = POWEROFF_STATE;		dbg("%s: removing bus:device(%x:%x)\n",				__FUNCTION__, p_slot->bus, p_slot->device);		pciehp_disable_slot(p_slot);		p_slot->state = STATIC_STATE;	} else {		p_slot->state = POWERON_STATE;		dbg("%s: adding bus:device(%x:%x)\n",				__FUNCTION__, p_slot->bus, p_slot->device);		if (pciehp_enable_slot(p_slot) && PWR_LED(p_slot->ctrl->ctrlcap)) {			/* Wait for exclusive access to hardware */			down(&p_slot->ctrl->crit_sect);			p_slot->hpc_ops->green_led_off(p_slot);			/* Wait for the command to complete */			wait_for_ctrl_irq (p_slot->ctrl);			/* Done with exclusive hardware access */			up(&p_slot->ctrl->crit_sect);		}		p_slot->state = STATIC_STATE;	}	return;}/* this is the main worker thread */static int event_thread(void* data){	struct controller *ctrl;	lock_kernel();	daemonize("pciehpd_event");	unlock_kernel();	while (1) {		dbg("!!!!event_thread sleeping\n");		down_interruptible (&event_semaphore);		dbg("event_thread woken finished = %d\n", event_finished);		if (event_finished || signal_pending(current))			break;		/* Do stuff here */		if (pushbutton_pending)			pciehp_pushbutton_thread(pushbutton_pending);		else if (surprise_rm_pending)			pciehp_surprise_rm_thread(surprise_rm_pending);		else			for (ctrl = pciehp_ctrl_list; ctrl; ctrl=ctrl->next)				interrupt_event_handler(ctrl);	}	dbg("event_thread signals exit\n");	up(&event_exit);	return 0;}int pciehp_event_start_thread(void){	int pid;	/* initialize our semaphores */	init_MUTEX_LOCKED(&event_exit);	event_finished=0;	init_MUTEX_LOCKED(&event_semaphore);	pid = kernel_thread(event_thread, NULL, 0);	if (pid < 0) {		err ("Can't start up our event thread\n");		return -1;	}	return 0;}void pciehp_event_stop_thread(void){	event_finished = 1;	up(&event_semaphore);	down(&event_exit);}static int update_slot_info(struct slot *slot){	struct hotplug_slot_info *info;	/* char buffer[SLOT_NAME_SIZE]; */	int result;	info = kmalloc(sizeof(struct hotplug_slot_info), GFP_KERNEL);	if (!info)		return -ENOMEM;	/* make_slot_name (&buffer[0], SLOT_NAME_SIZE, slot); */	slot->hpc_ops->get_power_status(slot, &(info->power_status));	slot->hpc_ops->get_attention_status(slot, &(info->attention_status));	slot->hpc_ops->get_latch_status(slot, &(info->latch_status));	slot->hpc_ops->get_adapter_status(slot, &(info->adapter_status));	/* result = pci_hp_change_slot_info(buffer, info); */	result = pci_hp_change_slot_info(slot->hotplug_slot, info);	kfree (info);	return result;}static void interrupt_event_handler(struct controller *ctrl){	int loop = 0;	int change = 1;	u8 hp_slot;	u8 getstatus;	struct slot *p_slot;	while (change) {		change = 0;		for (loop = 0; loop < MAX_EVENTS; loop++) {			if (ctrl->event_queue[loop].event_type != 0) {				hp_slot = ctrl->event_queue[loop].hp_slot;				p_slot = pciehp_find_slot(ctrl, hp_slot + ctrl->slot_device_offset);				if (ctrl->event_queue[loop].event_type == INT_BUTTON_CANCEL) {					dbg("button cancel\n");					del_timer(&p_slot->task_event);					switch (p_slot->state) {					case BLINKINGOFF_STATE:						/* Wait for exclusive access to hardware */						down(&ctrl->crit_sect);												if (PWR_LED(ctrl->ctrlcap)) {							p_slot->hpc_ops->green_led_on(p_slot);							/* Wait for the command to complete */							wait_for_ctrl_irq (ctrl);						}						if (ATTN_LED(ctrl->ctrlcap)) {							p_slot->hpc_ops->set_attention_status(p_slot, 0);							/* Wait for the command to complete */							wait_for_ctrl_irq (ctrl);						}						/* Done with exclusive hardware access */						up(&ctrl->crit_sect);						break;					case BLINKINGON_STATE:						/* Wait for exclusive access to hardware */						down(&ctrl->crit_sect);						if (PWR_LED(ctrl->ctrlcap)) {							p_slot->hpc_ops->green_led_off(p_slot);							/* Wait for the command to complete */							wait_for_ctrl_irq (ctrl);						}						if (ATTN_LED(ctrl->ctrlcap)){							p_slot->hpc_ops->set_attention_status(p_slot, 0);							/* Wait for the command to complete */							wait_for_ctrl_irq (ctrl);						}						/* Done with exclusive hardware access */						up(&ctrl->crit_sect);						break;					default:						warn("Not a valid state\n");						return;					}					info(msg_button_cancel, p_slot->number);					p_slot->state = STATIC_STATE;				}				/* ***********Button Pressed (No action on 1st press...) */				else if (ctrl->event_queue[loop].event_type == INT_BUTTON_PRESS) {										if (ATTN_BUTTN(ctrl->ctrlcap)) {						dbg("Button pressed\n");						p_slot->hpc_ops->get_power_status(p_slot, &getstatus);						if (getstatus) {							/* slot is on */							dbg("slot is on\n");							p_slot->state = BLINKINGOFF_STATE;							info(msg_button_off, p_slot->number);						} else {							/* slot is off */							dbg("slot is off\n");							p_slot->state = BLINKINGON_STATE;							info(msg_button_on, p_slot->number);						}						/* Wait for exclusive access to hardware */						down(&ctrl->crit_sect);						/* blink green LED and turn off amber */						if (PWR_LED(ctrl->ctrlcap)) {							p_slot->hpc_ops->green_led_blink(p_slot);							/* Wait for the command to complete */							wait_for_ctrl_irq (ctrl);						}						if (ATTN_LED(ctrl->ctrlcap)) {							p_slot->hpc_ops->set_attention_status(p_slot, 0);							/* Wait for the command to complete */							wait_for_ctrl_irq (ctrl);						}						/* Done with exclusive hardware access */						up(&ctrl->crit_sect);						init_timer(&p_slot->task_event);						p_slot->task_event.expires = jiffies + 5 * HZ;   /* 5 second delay */						p_slot->task_event.function = (void (*)(unsigned long)) pushbutton_helper_thread;						p_slot->task_event.data = (unsigned long) p_slot;						add_timer(&p_slot->task_event);					}				}				/***********POWER FAULT********************/				else if (ctrl->event_queue[loop].event_type == INT_POWER_FAULT) {					if (POWER_CTRL(ctrl->ctrlcap)) {						dbg("power fault\n");						/* Wait for exclusive access to hardware */						down(&ctrl->crit_sect);						if (ATTN_LED(ctrl->ctrlcap)) {							p_slot->hpc_ops->set_attention_status(p_slot, 1);							wait_for_ctrl_irq (ctrl);						}						if (PWR_LED(ctrl->ctrlcap)) {							p_slot->hpc_ops->green_led_off(p_slot);							wait_for_ctrl_irq (ctrl);						}						/* Done with exclusive hardware access */						up(&ctrl->crit_sect);					}				}				/***********SURPRISE REMOVAL********************/				else if ((ctrl->event_queue[loop].event_type == INT_PRESENCE_ON) || 					(ctrl->event_queue[loop].event_type == INT_PRESENCE_OFF)) {					if (HP_SUPR_RM(ctrl->ctrlcap)) {						dbg("Surprise Removal\n");						if (p_slot) {							surprise_rm_pending = (unsigned long) p_slot;							up(&event_semaphore);							update_slot_info(p_slot);						}					}				} else {					/* refresh notification */					if (p_slot)						update_slot_info(p_slot);				}				ctrl->event_queue[loop].event_type = 0;				change = 1;			}		}		/* End of FOR loop */	}}int pciehp_enable_slot(struct slot *p_slot){	u8 getstatus = 0;	int rc;	/* Check to see if (latch closed, card present, power off) */	down(&p_slot->ctrl->crit_sect);	rc = p_slot->hpc_ops->get_adapter_status(p_slot, &getstatus);	if (rc || !getstatus) {		info("%s: no adapter on slot(%x)\n", __FUNCTION__, p_slot->number);		up(&p_slot->ctrl->crit_sect);		return 1;	}	if (MRL_SENS(p_slot->ctrl->ctrlcap)) {			rc = p_slot->hpc_ops->get_latch_status(p_slot, &getstatus);		if (rc || getstatus) {			info("%s: latch open on slot(%x)\n", __FUNCTION__, p_slot->number);			up(&p_slot->ctrl->crit_sect);			return 1;		}	}		if (POWER_CTRL(p_slot->ctrl->ctrlcap)) {			rc = p_slot->hpc_ops->get_power_status(p_slot, &getstatus);		if (rc || getstatus) {			info("%s: already enabled on slot(%x)\n", __FUNCTION__, p_slot->number);			up(&p_slot->ctrl->crit_sect);			return 1;		}	}	up(&p_slot->ctrl->crit_sect);	p_slot->hpc_ops->get_latch_status(p_slot, &getstatus);	rc = board_added(p_slot);	if (rc) {		p_slot->hpc_ops->get_latch_status(p_slot, &getstatus);	}	if (p_slot)		update_slot_info(p_slot);	return rc;}int pciehp_disable_slot(struct slot *p_slot){	u8 getstatus = 0;	int ret = 0;	if (!p_slot->ctrl)		return 1;	/* Check to see if (latch closed, card present, power on) */	down(&p_slot->ctrl->crit_sect);	if (!HP_SUPR_RM(p_slot->ctrl->ctrlcap)) {			ret = p_slot->hpc_ops->get_adapter_status(p_slot, &getstatus);		if (ret || !getstatus) {			info("%s: no adapter on slot(%x)\n", __FUNCTION__, p_slot->number);			up(&p_slot->ctrl->crit_sect);			return 1;		}	}	if (MRL_SENS(p_slot->ctrl->ctrlcap)) {			ret = p_slot->hpc_ops->get_latch_status(p_slot, &getstatus);		if (ret || getstatus) {			info("%s: latch open on slot(%x)\n", __FUNCTION__, p_slot->number);			up(&p_slot->ctrl->crit_sect);			return 1;		}	}	if (POWER_CTRL(p_slot->ctrl->ctrlcap)) {			ret = p_slot->hpc_ops->get_power_status(p_slot, &getstatus);		if (ret || !getstatus) {			info("%s: already disabled slot(%x)\n", __FUNCTION__, p_slot->number);			up(&p_slot->ctrl->crit_sect);			return 1;		}	}	up(&p_slot->ctrl->crit_sect);	ret = remove_board(p_slot);	update_slot_info(p_slot);	return ret;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一二三四区| 国产成人亚洲综合a∨猫咪| 国产欧美一区二区精品性色| 日韩视频在线永久播放| 欧美日本一区二区| 欧美日韩国产三级| 欧美日韩视频第一区| 欧美自拍丝袜亚洲| 欧美视频一区在线| 欧美二区在线观看| 欧美大胆人体bbbb| 久久久久久夜精品精品免费| 精品国产伦一区二区三区免费 | 久久久一区二区三区捆绑**| 日韩欧美一区二区在线视频| 日韩免费看网站| 久久久久一区二区三区四区| 国产蜜臀av在线一区二区三区| 国产日产精品1区| 综合分类小说区另类春色亚洲小说欧美| 国产精品免费aⅴ片在线观看| 国产欧美日韩另类一区| 亚洲欧美日韩电影| 日韩高清不卡一区二区三区| 久久av老司机精品网站导航| 国产成人aaa| 色欧美片视频在线观看在线视频| 精品视频一区二区三区免费| 欧美电视剧在线观看完整版| 国产精品人妖ts系列视频| 亚洲国产精品嫩草影院| 卡一卡二国产精品| av男人天堂一区| 欧美日韩在线不卡| 欧美日韩国产另类一区| 久久久一区二区三区捆绑**| 一区二区欧美视频| 国产在线看一区| 91激情五月电影| 久久九九国产精品| 日韩精品乱码免费| av激情综合网| 久久久激情视频| 日韩精品一卡二卡三卡四卡无卡| 国产乱人伦偷精品视频不卡| 在线免费观看成人短视频| 欧美精品一区二区三区在线播放| 日韩理论片在线| 国产成人精品免费一区二区| 精品视频一区三区九区| 国产精品久久久久久久久快鸭| 亚洲福利一区二区| 99精品视频在线播放观看| 日韩三级精品电影久久久| 亚洲欧美日韩成人高清在线一区| 奇米影视一区二区三区小说| 91在线精品秘密一区二区| 精品美女一区二区| 午夜一区二区三区视频| av高清不卡在线| 国产欧美精品区一区二区三区| 热久久免费视频| 欧美日韩你懂的| 玉米视频成人免费看| 成人动漫在线一区| 国产网站一区二区三区| 久久成人免费电影| 欧美一级欧美三级| 欧美96一区二区免费视频| 欧美另类z0zxhd电影| 一区二区三区 在线观看视频| 成人av在线播放网址| 久久久久久亚洲综合| 国产在线精品一区二区不卡了| 欧美一区二区三区免费| 免费看日韩a级影片| 日韩一区二区三区高清免费看看| 午夜激情一区二区| 这里只有精品99re| 青娱乐精品视频| 日韩美女天天操| 国产麻豆午夜三级精品| 精品日韩成人av| 国产精品69毛片高清亚洲| 久久久综合视频| 不卡的电影网站| 亚洲免费色视频| 欧美在线色视频| 天堂资源在线中文精品| 日韩欧美高清dvd碟片| 极品少妇xxxx精品少妇偷拍| 久久久久久影视| 99久久99久久精品免费观看| 亚洲欧美日韩小说| 欧美日韩亚洲另类| 久久成人av少妇免费| 久久久国产精品午夜一区ai换脸| 成人av在线播放网址| 亚洲电影中文字幕在线观看| 在线日韩一区二区| 乱一区二区av| 欧美国产激情二区三区| 色婷婷综合久色| 蜜桃精品视频在线观看| 日本一区二区免费在线| www.成人在线| 日韩av电影天堂| 久久综合久久综合久久| 在线精品视频小说1| 亚洲v中文字幕| 精品久久久三级丝袜| 色哟哟一区二区| 免费观看成人鲁鲁鲁鲁鲁视频| 久久久久久亚洲综合影院红桃| 色国产精品一区在线观看| 日韩经典一区二区| 国产精品久久久久久久久搜平片| 91成人免费在线| 国内精品在线播放| 亚洲影院久久精品| 欧美激情综合五月色丁香小说| 欧美体内she精视频| 美腿丝袜亚洲综合| 亚洲曰韩产成在线| 国产精品美女久久久久aⅴ国产馆| 欧美日韩国产一级片| 99久久精品费精品国产一区二区| 久久精品国产亚洲高清剧情介绍 | 2021中文字幕一区亚洲| 欧美在线高清视频| www.亚洲国产| 国产一区二区h| 天天av天天翘天天综合网色鬼国产 | 国产日韩一级二级三级| 91精品福利在线一区二区三区| 99在线视频精品| 国产精品18久久久| 久久精品国产免费看久久精品| 日韩美女视频一区二区| 日韩亚洲国产中文字幕欧美| 欧美视频日韩视频在线观看| eeuss鲁片一区二区三区在线看| 蜜臀91精品一区二区三区| 亚洲成av人片在线| 一区二区三区丝袜| 亚洲三级在线看| 中文字幕在线不卡一区二区三区| 久久美女高清视频| 久久欧美中文字幕| 日韩免费福利电影在线观看| 7878成人国产在线观看| 欧美午夜影院一区| 在线观看91视频| 91一区二区三区在线观看| 国产成人免费视| 国产激情视频一区二区三区欧美 | 欧美中文字幕一区二区三区亚洲 | 亚洲777理论| 日韩专区一卡二卡| 日本91福利区| 美女mm1313爽爽久久久蜜臀| 蜜桃一区二区三区四区| 国产在线精品一区二区夜色| 国产精品一二三区| 91麻豆国产福利在线观看| 色综合久久88色综合天天| 精品视频1区2区| 欧美一区二区免费视频| 精品久久久久久久久久久久久久久 | 欧美三级日韩三级| 91.com视频| 久久久久久久久久久久久久久99| 久久久99久久| 亚洲卡通欧美制服中文| 亚洲电影在线播放| 蜜桃视频一区二区三区在线观看| 卡一卡二国产精品| 99综合电影在线视频| 欧美无人高清视频在线观看| 欧美一区二区日韩| 国产精品青草久久| 午夜视黄欧洲亚洲| 国产精品一区二区三区网站| 99re免费视频精品全部| 7777精品伊人久久久大香线蕉的| 26uuu欧美日本| 一二三四区精品视频| 日韩主播视频在线| 大胆亚洲人体视频| 欧美视频在线不卡| 国产欧美一区二区精品忘忧草| 一区二区在线电影| 国产精品77777| 在线不卡一区二区| 亚洲三级在线免费| 狠狠色狠狠色合久久伊人| 欧美性高清videossexo| 欧美精品一区二区不卡 | 亚洲综合色噜噜狠狠| 伦理电影国产精品|