Lines Matching +full:rx +full:- +full:eq
2 * Copyright(c) 2015 - 2017 Intel Corporation.
24 * - Redistributions of source code must retain the above copyright
26 * - Redistributions in binary form must reproduce the above copyright
30 * - Neither the name of Intel Corporation nor the names of its
92 hfi1_early_err(&pdev->dev, "pci enable failed: error %d\n", in hfi1_pcie_init()
93 -ret); in hfi1_pcie_init()
99 hfi1_early_err(&pdev->dev, in hfi1_pcie_init()
100 "pci_request_regions fails: err %d\n", -ret); in hfi1_pcie_init()
113 hfi1_early_err(&pdev->dev, in hfi1_pcie_init()
122 hfi1_early_err(&pdev->dev, in hfi1_pcie_init()
152 * fields required to re-initialize after a chip reset, or for
173 return -EINVAL; in hfi1_pcie_ddinit()
176 dd->kregbase1 = ioremap_nocache(addr, RCV_ARRAY); in hfi1_pcie_ddinit()
177 if (!dd->kregbase1) { in hfi1_pcie_ddinit()
179 return -ENOMEM; in hfi1_pcie_ddinit()
181 dd_dev_info(dd, "UC base1: %p for %x\n", dd->kregbase1, RCV_ARRAY); in hfi1_pcie_ddinit()
184 dd->revision = readq(dd->kregbase1 + CCE_REVISION); in hfi1_pcie_ddinit()
185 if (dd->revision == ~(u64)0) { in hfi1_pcie_ddinit()
190 rcv_array_count = readq(dd->kregbase1 + RCV_ARRAY_CNT); in hfi1_pcie_ddinit()
192 dd->base2_start = RCV_ARRAY + rcv_array_count * 8; in hfi1_pcie_ddinit()
194 dd->kregbase2 = ioremap_nocache( in hfi1_pcie_ddinit()
195 addr + dd->base2_start, in hfi1_pcie_ddinit()
196 TXE_PIO_SEND - dd->base2_start); in hfi1_pcie_ddinit()
197 if (!dd->kregbase2) { in hfi1_pcie_ddinit()
201 dd_dev_info(dd, "UC base2: %p for %x\n", dd->kregbase2, in hfi1_pcie_ddinit()
202 TXE_PIO_SEND - dd->base2_start); in hfi1_pcie_ddinit()
204 dd->piobase = ioremap_wc(addr + TXE_PIO_SEND, TXE_PIO_SIZE); in hfi1_pcie_ddinit()
205 if (!dd->piobase) { in hfi1_pcie_ddinit()
209 dd_dev_info(dd, "WC piobase: %p\n for %x", dd->piobase, TXE_PIO_SIZE); in hfi1_pcie_ddinit()
211 dd->physaddr = addr; /* used for io_remap, etc. */ in hfi1_pcie_ddinit()
214 * Map the chip's RcvArray as write-combining to allow us in hfi1_pcie_ddinit()
217 dd->rcvarray_wc = ioremap_wc(addr + RCV_ARRAY, in hfi1_pcie_ddinit()
219 if (!dd->rcvarray_wc) { in hfi1_pcie_ddinit()
224 dd->rcvarray_wc, rcv_array_count * 8); in hfi1_pcie_ddinit()
226 dd->flags |= HFI1_PRESENT; /* chip.c CSR routines now work */ in hfi1_pcie_ddinit()
229 ret = -ENOMEM; in hfi1_pcie_ddinit()
235 * Do PCIe cleanup related to dd, after chip-specific cleanup, etc. Just prior
241 dd->flags &= ~HFI1_PRESENT; in hfi1_pcie_ddcleanup()
242 if (dd->kregbase1) in hfi1_pcie_ddcleanup()
243 iounmap(dd->kregbase1); in hfi1_pcie_ddcleanup()
244 dd->kregbase1 = NULL; in hfi1_pcie_ddcleanup()
245 if (dd->kregbase2) in hfi1_pcie_ddcleanup()
246 iounmap(dd->kregbase2); in hfi1_pcie_ddcleanup()
247 dd->kregbase2 = NULL; in hfi1_pcie_ddcleanup()
248 if (dd->rcvarray_wc) in hfi1_pcie_ddcleanup()
249 iounmap(dd->rcvarray_wc); in hfi1_pcie_ddcleanup()
250 dd->rcvarray_wc = NULL; in hfi1_pcie_ddcleanup()
251 if (dd->piobase) in hfi1_pcie_ddcleanup()
252 iounmap(dd->piobase); in hfi1_pcie_ddcleanup()
253 dd->piobase = NULL; in hfi1_pcie_ddcleanup()
282 /* read the link status and set dd->{lbus_width,lbus_speed,lbus_info} */
288 ret = pcie_capability_read_word(dd->pcidev, PCI_EXP_LNKSTA, &linkstat); in update_lbus_info()
294 dd->lbus_width = extract_width(linkstat); in update_lbus_info()
295 dd->lbus_speed = extract_speed(linkstat); in update_lbus_info()
296 snprintf(dd->lbus_info, sizeof(dd->lbus_info), in update_lbus_info()
297 "PCIe,%uMHz,x%u", dd->lbus_speed, dd->lbus_width); in update_lbus_info()
307 struct pci_dev *parent = dd->pcidev->bus->self; in pcie_speeds()
310 if (!pci_is_pcie(dd->pcidev)) { in pcie_speeds()
312 return -EINVAL; in pcie_speeds()
316 dd->link_gen3_capable = 1; in pcie_speeds()
318 ret = pcie_capability_read_dword(dd->pcidev, PCI_EXP_LNKCAP, &linkcap); in pcie_speeds()
328 dd->link_gen3_capable = 0; in pcie_speeds()
332 * bus->max_bus_speed is set from the bridge's linkcap Max Link Speed in pcie_speeds()
335 (dd->pcidev->bus->max_bus_speed == PCIE_SPEED_2_5GT || in pcie_speeds()
336 dd->pcidev->bus->max_bus_speed == PCIE_SPEED_5_0GT)) { in pcie_speeds()
338 dd->link_gen3_capable = 0; in pcie_speeds()
344 dd_dev_info(dd, "%s\n", dd->lbus_info); in pcie_speeds()
351 * - actual number of interrupts allocated or
352 * - error
358 nvec = pci_alloc_irq_vectors(dd->pcidev, msireq, msireq, PCI_IRQ_MSIX); in request_msix()
374 ret = pci_write_config_word(dd->pcidev, PCI_COMMAND, dd->pci_command); in restore_pci_variables()
378 ret = pci_write_config_dword(dd->pcidev, PCI_BASE_ADDRESS_0, in restore_pci_variables()
379 dd->pcibar0); in restore_pci_variables()
383 ret = pci_write_config_dword(dd->pcidev, PCI_BASE_ADDRESS_1, in restore_pci_variables()
384 dd->pcibar1); in restore_pci_variables()
388 ret = pci_write_config_dword(dd->pcidev, PCI_ROM_ADDRESS, dd->pci_rom); in restore_pci_variables()
392 ret = pcie_capability_write_word(dd->pcidev, PCI_EXP_DEVCTL, in restore_pci_variables()
393 dd->pcie_devctl); in restore_pci_variables()
397 ret = pcie_capability_write_word(dd->pcidev, PCI_EXP_LNKCTL, in restore_pci_variables()
398 dd->pcie_lnkctl); in restore_pci_variables()
402 ret = pcie_capability_write_word(dd->pcidev, PCI_EXP_DEVCTL2, in restore_pci_variables()
403 dd->pcie_devctl2); in restore_pci_variables()
407 ret = pci_write_config_dword(dd->pcidev, PCI_CFG_MSIX0, dd->pci_msix0); in restore_pci_variables()
411 if (pci_find_ext_capability(dd->pcidev, PCI_EXT_CAP_ID_TPH)) { in restore_pci_variables()
412 ret = pci_write_config_dword(dd->pcidev, PCIE_CFG_TPH2, in restore_pci_variables()
413 dd->pci_tph2); in restore_pci_variables()
429 ret = pci_read_config_dword(dd->pcidev, PCI_BASE_ADDRESS_0, in save_pci_variables()
430 &dd->pcibar0); in save_pci_variables()
434 ret = pci_read_config_dword(dd->pcidev, PCI_BASE_ADDRESS_1, in save_pci_variables()
435 &dd->pcibar1); in save_pci_variables()
439 ret = pci_read_config_dword(dd->pcidev, PCI_ROM_ADDRESS, &dd->pci_rom); in save_pci_variables()
443 ret = pci_read_config_word(dd->pcidev, PCI_COMMAND, &dd->pci_command); in save_pci_variables()
447 ret = pcie_capability_read_word(dd->pcidev, PCI_EXP_DEVCTL, in save_pci_variables()
448 &dd->pcie_devctl); in save_pci_variables()
452 ret = pcie_capability_read_word(dd->pcidev, PCI_EXP_LNKCTL, in save_pci_variables()
453 &dd->pcie_lnkctl); in save_pci_variables()
457 ret = pcie_capability_read_word(dd->pcidev, PCI_EXP_DEVCTL2, in save_pci_variables()
458 &dd->pcie_devctl2); in save_pci_variables()
462 ret = pci_read_config_dword(dd->pcidev, PCI_CFG_MSIX0, &dd->pci_msix0); in save_pci_variables()
466 if (pci_find_ext_capability(dd->pcidev, PCI_EXT_CAP_ID_TPH)) { in save_pci_variables()
467 ret = pci_read_config_dword(dd->pcidev, PCIE_CFG_TPH2, in save_pci_variables()
468 &dd->pci_tph2); in save_pci_variables()
480 * BIOS may not set PCIe bus-utilization parameters for best performance.
502 ret = pcie_capability_read_word(dd->pcidev, PCI_EXP_DEVCTL, &ectl); in tune_pcie_caps()
506 ret = pcie_capability_write_word(dd->pcidev, in tune_pcie_caps()
512 parent = dd->pcidev->bus->self; in tune_pcie_caps()
521 if (!pci_is_root_bus(parent->bus)) { in tune_pcie_caps()
529 if (!pci_is_pcie(dd->pcidev)) { in tune_pcie_caps()
533 rc_mpss = parent->pcie_mpss; in tune_pcie_caps()
534 rc_mps = ffs(pcie_get_mps(parent)) - 8; in tune_pcie_caps()
536 ep_mpss = dd->pcidev->pcie_mpss; in tune_pcie_caps()
537 ep_mps = ffs(pcie_get_mps(dd->pcidev)) - 8; in tune_pcie_caps()
554 pcie_set_mps(dd->pcidev, 128 << ep_mps); in tune_pcie_caps()
560 * which is code '5' (log2(4096) - 7) in tune_pcie_caps()
568 ep_mrrs = pcie_get_readrq(dd->pcidev); in tune_pcie_caps()
576 pcie_set_readrq(dd->pcidev, ep_mrrs); in tune_pcie_caps()
607 dd->flags &= ~HFI1_PRESENT; in pci_error_detected()
629 if (dd && dd->pport) { in pci_mmio_enabled()
630 words = read_port_cntr(dd->pport, C_RX_WORDS, CNTR_INVALID_VL); in pci_mmio_enabled()
658 * unlike sysfs-requested reset. Better than in pci_resume()
661 hfi1_init(dd, 1); /* same as re-init after reset */ in pci_resume()
699 MODULE_PARM_DESC(pcie_target, "PCIe target speed (0 skip, 1-3 Gen1-3)");
714 MODULE_PARM_DESC(pcie_pset, "PCIe Eq Pset value to use, range is 0-10");
718 MODULE_PARM_DESC(pcie_ctle, "PCIe static CTLE mode, bit 0 - discrete on/off, bit 1 - integrated on/…
796 * Load the given EQ preset table into the PCIe hardware.
798 static int load_eq_table(struct hfi1_devdata *dd, const u8 eq[11][3], u8 fs, in load_eq_table()
801 struct pci_dev *pdev = dd->pcidev; in load_eq_table()
812 c_minus1 = eq[i][PREC] / div; in load_eq_table()
813 c0 = fs - (eq[i][PREC] / div) - (eq[i][POST] / div); in load_eq_table()
814 c_plus1 = eq[i][POST] / div; in load_eq_table()
817 /* check if these coefficients violate EQ rules */ in load_eq_table()
818 ret = pci_read_config_dword(dd->pcidev, in load_eq_table()
830 "Gen3 EQ Table Coefficient rule violations\n"); in load_eq_table()
834 i, (u32)eq[i][0], (u32)eq[i][1], in load_eq_table()
835 (u32)eq[i][2]); in load_eq_table()
842 return -EINVAL; in load_eq_table()
864 sbus_request(dd, pcie_pcs_addrs[dd->hfi1_id][i], in pcie_post_steps()
879 struct pci_dev *dev = dd->pcidev; in trigger_sbr()
883 if (!dev->bus->self) { in trigger_sbr()
885 return -ENOTTY; in trigger_sbr()
889 list_for_each_entry(pdev, &dev->bus->devices, bus_list) in trigger_sbr()
894 return -ENOTTY; in trigger_sbr()
902 return pci_bridge_secondary_bus_reset(dev->bus->self); in trigger_sbr()
923 reg = (((u64)1 << dd->hfi1_id) << in arm_gasket_logic()
925 ((u64)pcie_serdes_broadcast[dd->hfi1_id] << in arm_gasket_logic()
952 * Write xmt_margin for full-swing (WFR-B) or half-swing (WFR-C).
965 * For Discrete, use full-swing. in write_xmt_margin()
966 * - PCIe TX defaults to full-swing. in write_xmt_margin()
968 * For Integrated, use half-swing in write_xmt_margin()
969 * - Copy xmt_margin and xmt_margin_oe in write_xmt_margin()
972 if (dd->pcidev->device == PCI_DEVICE_ID_INTEL1) { /* integrated */ in write_xmt_margin()
1017 struct pci_dev *parent = dd->pcidev->bus->self; in do_pcie_gen3_transition()
1030 const u8 (*eq)[3]; in do_pcie_gen3_transition() local
1036 if (dd->icode != ICODE_RTL_SILICON) in do_pcie_gen3_transition()
1049 /* off or invalid target - skip */ in do_pcie_gen3_transition()
1055 if (dd->lbus_speed == target_speed) { in do_pcie_gen3_transition()
1058 pcie_force ? "re-doing anyway" : "skipping"); in do_pcie_gen3_transition()
1081 if (pcie_target == 3 && !dd->link_gen3_capable) { in do_pcie_gen3_transition()
1083 ret = -ENOSYS; in do_pcie_gen3_transition()
1121 * PcieCfgSpcie1 - Link Control 3 in do_pcie_gen3_transition()
1122 * Leave at reset value. No need to set PerfEq - link equalization in do_pcie_gen3_transition()
1127 /* clear all 16 per-lane error bits (PCIe: Lane Error Status) */ in do_pcie_gen3_transition()
1128 pci_write_config_dword(dd->pcidev, PCIE_CFG_SPCIE2, 0xffff); in do_pcie_gen3_transition()
1133 * PcieCfgRegPl2 - Port Force Link in do_pcie_gen3_transition()
1139 pci_write_config_dword(dd->pcidev, PCIE_CFG_REG_PL2, reg32); in do_pcie_gen3_transition()
1142 * PcieCfgRegPl100 - Gen3 Control in do_pcie_gen3_transition()
1149 pci_write_config_dword(dd->pcidev, PCIE_CFG_REG_PL100, reg32); in do_pcie_gen3_transition()
1152 * PcieCfgRegPl101 - Gen3 EQ FS and LF in do_pcie_gen3_transition()
1153 * PcieCfgRegPl102 - Gen3 EQ Presets to Coefficients Mapping in do_pcie_gen3_transition()
1154 * PcieCfgRegPl103 - Gen3 EQ Preset Index in do_pcie_gen3_transition()
1155 * PcieCfgRegPl105 - Gen3 EQ Status in do_pcie_gen3_transition()
1157 * Give initial EQ settings. in do_pcie_gen3_transition()
1159 if (dd->pcidev->device == PCI_DEVICE_ID_INTEL0) { /* discrete */ in do_pcie_gen3_transition()
1164 eq = discrete_preliminary_eq; in do_pcie_gen3_transition()
1167 /* bit 0 - discrete on/off */ in do_pcie_gen3_transition()
1174 eq = integrated_preliminary_eq; in do_pcie_gen3_transition()
1177 /* bit 1 - integrated on/off */ in do_pcie_gen3_transition()
1180 pci_write_config_dword(dd->pcidev, PCIE_CFG_REG_PL101, in do_pcie_gen3_transition()
1185 ret = load_eq_table(dd, eq, fs, div); in do_pcie_gen3_transition()
1190 * PcieCfgRegPl106 - Gen3 EQ Control in do_pcie_gen3_transition()
1196 if (pset > 10) { /* valid range is 0-10, inclusive */ in do_pcie_gen3_transition()
1197 dd_dev_err(dd, "%s: Invalid Eq Pset %u, setting to %d\n", in do_pcie_gen3_transition()
1201 dd_dev_info(dd, "%s: using EQ Pset %u\n", __func__, pset); in do_pcie_gen3_transition()
1202 pci_write_config_dword(dd->pcidev, PCIE_CFG_REG_PL106, in do_pcie_gen3_transition()
1217 /* set the Rx Bit Rate to REFCLK ratio */ in do_pcie_gen3_transition()
1219 /* disable pCal for PCIe Gen3 RX equalization */ in do_pcie_gen3_transition()
1224 * Enable iCal for PCIe Gen3 RX equalization, and set which in do_pcie_gen3_transition()
1302 ret = pcie_capability_read_word(dd->pcidev, PCI_EXP_LNKCTL2, &lnkctl2); in do_pcie_gen3_transition()
1315 ret = pcie_capability_write_word(dd->pcidev, PCI_EXP_LNKCTL2, lnkctl2); in do_pcie_gen3_transition()
1353 ret = pci_read_config_word(dd->pcidev, PCI_VENDOR_ID, &vendor); in do_pcie_gen3_transition()
1364 ret = -EIO; in do_pcie_gen3_transition()
1388 * the SBR. Then check for any per-lane errors. Then look over in do_pcie_gen3_transition()
1394 dd_dev_err(dd, "SBR failed - unable to read from device\n"); in do_pcie_gen3_transition()
1396 ret = -ENOSYS; in do_pcie_gen3_transition()
1406 /* check for any per-lane errors */ in do_pcie_gen3_transition()
1407 ret = pci_read_config_dword(dd->pcidev, PCIE_CFG_SPCIE2, ®32); in do_pcie_gen3_transition()
1414 dd_dev_info(dd, "%s: per-lane errors: 0x%x\n", __func__, reg32); in do_pcie_gen3_transition()
1419 if ((status & (1 << dd->hfi1_id)) == 0) { in do_pcie_gen3_transition()
1422 __func__, status, 1 << dd->hfi1_id); in do_pcie_gen3_transition()
1423 ret = -EIO; in do_pcie_gen3_transition()
1432 ret = -EIO; in do_pcie_gen3_transition()
1439 dd->lbus_info); in do_pcie_gen3_transition()
1441 if (dd->lbus_speed != target_speed) { /* not target */ in do_pcie_gen3_transition()
1451 ret = -EIO; in do_pcie_gen3_transition()
1458 dd_dev_info(dd, "%s: Re-enable therm polling\n", in do_pcie_gen3_transition()