Commit 2f58265e authored by Kelvin Cao's avatar Kelvin Cao Committed by Jon Mason

ntb_hw_switchtec: Update the way of getting VEP instance ID

Gen4 firmware adds DMA VEP and NVMe VEP support in VEP (virtual EP)
instance ID register in addtion to management EP. Update the way of
getting management VEP instance ID.
Signed-off-by: default avatarKelvin Cao <kelvin.cao@microchip.com>
Signed-off-by: default avatarJon Mason <jdmason@kudzu.us>
parent 857e239c
...@@ -419,8 +419,10 @@ static void switchtec_ntb_part_link_speed(struct switchtec_ntb *sndev, ...@@ -419,8 +419,10 @@ static void switchtec_ntb_part_link_speed(struct switchtec_ntb *sndev,
enum ntb_width *width) enum ntb_width *width)
{ {
struct switchtec_dev *stdev = sndev->stdev; struct switchtec_dev *stdev = sndev->stdev;
u32 pff = struct part_cfg_regs __iomem *part_cfg =
ioread32(&stdev->mmio_part_cfg_all[partition].vep_pff_inst_id); &stdev->mmio_part_cfg_all[partition];
u32 pff = ioread32(&part_cfg->vep_pff_inst_id) & 0xFF;
u32 linksta = ioread32(&stdev->mmio_pff_csr[pff].pci_cap_region[13]); u32 linksta = ioread32(&stdev->mmio_pff_csr[pff].pci_cap_region[13]);
if (speed) if (speed)
...@@ -1089,7 +1091,7 @@ static int crosslink_enum_partition(struct switchtec_ntb *sndev, ...@@ -1089,7 +1091,7 @@ static int crosslink_enum_partition(struct switchtec_ntb *sndev,
{ {
struct part_cfg_regs __iomem *part_cfg = struct part_cfg_regs __iomem *part_cfg =
&sndev->stdev->mmio_part_cfg_all[sndev->peer_partition]; &sndev->stdev->mmio_part_cfg_all[sndev->peer_partition];
u32 pff = ioread32(&part_cfg->vep_pff_inst_id); u32 pff = ioread32(&part_cfg->vep_pff_inst_id) & 0xFF;
struct pff_csr_regs __iomem *mmio_pff = struct pff_csr_regs __iomem *mmio_pff =
&sndev->stdev->mmio_pff_csr[pff]; &sndev->stdev->mmio_pff_csr[pff];
const u64 bar_space = 0x1000000000LL; const u64 bar_space = 0x1000000000LL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment