diff options
author | Lance Ortiz <lance.ortiz@hp.com> | 2013-01-03 17:34:08 -0500 |
---|---|---|
committer | Tony Luck <tony.luck@intel.com> | 2013-01-03 17:34:06 -0500 |
commit | 1d5210008bd3a26daf4b06aed9d6c330dd4c83e2 (patch) | |
tree | dae434fdd145b772b77f003ecb8237cb04c53b79 /drivers/pci | |
parent | 1ca1d8d54f925ad0eb6d9806ecd4309738f25301 (diff) |
aerdrv: Enhanced AER logging
This patch will provide a more reliable and easy way for user-space
applications to have access to AER logs rather than reading them from the
message buffer. It also provides a way to notify user-space when an AER
event occurs.
The aer driver is updated to generate a trace event of function 'aer_event'
when a PCIe error is reported over the AER interface. The trace event was
added to both the interrupt based aer path and the firmware first path.
Signed-off-by: Lance Ortiz <lance.ortiz@hp.com>
Acked-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Acked-by: Boris Petkov <bp@alien8.de>
Signed-off-by: Tony Luck <tony.luck@intel.com>
Diffstat (limited to 'drivers/pci')
-rw-r--r-- | drivers/pci/pcie/aer/aerdrv_errprint.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/drivers/pci/pcie/aer/aerdrv_errprint.c b/drivers/pci/pcie/aer/aerdrv_errprint.c index 3ea51736f18d..d3e5fc5a2de9 100644 --- a/drivers/pci/pcie/aer/aerdrv_errprint.c +++ b/drivers/pci/pcie/aer/aerdrv_errprint.c | |||
@@ -23,6 +23,9 @@ | |||
23 | 23 | ||
24 | #include "aerdrv.h" | 24 | #include "aerdrv.h" |
25 | 25 | ||
26 | #define CREATE_TRACE_POINTS | ||
27 | #include <trace/events/ras.h> | ||
28 | |||
26 | #define AER_AGENT_RECEIVER 0 | 29 | #define AER_AGENT_RECEIVER 0 |
27 | #define AER_AGENT_REQUESTER 1 | 30 | #define AER_AGENT_REQUESTER 1 |
28 | #define AER_AGENT_COMPLETER 2 | 31 | #define AER_AGENT_COMPLETER 2 |
@@ -194,6 +197,8 @@ void aer_print_error(struct pci_dev *dev, struct aer_err_info *info) | |||
194 | if (info->id && info->error_dev_num > 1 && info->id == id) | 197 | if (info->id && info->error_dev_num > 1 && info->id == id) |
195 | printk("%s"" Error of this Agent(%04x) is reported first\n", | 198 | printk("%s"" Error of this Agent(%04x) is reported first\n", |
196 | prefix, id); | 199 | prefix, id); |
200 | trace_aer_event(dev_name(&dev->dev), (info->status & ~info->mask), | ||
201 | info->severity); | ||
197 | } | 202 | } |
198 | 203 | ||
199 | void aer_print_port_info(struct pci_dev *dev, struct aer_err_info *info) | 204 | void aer_print_port_info(struct pci_dev *dev, struct aer_err_info *info) |
@@ -217,7 +222,7 @@ int cper_severity_to_aer(int cper_severity) | |||
217 | } | 222 | } |
218 | EXPORT_SYMBOL_GPL(cper_severity_to_aer); | 223 | EXPORT_SYMBOL_GPL(cper_severity_to_aer); |
219 | 224 | ||
220 | void cper_print_aer(const char *prefix, int cper_severity, | 225 | void cper_print_aer(const char *prefix, struct pci_dev *dev, int cper_severity, |
221 | struct aer_capability_regs *aer) | 226 | struct aer_capability_regs *aer) |
222 | { | 227 | { |
223 | int aer_severity, layer, agent, status_strs_size, tlp_header_valid = 0; | 228 | int aer_severity, layer, agent, status_strs_size, tlp_header_valid = 0; |
@@ -259,5 +264,7 @@ void cper_print_aer(const char *prefix, int cper_severity, | |||
259 | *(tlp + 8), *(tlp + 15), *(tlp + 14), | 264 | *(tlp + 8), *(tlp + 15), *(tlp + 14), |
260 | *(tlp + 13), *(tlp + 12)); | 265 | *(tlp + 13), *(tlp + 12)); |
261 | } | 266 | } |
267 | trace_aer_event(dev_name(&dev->dev), (status & ~mask), | ||
268 | aer_severity); | ||
262 | } | 269 | } |
263 | #endif | 270 | #endif |