2006-07-31 14:21:33 +07:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2006 Intel Corp.
|
|
|
|
* Tom Long Nguyen (tom.l.nguyen@intel.com)
|
|
|
|
* Zhang Yanmin (yanmin.zhang@intel.com)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _AER_H_
|
|
|
|
#define _AER_H_
|
|
|
|
|
2015-12-23 22:35:26 +07:00
|
|
|
#include <linux/errno.h>
|
2014-08-05 19:08:55 +07:00
|
|
|
#include <linux/types.h>
|
|
|
|
|
2013-06-07 01:10:49 +07:00
|
|
|
#define AER_NONFATAL 0
|
|
|
|
#define AER_FATAL 1
|
|
|
|
#define AER_CORRECTABLE 2
|
|
|
|
|
2014-07-30 00:49:25 +07:00
|
|
|
struct pci_dev;
|
|
|
|
|
2011-02-21 12:54:43 +07:00
|
|
|
struct aer_header_log_regs {
|
|
|
|
unsigned int dw0;
|
|
|
|
unsigned int dw1;
|
|
|
|
unsigned int dw2;
|
|
|
|
unsigned int dw3;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct aer_capability_regs {
|
|
|
|
u32 header;
|
|
|
|
u32 uncor_status;
|
|
|
|
u32 uncor_mask;
|
|
|
|
u32 uncor_severity;
|
|
|
|
u32 cor_status;
|
|
|
|
u32 cor_mask;
|
|
|
|
u32 cap_control;
|
|
|
|
struct aer_header_log_regs header_log;
|
|
|
|
u32 root_command;
|
|
|
|
u32 root_status;
|
|
|
|
u16 cor_err_source;
|
|
|
|
u16 uncor_err_source;
|
|
|
|
};
|
|
|
|
|
2006-07-31 14:21:33 +07:00
|
|
|
#if defined(CONFIG_PCIEAER)
|
2017-09-02 04:35:50 +07:00
|
|
|
/* PCIe port driver needs this function to enable AER */
|
2013-06-07 03:35:35 +07:00
|
|
|
int pci_enable_pcie_error_reporting(struct pci_dev *dev);
|
|
|
|
int pci_disable_pcie_error_reporting(struct pci_dev *dev);
|
|
|
|
int pci_cleanup_aer_uncorrect_error_status(struct pci_dev *dev);
|
2015-09-17 22:09:37 +07:00
|
|
|
int pci_cleanup_aer_error_status_regs(struct pci_dev *dev);
|
2006-07-31 14:21:33 +07:00
|
|
|
#else
|
2007-08-24 00:37:53 +07:00
|
|
|
static inline int pci_enable_pcie_error_reporting(struct pci_dev *dev)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
static inline int pci_disable_pcie_error_reporting(struct pci_dev *dev)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
static inline int pci_cleanup_aer_uncorrect_error_status(struct pci_dev *dev)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
2015-09-17 22:09:37 +07:00
|
|
|
static inline int pci_cleanup_aer_error_status_regs(struct pci_dev *dev)
|
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
2006-07-31 14:21:33 +07:00
|
|
|
#endif
|
|
|
|
|
2016-09-15 04:14:45 +07:00
|
|
|
void cper_print_aer(struct pci_dev *dev, int aer_severity,
|
2013-06-07 03:35:35 +07:00
|
|
|
struct aer_capability_regs *aer);
|
|
|
|
int cper_severity_to_aer(int cper_severity);
|
|
|
|
void aer_recover_queue(int domain, unsigned int bus, unsigned int devfn,
|
2017-09-02 04:35:50 +07:00
|
|
|
int severity, struct aer_capability_regs *aer_regs);
|
2006-07-31 14:21:33 +07:00
|
|
|
#endif //_AER_H_
|
|
|
|
|