aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/pci/pcie/aer/aerdrv.h1
-rw-r--r--drivers/pci/pcie/aer/aerdrv_core.c2
-rw-r--r--drivers/pci/pcie/aer/aerdrv_errprint.c68
3 files changed, 39 insertions, 32 deletions
diff --git a/drivers/pci/pcie/aer/aerdrv.h b/drivers/pci/pcie/aer/aerdrv.h
index 78c977cec479..f9979eb56fb2 100644
--- a/drivers/pci/pcie/aer/aerdrv.h
+++ b/drivers/pci/pcie/aer/aerdrv.h
@@ -124,6 +124,7 @@ extern void aer_delete_rootport(struct aer_rpc *rpc);
124extern int aer_init(struct pcie_device *dev); 124extern int aer_init(struct pcie_device *dev);
125extern void aer_isr(struct work_struct *work); 125extern void aer_isr(struct work_struct *work);
126extern void aer_print_error(struct pci_dev *dev, struct aer_err_info *info); 126extern void aer_print_error(struct pci_dev *dev, struct aer_err_info *info);
127extern void aer_print_port_info(struct pci_dev *dev, struct aer_err_info *info);
127extern irqreturn_t aer_irq(int irq, void *context); 128extern irqreturn_t aer_irq(int irq, void *context);
128 129
129#ifdef CONFIG_ACPI 130#ifdef CONFIG_ACPI
diff --git a/drivers/pci/pcie/aer/aerdrv_core.c b/drivers/pci/pcie/aer/aerdrv_core.c
index 962646974466..d9185cd2d900 100644
--- a/drivers/pci/pcie/aer/aerdrv_core.c
+++ b/drivers/pci/pcie/aer/aerdrv_core.c
@@ -813,6 +813,8 @@ static void aer_isr_one_error(struct pcie_device *p_device,
813 PCI_ERR_ROOT_MULTI_UNCOR_RCV)) 813 PCI_ERR_ROOT_MULTI_UNCOR_RCV))
814 e_info->multi_error_valid = 1; 814 e_info->multi_error_valid = 1;
815 815
816 aer_print_port_info(p_device->port, e_info);
817
816 find_source_device(p_device->port, e_info); 818 find_source_device(p_device->port, e_info);
817 aer_process_err_devices(p_device, e_info); 819 aer_process_err_devices(p_device, e_info);
818 } 820 }
diff --git a/drivers/pci/pcie/aer/aerdrv_errprint.c b/drivers/pci/pcie/aer/aerdrv_errprint.c
index f0bdf0ff859e..44acde72294f 100644
--- a/drivers/pci/pcie/aer/aerdrv_errprint.c
+++ b/drivers/pci/pcie/aer/aerdrv_errprint.c
@@ -57,9 +57,10 @@
57 (e & AER_DATA_LINK_LAYER_ERROR_MASK(t)) ? AER_DATA_LINK_LAYER_ERROR : \ 57 (e & AER_DATA_LINK_LAYER_ERROR_MASK(t)) ? AER_DATA_LINK_LAYER_ERROR : \
58 AER_TRANSACTION_LAYER_ERROR) 58 AER_TRANSACTION_LAYER_ERROR)
59 59
60#define AER_PR(info, fmt, args...) \ 60#define AER_PR(info, pdev, fmt, args...) \
61 printk("%s" fmt, (info->severity == AER_CORRECTABLE) ? \ 61 printk("%s%s %s: " fmt, (info->severity == AER_CORRECTABLE) ? \
62 KERN_WARNING : KERN_ERR, ## args) 62 KERN_WARNING : KERN_ERR, dev_driver_string(&pdev->dev), \
63 dev_name(&pdev->dev), ## args)
63 64
64/* 65/*
65 * AER error strings 66 * AER error strings
@@ -152,7 +153,7 @@ static char *aer_agent_string[] = {
152 "Transmitter ID" 153 "Transmitter ID"
153}; 154};
154 155
155static void aer_print_error_source(struct aer_err_info *info) 156static void __aer_print_error(struct aer_err_info *info, struct pci_dev *dev)
156{ 157{
157 int i, status; 158 int i, status;
158 char *errmsg = NULL; 159 char *errmsg = NULL;
@@ -169,48 +170,44 @@ static void aer_print_error_source(struct aer_err_info *info)
169 errmsg = aer_uncorrectable_error_string[i]; 170 errmsg = aer_uncorrectable_error_string[i];
170 171
171 if (errmsg) 172 if (errmsg)
172 AER_PR(info, "%s\t: %s\n", errmsg, 173 AER_PR(info, dev, " [%2d] %s%s\n", i, errmsg,
173 info->first_error == i ? "First" : ""); 174 info->first_error == i ? " (First)" : "");
174 else 175 else
175 AER_PR(info, "Unknown Error Bit %2d \t: %s\n", 176 AER_PR(info, dev, " [%2d] Unknown Error Bit%s\n", i,
176 i, info->first_error == i ? "First" : ""); 177 info->first_error == i ? " (First)" : "");
177 } 178 }
178} 179}
179 180
180void aer_print_error(struct pci_dev *dev, struct aer_err_info *info) 181void aer_print_error(struct pci_dev *dev, struct aer_err_info *info)
181{ 182{
182 int err_layer, agent;
183 int id = ((dev->bus->number << 8) | dev->devfn); 183 int id = ((dev->bus->number << 8) | dev->devfn);
184 184
185 AER_PR(info, "+------ PCI-Express Device Error ------+\n");
186 AER_PR(info, "Error Severity\t\t: %s\n",
187 aer_error_severity_string[info->severity]);
188
189 if (info->status == 0) { 185 if (info->status == 0) {
190 AER_PR(info, "PCIE Bus Error type\t: (Unaccessible)\n"); 186 AER_PR(info, dev,
191 AER_PR(info, "Unregistered Agent ID\t: %04x\n", id); 187 "PCIE Bus Error: severity=%s, type=Unaccessible, "
188 "id=%04x(Unregistered Agent ID)\n",
189 aer_error_severity_string[info->severity], id);
192 } else { 190 } else {
193 err_layer = AER_GET_LAYER_ERROR(info->severity, info->status); 191 int layer, agent;
194 AER_PR(info, "PCIE Bus Error type\t: %s\n",
195 aer_error_layer[err_layer]);
196
197 aer_print_error_source(info);
198 192
193 layer = AER_GET_LAYER_ERROR(info->severity, info->status);
199 agent = AER_GET_AGENT(info->severity, info->status); 194 agent = AER_GET_AGENT(info->severity, info->status);
200 AER_PR(info, "%s\t\t: %04x\n", aer_agent_string[agent], id);
201 195
202 AER_PR(info, "VendorID=%04xh, DeviceID=%04xh," 196 AER_PR(info, dev,
203 " Bus=%02xh, Device=%02xh, Function=%02xh\n", 197 "PCIE Bus Error: severity=%s, type=%s, id=%04x(%s)\n",
204 dev->vendor, 198 aer_error_severity_string[info->severity],
205 dev->device, 199 aer_error_layer[layer], id, aer_agent_string[agent]);
206 dev->bus->number, 200
207 PCI_SLOT(dev->devfn), 201 AER_PR(info, dev,
208 PCI_FUNC(dev->devfn)); 202 " device [%04x:%04x] error status/mask=%08x/%08x\n",
203 dev->vendor, dev->device, info->status, info->mask);
204
205 __aer_print_error(info, dev);
209 206
210 if (info->tlp_header_valid) { 207 if (info->tlp_header_valid) {
211 unsigned char *tlp = (unsigned char *) &info->tlp; 208 unsigned char *tlp = (unsigned char *) &info->tlp;
212 AER_PR(info, "TLP Header:\n"); 209 AER_PR(info, dev, " TLP Header:"
213 AER_PR(info, "%02x%02x%02x%02x %02x%02x%02x%02x" 210 " %02x%02x%02x%02x %02x%02x%02x%02x"
214 " %02x%02x%02x%02x %02x%02x%02x%02x\n", 211 " %02x%02x%02x%02x %02x%02x%02x%02x\n",
215 *(tlp + 3), *(tlp + 2), *(tlp + 1), *tlp, 212 *(tlp + 3), *(tlp + 2), *(tlp + 1), *tlp,
216 *(tlp + 7), *(tlp + 6), *(tlp + 5), *(tlp + 4), 213 *(tlp + 7), *(tlp + 6), *(tlp + 5), *(tlp + 4),
@@ -221,6 +218,13 @@ void aer_print_error(struct pci_dev *dev, struct aer_err_info *info)
221 } 218 }
222 219
223 if (info->id && info->error_dev_num > 1 && info->id == id) 220 if (info->id && info->error_dev_num > 1 && info->id == id)
224 AER_PR(info, "Error of this Agent(%04x) is reported first\n", 221 AER_PR(info, dev,
225 id); 222 " Error of this Agent(%04x) is reported first\n", id);
223}
224
225void aer_print_port_info(struct pci_dev *dev, struct aer_err_info *info)
226{
227 dev_info(&dev->dev, "AER: %s%s error received: id=%04x\n",
228 info->multi_error_valid ? "Multiple " : "",
229 aer_error_severity_string[info->severity], info->id);
226} 230}