net/nfp: reserve BAR for expansion ROM
Checks
Commit Message
For some platform, the warm restart of host doesn't trigger
the reset of NIC, which causes the initialize process of NIC
not executed with the right expansion ROM mapping. Consequently,
the PXE boot won't work in this case.
Now reserve BAR 2.0 which used by expansion ROM so that the
mapping is fixed.
Signed-off-by: Chaoyong He <chaoyong.he@corigine.com>
Reviewed-by: Long Wu <long.wu@corigine.com>
Reviewed-by: Peng Zhang <peng.zhang@corigine.com>
---
drivers/net/nfp/nfpcore/nfp6000_pcie.c | 10 ++++++++++
1 file changed, 10 insertions(+)
Comments
On 9/3/2024 3:34 AM, Chaoyong He wrote:
> For some platform, the warm restart of host doesn't trigger
> the reset of NIC, which causes the initialize process of NIC
> not executed with the right expansion ROM mapping. Consequently,
> the PXE boot won't work in this case.
>
> Now reserve BAR 2.0 which used by expansion ROM so that the
> mapping is fixed.
>
> Signed-off-by: Chaoyong He <chaoyong.he@corigine.com>
> Reviewed-by: Long Wu <long.wu@corigine.com>
> Reviewed-by: Peng Zhang <peng.zhang@corigine.com>
>
Applied to dpdk-next-net/main, thanks.
@@ -370,6 +370,16 @@ nfp_enable_bars(struct nfp_pcie_user *nfp)
if (nfp_bar_write(nfp, bar, barcfg_msix_general) < 0)
return -EIO;
+
+ /* Reserve BAR2.0 for expansion rom mapping */
+ if (type == RTE_PROC_PRIMARY) {
+ if (nfp->pci_dev->id.device_id == PCI_DEVICE_ID_NFP3800_PF_NIC) {
+ bar = &nfp->bar[16];
+ if (bar != NULL)
+ bar->lock = true;
+ }
+ }
+
return 0;
}