NTB: Ensure ntb_mw_get_align() is only called when the link is up
With Switchtec hardware it's impossible to get the alignment parameters for a peer's memory window until the peer's driver has configured its windows. Strictly speaking, the link doesn't have to be up for this, but the link being up is the only way the client can tell that the other side has been configured. This patch converts ntb_transport and ntb_perf to use this function after the link goes up. This simplifies these clients slightly because they no longer have to store the alignment parameters. It also tweaks ntb_tool so that peer_mw_trans will print zero if it is run before the link goes up. Signed-off-by: Logan Gunthorpe <logang@deltatee.com> Acked-by: Allen Hubbe <Allen.Hubbe@dell.com> Signed-off-by: Jon Mason <jdmason@kudzu.us>
This commit is contained in:

committed by
Jon Mason

parent
48c302dc8f
commit
980c41c86b
@@ -108,8 +108,6 @@ MODULE_PARM_DESC(on_node, "Run threads only on NTB device node (default: true)")
|
||||
struct perf_mw {
|
||||
phys_addr_t phys_addr;
|
||||
resource_size_t phys_size;
|
||||
resource_size_t xlat_align;
|
||||
resource_size_t xlat_align_size;
|
||||
void __iomem *vbase;
|
||||
size_t xlat_size;
|
||||
size_t buf_size;
|
||||
@@ -472,13 +470,20 @@ static int perf_set_mw(struct perf_ctx *perf, resource_size_t size)
|
||||
{
|
||||
struct perf_mw *mw = &perf->mw;
|
||||
size_t xlat_size, buf_size;
|
||||
resource_size_t xlat_align;
|
||||
resource_size_t xlat_align_size;
|
||||
int rc;
|
||||
|
||||
if (!size)
|
||||
return -EINVAL;
|
||||
|
||||
xlat_size = round_up(size, mw->xlat_align_size);
|
||||
buf_size = round_up(size, mw->xlat_align);
|
||||
rc = ntb_mw_get_align(perf->ntb, PIDX, 0, &xlat_align,
|
||||
&xlat_align_size, NULL);
|
||||
if (rc)
|
||||
return rc;
|
||||
|
||||
xlat_size = round_up(size, xlat_align_size);
|
||||
buf_size = round_up(size, xlat_align);
|
||||
|
||||
if (mw->xlat_size == xlat_size)
|
||||
return 0;
|
||||
@@ -567,11 +572,6 @@ static int perf_setup_mw(struct ntb_dev *ntb, struct perf_ctx *perf)
|
||||
|
||||
mw = &perf->mw;
|
||||
|
||||
rc = ntb_mw_get_align(ntb, PIDX, 0, &mw->xlat_align,
|
||||
&mw->xlat_align_size, NULL);
|
||||
if (rc)
|
||||
return rc;
|
||||
|
||||
rc = ntb_peer_mw_get_addr(ntb, 0, &mw->phys_addr, &mw->phys_size);
|
||||
if (rc)
|
||||
return rc;
|
||||
|
Reference in New Issue
Block a user