提交 98ca3964 编写于 作者: H Hidetoshi Seto 提交者: Jesse Barnes

PCI: aerdrv: rework find_source_device

Return bool to indicate that the source device is found or not.
This allows us to skip calling aer_process_err_devices() if we can.

And move dev_printk for debug into this function.

v2: return bool instead of int
Signed-off-by: NHidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
Reviewed-by: NKenji Kaneshige <kaneshige.kenji@jp.fujitsu.com>
Signed-off-by: NJesse Barnes <jbarnes@virtuousgeek.org>
上级 843f4697
...@@ -215,11 +215,13 @@ static int find_device_iter(struct pci_dev *dev, void *data) ...@@ -215,11 +215,13 @@ static int find_device_iter(struct pci_dev *dev, void *data)
/** /**
* find_source_device - search through device hierarchy for source device * find_source_device - search through device hierarchy for source device
* @parent: pointer to Root Port pci_dev data structure * @parent: pointer to Root Port pci_dev data structure
* @err_info: including detailed error information such like id * @e_info: including detailed error information such like id
* *
* Invoked when error is detected at the Root Port. * Return true if found.
*
* Invoked by DPC when error is detected at the Root Port.
*/ */
static void find_source_device(struct pci_dev *parent, static bool find_source_device(struct pci_dev *parent,
struct aer_err_info *e_info) struct aer_err_info *e_info)
{ {
struct pci_dev *dev = parent; struct pci_dev *dev = parent;
...@@ -228,9 +230,17 @@ static void find_source_device(struct pci_dev *parent, ...@@ -228,9 +230,17 @@ static void find_source_device(struct pci_dev *parent,
/* Is Root Port an agent that sends error message? */ /* Is Root Port an agent that sends error message? */
result = find_device_iter(dev, e_info); result = find_device_iter(dev, e_info);
if (result) if (result)
return; return true;
pci_walk_bus(parent->subordinate, find_device_iter, e_info); pci_walk_bus(parent->subordinate, find_device_iter, e_info);
if (!e_info->error_dev_num) {
dev_printk(KERN_DEBUG, &parent->dev,
"can't find device of ID%04x\n",
e_info->id);
return false;
}
return true;
} }
static int report_error_detected(struct pci_dev *dev, void *data) static int report_error_detected(struct pci_dev *dev, void *data)
...@@ -639,12 +649,6 @@ static inline void aer_process_err_devices(struct pcie_device *p_device, ...@@ -639,12 +649,6 @@ static inline void aer_process_err_devices(struct pcie_device *p_device,
{ {
int i; int i;
if (!e_info->dev[0]) {
dev_printk(KERN_DEBUG, &p_device->port->dev,
"can't find device of ID%04x\n",
e_info->id);
}
/* Report all before handle them, not to lost records by reset etc. */ /* Report all before handle them, not to lost records by reset etc. */
for (i = 0; i < e_info->error_dev_num && e_info->dev[i]; i++) { for (i = 0; i < e_info->error_dev_num && e_info->dev[i]; i++) {
if (get_device_error_info(e_info->dev[i], e_info)) if (get_device_error_info(e_info->dev[i], e_info))
...@@ -702,8 +706,8 @@ static void aer_isr_one_error(struct pcie_device *p_device, ...@@ -702,8 +706,8 @@ static void aer_isr_one_error(struct pcie_device *p_device,
aer_print_port_info(p_device->port, e_info); aer_print_port_info(p_device->port, e_info);
find_source_device(p_device->port, e_info); if (find_source_device(p_device->port, e_info))
aer_process_err_devices(p_device, e_info); aer_process_err_devices(p_device, e_info);
} }
kfree(e_info); kfree(e_info);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册