mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-03 19:24:02 +08:00
cxgb4vf: Make sge init code more readable
Adds a new function t4vf_fl_pkt_align() and use the same in SGE initialization code to find out freelist packet alignment Signed-off-by: Hariprasad Shenai <hariprasad@chelsio.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
edadad80d6
commit
cb440364c7
@ -2618,7 +2618,6 @@ int t4vf_sge_init(struct adapter *adapter)
|
|||||||
u32 fl0 = sge_params->sge_fl_buffer_size[0];
|
u32 fl0 = sge_params->sge_fl_buffer_size[0];
|
||||||
u32 fl1 = sge_params->sge_fl_buffer_size[1];
|
u32 fl1 = sge_params->sge_fl_buffer_size[1];
|
||||||
struct sge *s = &adapter->sge;
|
struct sge *s = &adapter->sge;
|
||||||
unsigned int ingpadboundary, ingpackboundary, ingpad_shift;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Start by vetting the basic SGE parameters which have been set up by
|
* Start by vetting the basic SGE parameters which have been set up by
|
||||||
@ -2630,7 +2629,8 @@ int t4vf_sge_init(struct adapter *adapter)
|
|||||||
fl0, fl1);
|
fl0, fl1);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
if ((sge_params->sge_control & RXPKTCPLMODE_F) == 0) {
|
if ((sge_params->sge_control & RXPKTCPLMODE_F) !=
|
||||||
|
RXPKTCPLMODE_V(RXPKTCPLMODE_SPLIT_X)) {
|
||||||
dev_err(adapter->pdev_dev, "bad SGE CPL MODE\n");
|
dev_err(adapter->pdev_dev, "bad SGE CPL MODE\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
@ -2643,41 +2643,7 @@ int t4vf_sge_init(struct adapter *adapter)
|
|||||||
s->stat_len = ((sge_params->sge_control & EGRSTATUSPAGESIZE_F)
|
s->stat_len = ((sge_params->sge_control & EGRSTATUSPAGESIZE_F)
|
||||||
? 128 : 64);
|
? 128 : 64);
|
||||||
s->pktshift = PKTSHIFT_G(sge_params->sge_control);
|
s->pktshift = PKTSHIFT_G(sge_params->sge_control);
|
||||||
|
s->fl_align = t4vf_fl_pkt_align(adapter);
|
||||||
/* T4 uses a single control field to specify both the PCIe Padding and
|
|
||||||
* Packing Boundary. T5 introduced the ability to specify these
|
|
||||||
* separately. The actual Ingress Packet Data alignment boundary
|
|
||||||
* within Packed Buffer Mode is the maximum of these two
|
|
||||||
* specifications. (Note that it makes no real practical sense to
|
|
||||||
* have the Pading Boudary be larger than the Packing Boundary but you
|
|
||||||
* could set the chip up that way and, in fact, legacy T4 code would
|
|
||||||
* end doing this because it would initialize the Padding Boundary and
|
|
||||||
* leave the Packing Boundary initialized to 0 (16 bytes).)
|
|
||||||
* Padding Boundary values in T6 starts from 8B,
|
|
||||||
* where as it is 32B for T4 and T5.
|
|
||||||
*/
|
|
||||||
if (CHELSIO_CHIP_VERSION(adapter->params.chip) <= CHELSIO_T5)
|
|
||||||
ingpad_shift = INGPADBOUNDARY_SHIFT_X;
|
|
||||||
else
|
|
||||||
ingpad_shift = T6_INGPADBOUNDARY_SHIFT_X;
|
|
||||||
|
|
||||||
ingpadboundary = 1 << (INGPADBOUNDARY_G(sge_params->sge_control) +
|
|
||||||
ingpad_shift);
|
|
||||||
if (is_t4(adapter->params.chip)) {
|
|
||||||
s->fl_align = ingpadboundary;
|
|
||||||
} else {
|
|
||||||
/* T5 has a different interpretation of one of the PCIe Packing
|
|
||||||
* Boundary values.
|
|
||||||
*/
|
|
||||||
ingpackboundary = INGPACKBOUNDARY_G(sge_params->sge_control2);
|
|
||||||
if (ingpackboundary == INGPACKBOUNDARY_16B_X)
|
|
||||||
ingpackboundary = 16;
|
|
||||||
else
|
|
||||||
ingpackboundary = 1 << (ingpackboundary +
|
|
||||||
INGPACKBOUNDARY_SHIFT_X);
|
|
||||||
|
|
||||||
s->fl_align = max(ingpadboundary, ingpackboundary);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* A FL with <= fl_starve_thres buffers is starving and a periodic
|
/* A FL with <= fl_starve_thres buffers is starving and a periodic
|
||||||
* timer will attempt to refill it. This needs to be larger than the
|
* timer will attempt to refill it. This needs to be larger than the
|
||||||
|
@ -309,6 +309,7 @@ int t4vf_port_init(struct adapter *, int);
|
|||||||
int t4vf_fw_reset(struct adapter *);
|
int t4vf_fw_reset(struct adapter *);
|
||||||
int t4vf_set_params(struct adapter *, unsigned int, const u32 *, const u32 *);
|
int t4vf_set_params(struct adapter *, unsigned int, const u32 *, const u32 *);
|
||||||
|
|
||||||
|
int t4vf_fl_pkt_align(struct adapter *adapter);
|
||||||
enum t4_bar2_qtype { T4_BAR2_QTYPE_EGRESS, T4_BAR2_QTYPE_INGRESS };
|
enum t4_bar2_qtype { T4_BAR2_QTYPE_EGRESS, T4_BAR2_QTYPE_INGRESS };
|
||||||
int t4vf_bar2_sge_qregs(struct adapter *adapter,
|
int t4vf_bar2_sge_qregs(struct adapter *adapter,
|
||||||
unsigned int qid,
|
unsigned int qid,
|
||||||
|
@ -417,6 +417,61 @@ int t4vf_set_params(struct adapter *adapter, unsigned int nparams,
|
|||||||
return t4vf_wr_mbox(adapter, &cmd, sizeof(cmd), NULL);
|
return t4vf_wr_mbox(adapter, &cmd, sizeof(cmd), NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* t4vf_fl_pkt_align - return the fl packet alignment
|
||||||
|
* @adapter: the adapter
|
||||||
|
*
|
||||||
|
* T4 has a single field to specify the packing and padding boundary.
|
||||||
|
* T5 onwards has separate fields for this and hence the alignment for
|
||||||
|
* next packet offset is maximum of these two. And T6 changes the
|
||||||
|
* Ingress Padding Boundary Shift, so it's all a mess and it's best
|
||||||
|
* if we put this in low-level Common Code ...
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
int t4vf_fl_pkt_align(struct adapter *adapter)
|
||||||
|
{
|
||||||
|
u32 sge_control, sge_control2;
|
||||||
|
unsigned int ingpadboundary, ingpackboundary, fl_align, ingpad_shift;
|
||||||
|
|
||||||
|
sge_control = adapter->params.sge.sge_control;
|
||||||
|
|
||||||
|
/* T4 uses a single control field to specify both the PCIe Padding and
|
||||||
|
* Packing Boundary. T5 introduced the ability to specify these
|
||||||
|
* separately. The actual Ingress Packet Data alignment boundary
|
||||||
|
* within Packed Buffer Mode is the maximum of these two
|
||||||
|
* specifications. (Note that it makes no real practical sense to
|
||||||
|
* have the Pading Boudary be larger than the Packing Boundary but you
|
||||||
|
* could set the chip up that way and, in fact, legacy T4 code would
|
||||||
|
* end doing this because it would initialize the Padding Boundary and
|
||||||
|
* leave the Packing Boundary initialized to 0 (16 bytes).)
|
||||||
|
* Padding Boundary values in T6 starts from 8B,
|
||||||
|
* where as it is 32B for T4 and T5.
|
||||||
|
*/
|
||||||
|
if (CHELSIO_CHIP_VERSION(adapter->params.chip) <= CHELSIO_T5)
|
||||||
|
ingpad_shift = INGPADBOUNDARY_SHIFT_X;
|
||||||
|
else
|
||||||
|
ingpad_shift = T6_INGPADBOUNDARY_SHIFT_X;
|
||||||
|
|
||||||
|
ingpadboundary = 1 << (INGPADBOUNDARY_G(sge_control) + ingpad_shift);
|
||||||
|
|
||||||
|
fl_align = ingpadboundary;
|
||||||
|
if (!is_t4(adapter->params.chip)) {
|
||||||
|
/* T5 has a different interpretation of one of the PCIe Packing
|
||||||
|
* Boundary values.
|
||||||
|
*/
|
||||||
|
sge_control2 = adapter->params.sge.sge_control2;
|
||||||
|
ingpackboundary = INGPACKBOUNDARY_G(sge_control2);
|
||||||
|
if (ingpackboundary == INGPACKBOUNDARY_16B_X)
|
||||||
|
ingpackboundary = 16;
|
||||||
|
else
|
||||||
|
ingpackboundary = 1 << (ingpackboundary +
|
||||||
|
INGPACKBOUNDARY_SHIFT_X);
|
||||||
|
|
||||||
|
fl_align = max(ingpadboundary, ingpackboundary);
|
||||||
|
}
|
||||||
|
return fl_align;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* t4vf_bar2_sge_qregs - return BAR2 SGE Queue register information
|
* t4vf_bar2_sge_qregs - return BAR2 SGE Queue register information
|
||||||
* @adapter: the adapter
|
* @adapter: the adapter
|
||||||
|
Loading…
Reference in New Issue
Block a user