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

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

?? aerdrv_core.c

?? linux內核源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * drivers/pci/pcie/aer/aerdrv_core.c * * This file is subject to the terms and conditions of the GNU General Public * License.  See the file "COPYING" in the main directory of this archive * for more details. * * This file implements the core part of PCI-Express AER. When an pci-express * error is delivered, an error message will be collected and printed to * console, then, an error recovery procedure will be executed by following * the pci error recovery rules. * * Copyright (C) 2006 Intel Corp. *	Tom Long Nguyen (tom.l.nguyen@intel.com) *	Zhang Yanmin (yanmin.zhang@intel.com) * */#include <linux/module.h>#include <linux/pci.h>#include <linux/kernel.h>#include <linux/errno.h>#include <linux/pm.h>#include <linux/suspend.h>#include <linux/delay.h>#include "aerdrv.h"static int forceload;module_param(forceload, bool, 0);#define PCI_CFG_SPACE_SIZE	(0x100)int pci_find_aer_capability(struct pci_dev *dev){	int pos;	u32 reg32 = 0;	/* Check if it's a pci-express device */	pos = pci_find_capability(dev, PCI_CAP_ID_EXP);	if (!pos)		return 0;	/* Check if it supports pci-express AER */	pos = PCI_CFG_SPACE_SIZE;	while (pos) {		if (pci_read_config_dword(dev, pos, &reg32))			return 0;		/* some broken boards return ~0 */		if (reg32 == 0xffffffff)			return 0;		if (PCI_EXT_CAP_ID(reg32) == PCI_EXT_CAP_ID_ERR)			break;		pos = reg32 >> 20;	}	return pos;}int pci_enable_pcie_error_reporting(struct pci_dev *dev){	u16 reg16 = 0;	int pos;	pos = pci_find_capability(dev, PCI_CAP_ID_EXP);	if (!pos)		return -EIO;	pci_read_config_word(dev, pos+PCI_EXP_DEVCTL, &reg16);	reg16 = reg16 |		PCI_EXP_DEVCTL_CERE |		PCI_EXP_DEVCTL_NFERE |		PCI_EXP_DEVCTL_FERE |		PCI_EXP_DEVCTL_URRE;	pci_write_config_word(dev, pos+PCI_EXP_DEVCTL,			reg16);	return 0;}int pci_disable_pcie_error_reporting(struct pci_dev *dev){	u16 reg16 = 0;	int pos;	pos = pci_find_capability(dev, PCI_CAP_ID_EXP);	if (!pos)		return -EIO;	pci_read_config_word(dev, pos+PCI_EXP_DEVCTL, &reg16);	reg16 = reg16 & ~(PCI_EXP_DEVCTL_CERE |			PCI_EXP_DEVCTL_NFERE |			PCI_EXP_DEVCTL_FERE |			PCI_EXP_DEVCTL_URRE);	pci_write_config_word(dev, pos+PCI_EXP_DEVCTL,			reg16);	return 0;}int pci_cleanup_aer_uncorrect_error_status(struct pci_dev *dev){	int pos;	u32 status, mask;	pos = pci_find_aer_capability(dev);	if (!pos)		return -EIO;	pci_read_config_dword(dev, pos + PCI_ERR_UNCOR_STATUS, &status);	pci_read_config_dword(dev, pos + PCI_ERR_UNCOR_SEVER, &mask);	if (dev->error_state == pci_channel_io_normal)		status &= ~mask; /* Clear corresponding nonfatal bits */	else		status &= mask; /* Clear corresponding fatal bits */	pci_write_config_dword(dev, pos + PCI_ERR_UNCOR_STATUS, status);	return 0;}int pci_cleanup_aer_correct_error_status(struct pci_dev *dev){	int pos;	u32 status;	pos = pci_find_aer_capability(dev);	if (!pos)		return -EIO;	pci_read_config_dword(dev, pos + PCI_ERR_COR_STATUS, &status);	pci_write_config_dword(dev, pos + PCI_ERR_COR_STATUS, status);	return 0;}static int find_device_iter(struct device *device, void *data){	struct pci_dev *dev;	u16 id = *(unsigned long *)data;	u8 secondary, subordinate, d_bus = id >> 8;	if (device->bus == &pci_bus_type) {		dev = to_pci_dev(device);		if (id == ((dev->bus->number << 8) | dev->devfn)) {			/*			 * Device ID match			 */			*(unsigned long*)data = (unsigned long)device;			return 1;		}		/*		 * If device is P2P, check if it is an upstream?		 */		if (dev->hdr_type & PCI_HEADER_TYPE_BRIDGE) {			pci_read_config_byte(dev, PCI_SECONDARY_BUS,				&secondary);			pci_read_config_byte(dev, PCI_SUBORDINATE_BUS,				&subordinate);			if (d_bus >= secondary && d_bus <= subordinate) {				*(unsigned long*)data = (unsigned long)device;				return 1;			}		}	}	return 0;}/** * find_source_device - search through device hierarchy for source device * @parent: pointer to Root Port pci_dev data structure * @id: device ID of agent who sends an error message to this Root Port * * Invoked when error is detected at the Root Port. */static struct device* find_source_device(struct pci_dev *parent, u16 id){	struct pci_dev *dev = parent;	struct device *device;	unsigned long device_addr;	int status;	/* Is Root Port an agent that sends error message? */	if (id == ((dev->bus->number << 8) | dev->devfn))		return &dev->dev;	do {		device_addr = id; 		if ((status = device_for_each_child(&dev->dev,			&device_addr, find_device_iter))) {			device = (struct device*)device_addr;			dev = to_pci_dev(device);			if (id == ((dev->bus->number << 8) | dev->devfn))				return device;		} 	}while (status);	return NULL;}static void report_error_detected(struct pci_dev *dev, void *data){	pci_ers_result_t vote;	struct pci_error_handlers *err_handler;	struct aer_broadcast_data *result_data;	result_data = (struct aer_broadcast_data *) data;	dev->error_state = result_data->state;	if (!dev->driver ||		!dev->driver->err_handler ||		!dev->driver->err_handler->error_detected) {		if (result_data->state == pci_channel_io_frozen &&			!(dev->hdr_type & PCI_HEADER_TYPE_BRIDGE)) {			/*			 * In case of fatal recovery, if one of down-			 * stream device has no driver. We might be			 * unable to recover because a later insmod			 * of a driver for this device is unaware of			 * its hw state.			 */			printk(KERN_DEBUG "Device ID[%s] has %s\n",					dev->dev.bus_id, (dev->driver) ?					"no AER-aware driver" : "no driver");		}		return;	}	err_handler = dev->driver->err_handler;	vote = err_handler->error_detected(dev, result_data->state);	result_data->result = merge_result(result_data->result, vote);	return;}static void report_mmio_enabled(struct pci_dev *dev, void *data){	pci_ers_result_t vote;	struct pci_error_handlers *err_handler;	struct aer_broadcast_data *result_data;	result_data = (struct aer_broadcast_data *) data;	if (!dev->driver ||		!dev->driver->err_handler ||		!dev->driver->err_handler->mmio_enabled)		return;	err_handler = dev->driver->err_handler;	vote = err_handler->mmio_enabled(dev);	result_data->result = merge_result(result_data->result, vote);	return;}static void report_slot_reset(struct pci_dev *dev, void *data){	pci_ers_result_t vote;	struct pci_error_handlers *err_handler;	struct aer_broadcast_data *result_data;	result_data = (struct aer_broadcast_data *) data;	if (!dev->driver ||		!dev->driver->err_handler ||		!dev->driver->err_handler->slot_reset)		return;	err_handler = dev->driver->err_handler;	vote = err_handler->slot_reset(dev);	result_data->result = merge_result(result_data->result, vote);	return;}static void report_resume(struct pci_dev *dev, void *data){	struct pci_error_handlers *err_handler;	dev->error_state = pci_channel_io_normal;	if (!dev->driver ||		!dev->driver->err_handler ||		!dev->driver->err_handler->slot_reset)		return;	err_handler = dev->driver->err_handler;	err_handler->resume(dev);	return;}/** * broadcast_error_message - handle message broadcast to downstream drivers * @dev: pointer to from where in a hierarchy message is broadcasted down * @state: error state * @error_mesg: message to print * @cb: callback to be broadcasted * * Invoked during error recovery process. Once being invoked, the content * of error severity will be broadcasted to all downstream drivers in a * hierarchy in question. */static pci_ers_result_t broadcast_error_message(struct pci_dev *dev,	enum pci_channel_state state,	char *error_mesg,	void (*cb)(struct pci_dev *, void *)){	struct aer_broadcast_data result_data;	printk(KERN_DEBUG "Broadcast %s message\n", error_mesg);	result_data.state = state;	if (cb == report_error_detected)		result_data.result = PCI_ERS_RESULT_CAN_RECOVER;	else		result_data.result = PCI_ERS_RESULT_RECOVERED;	if (dev->hdr_type & PCI_HEADER_TYPE_BRIDGE) {		/*		 * If the error is reported by a bridge, we think this error		 * is related to the downstream link of the bridge, so we		 * do error recovery on all subordinates of the bridge instead		 * of the bridge and clear the error status of the bridge.		 */		if (cb == report_error_detected)			dev->error_state = state;		pci_walk_bus(dev->subordinate, cb, &result_data);		if (cb == report_resume) {			pci_cleanup_aer_uncorrect_error_status(dev);			dev->error_state = pci_channel_io_normal;		}	}	else {		/*		 * If the error is reported by an end point, we think this		 * error is related to the upstream link of the end point.		 */		pci_walk_bus(dev->bus, cb, &result_data);	}	return result_data.result;}struct find_aer_service_data {	struct pcie_port_service_driver *aer_driver;	int is_downstream;};static int find_aer_service_iter(struct device *device, void *data){	struct device_driver *driver;	struct pcie_port_service_driver *service_driver;	struct pcie_device *pcie_dev;	struct find_aer_service_data *result;	result = (struct find_aer_service_data *) data;	if (device->bus == &pcie_port_bus_type) {		pcie_dev = to_pcie_device(device);		if (pcie_dev->id.port_type == PCIE_SW_DOWNSTREAM_PORT)			result->is_downstream = 1;		driver = device->driver;		if (driver) {			service_driver = to_service_driver(driver);			if (service_driver->id_table->service_type ==					PCIE_PORT_SERVICE_AER) {				result->aer_driver = service_driver;				return 1;			}		}	}	return 0;}static void find_aer_service(struct pci_dev *dev,		struct find_aer_service_data *data){	int retval;	retval = device_for_each_child(&dev->dev, data, find_aer_service_iter);}static pci_ers_result_t reset_link(struct pcie_device *aerdev,		struct pci_dev *dev){	struct pci_dev *udev;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久影院| 免费成人在线观看| 亚洲精品成a人| 久久99国内精品| 色婷婷久久久综合中文字幕| 欧美一区二区三区四区五区| 中文字幕亚洲区| 国产原创一区二区三区| 欧美婷婷六月丁香综合色| 久久久不卡网国产精品二区| 午夜精品福利一区二区蜜股av| 国产在线精品免费| 91精品国产免费| 亚洲最色的网站| 不卡一区二区在线| 国产欧美一区二区在线观看| 日本不卡视频一二三区| 一本高清dvd不卡在线观看 | 国产精品久久精品日日| 日韩不卡手机在线v区| 色呦呦一区二区三区| 久久久国产精华| 日本vs亚洲vs韩国一区三区二区| 成人av先锋影音| 日本一区二区在线不卡| 精品在线视频一区| 欧美v亚洲v综合ⅴ国产v| 石原莉奈一区二区三区在线观看| 在线中文字幕一区| 亚洲综合成人网| 欧美亚洲精品一区| 亚洲午夜在线观看视频在线| 一本一本久久a久久精品综合麻豆| 国产农村妇女精品| 成人黄页在线观看| 国产精品无圣光一区二区| 国产成人8x视频一区二区| 国产欧美日韩视频一区二区| 国产真实乱偷精品视频免| 精品国产一区二区三区久久影院| 免费欧美高清视频| 精品少妇一区二区三区在线视频 | 欧美亚洲综合在线| 一区二区三区美女视频| 欧美在线制服丝袜| 亚洲成人综合在线| 日韩午夜av一区| 国产精品白丝jk白祙喷水网站 | 91精品国产综合久久精品图片| 亚洲国产精品天堂| 欧美久久一区二区| 精品一区二区在线视频| 国产女同性恋一区二区| 日本伦理一区二区| 麻豆视频观看网址久久| 久久久久久久久伊人| 波多野结衣亚洲一区| 亚洲乱码国产乱码精品精的特点| 精品视频资源站| 精品一区二区成人精品| 国产精品久久久久9999吃药| 欧洲色大大久久| 久久精品国产一区二区三| 国产免费观看久久| 欧美日韩一区二区在线观看| 激情综合色综合久久| 亚洲国产成人一区二区三区| 在线一区二区三区| 麻豆国产91在线播放| 亚洲欧美自拍偷拍色图| 欧美美女bb生活片| 岛国一区二区在线观看| 亚洲成人7777| 中文字幕不卡的av| 欧美一级搡bbbb搡bbbb| av男人天堂一区| 蜜臀a∨国产成人精品| 国产精品伦理一区二区| 91麻豆精品国产91久久久| 成人午夜av在线| 蜜芽一区二区三区| 一区二区三区国产精品| 精品免费一区二区三区| 欧美影院一区二区三区| 丁香婷婷综合网| 青青草国产成人av片免费| 综合久久一区二区三区| 亚洲精品一线二线三线无人区| 色视频成人在线观看免| 国产成人免费视频网站| 偷拍一区二区三区| 国产精品麻豆一区二区| 久久嫩草精品久久久精品| 欧美绝品在线观看成人午夜影视| gogogo免费视频观看亚洲一| 国产在线视频不卡二| 欧美日韩一区二区在线观看视频| 国产a久久麻豆| 在线中文字幕不卡| 色国产精品一区在线观看| 久久综合色婷婷| 亚洲欧美国产毛片在线| 综合电影一区二区三区| 精品欧美一区二区三区精品久久| 成人高清视频免费观看| 日韩精品在线一区| 欧美日韩国产一级片| 91一区二区在线观看| 国产成人精品影视| 国产原创一区二区| 国产麻豆精品在线| 久久99久久精品欧美| 日本强好片久久久久久aaa| 亚洲午夜免费电影| 亚洲精品自拍动漫在线| 亚洲人成精品久久久久| 亚洲欧洲精品天堂一级| 日韩区在线观看| 日韩午夜在线观看| 欧美成人a∨高清免费观看| 欧美一卡2卡3卡4卡| 欧美一区二区美女| 精品久久久久99| 26uuu国产在线精品一区二区| 欧美tickling挠脚心丨vk| 日韩欧美专区在线| 久久综合九色综合欧美就去吻| 日韩欧美一区在线| 久久久久久久久岛国免费| 国产日产欧美一区| 亚洲日本一区二区三区| 一区二区三区免费| 青青草97国产精品免费观看| 精品一区二区三区久久| 国产精品一二二区| 97国产一区二区| 欧美日韩精品福利| 日韩限制级电影在线观看| 久久久www成人免费毛片麻豆| 中文字幕精品综合| 亚洲少妇中出一区| 舔着乳尖日韩一区| 国内精品视频666| 91视频在线观看| 91精品欧美福利在线观看| 亚洲精品一区二区三区香蕉| 国产精品久久久久7777按摩| 亚洲一区二区三区在线播放| 久久国产三级精品| 99国产精品久久久久久久久久久| 色婷婷av一区二区三区软件| 日韩欧美一级二级| 国产精品乱码一区二三区小蝌蚪| 亚洲无线码一区二区三区| 久久精品72免费观看| 91亚洲国产成人精品一区二三| 在线综合亚洲欧美在线视频| 国产精品天天摸av网| 亚洲成人在线观看视频| 国产91高潮流白浆在线麻豆 | 亚洲国产岛国毛片在线| 亚洲国产va精品久久久不卡综合 | 国产精品自拍三区| 在线观看www91| 国产三级一区二区三区| 一区二区三区久久久| 国产成人在线免费观看| 欧美精品在欧美一区二区少妇| 日本一区二区免费在线观看视频 | 九九国产精品视频| 91性感美女视频| 精品福利一二区| 五月天欧美精品| 91小视频免费观看| 国产日本一区二区| 免费成人美女在线观看.| 91成人免费在线| 国产精品嫩草影院av蜜臀| 美女网站色91| 欧美日本国产视频| 日韩美女久久久| 成人涩涩免费视频| 久久久久久免费网| 久久精品二区亚洲w码| 欧美日韩另类国产亚洲欧美一级| 国产精品美女www爽爽爽| 国产一区二区三区综合| 欧美一区二区三区在| 亚洲一区电影777| 色综合天天综合给合国产| 国产午夜精品久久| 久久精品国产一区二区| 日韩一区二区三区免费观看| 亚洲国产欧美日韩另类综合 | 欧美精品v国产精品v日韩精品| 亚洲精品中文在线观看| 99r国产精品| 亚洲欧洲99久久| 一本久久a久久精品亚洲| 亚洲色大成网站www久久九九|