net: mvpp2: do not use the CPU number to access the per-thread registers
This patch reworks the Marvell PPv2 driver to stop using directly the CPU number to access per-thread registers. Signed-off-by: Antoine Tenart <antoine.tenart@bootlin.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
1627442721
commit
543ec376e3
|
@ -86,9 +86,15 @@ static u32 mvpp2_read_relaxed(struct mvpp2 *priv, u32 offset)
|
||||||
{
|
{
|
||||||
return readl_relaxed(priv->swth_base[0] + offset);
|
return readl_relaxed(priv->swth_base[0] + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline u32 mvpp2_cpu_to_thread(int cpu)
|
||||||
|
{
|
||||||
|
return cpu;
|
||||||
|
}
|
||||||
|
|
||||||
/* These accessors should be used to access:
|
/* These accessors should be used to access:
|
||||||
*
|
*
|
||||||
* - per-CPU registers, where each CPU has its own copy of the
|
* - per-thread registers, where each thread has its own copy of the
|
||||||
* register.
|
* register.
|
||||||
*
|
*
|
||||||
* MVPP2_BM_VIRT_ALLOC_REG
|
* MVPP2_BM_VIRT_ALLOC_REG
|
||||||
|
@ -104,8 +110,8 @@ static u32 mvpp2_read_relaxed(struct mvpp2 *priv, u32 offset)
|
||||||
* MVPP2_TXQ_SENT_REG
|
* MVPP2_TXQ_SENT_REG
|
||||||
* MVPP2_RXQ_NUM_REG
|
* MVPP2_RXQ_NUM_REG
|
||||||
*
|
*
|
||||||
* - global registers that must be accessed through a specific CPU
|
* - global registers that must be accessed through a specific thread
|
||||||
* window, because they are related to an access to a per-CPU
|
* window, because they are related to an access to a per-thread
|
||||||
* register
|
* register
|
||||||
*
|
*
|
||||||
* MVPP2_BM_PHY_ALLOC_REG (related to MVPP2_BM_VIRT_ALLOC_REG)
|
* MVPP2_BM_PHY_ALLOC_REG (related to MVPP2_BM_VIRT_ALLOC_REG)
|
||||||
|
@ -122,28 +128,28 @@ static u32 mvpp2_read_relaxed(struct mvpp2 *priv, u32 offset)
|
||||||
* MVPP2_TXQ_PREF_BUF_REG (related to MVPP2_TXQ_NUM_REG)
|
* MVPP2_TXQ_PREF_BUF_REG (related to MVPP2_TXQ_NUM_REG)
|
||||||
* MVPP2_TXQ_PREF_BUF_REG (related to MVPP2_TXQ_NUM_REG)
|
* MVPP2_TXQ_PREF_BUF_REG (related to MVPP2_TXQ_NUM_REG)
|
||||||
*/
|
*/
|
||||||
static void mvpp2_percpu_write(struct mvpp2 *priv, unsigned int cpu,
|
static void mvpp2_percpu_write(struct mvpp2 *priv, unsigned int thread,
|
||||||
u32 offset, u32 data)
|
u32 offset, u32 data)
|
||||||
{
|
{
|
||||||
writel(data, priv->swth_base[cpu] + offset);
|
writel(data, priv->swth_base[thread] + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
static u32 mvpp2_percpu_read(struct mvpp2 *priv, unsigned int cpu,
|
static u32 mvpp2_percpu_read(struct mvpp2 *priv, unsigned int thread,
|
||||||
u32 offset)
|
u32 offset)
|
||||||
{
|
{
|
||||||
return readl(priv->swth_base[cpu] + offset);
|
return readl(priv->swth_base[thread] + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mvpp2_percpu_write_relaxed(struct mvpp2 *priv, unsigned int cpu,
|
static void mvpp2_percpu_write_relaxed(struct mvpp2 *priv, unsigned int thread,
|
||||||
u32 offset, u32 data)
|
u32 offset, u32 data)
|
||||||
{
|
{
|
||||||
writel_relaxed(data, priv->swth_base[cpu] + offset);
|
writel_relaxed(data, priv->swth_base[thread] + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
static u32 mvpp2_percpu_read_relaxed(struct mvpp2 *priv, unsigned int cpu,
|
static u32 mvpp2_percpu_read_relaxed(struct mvpp2 *priv, unsigned int thread,
|
||||||
u32 offset)
|
u32 offset)
|
||||||
{
|
{
|
||||||
return readl_relaxed(priv->swth_base[cpu] + offset);
|
return readl_relaxed(priv->swth_base[thread] + offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
static dma_addr_t mvpp2_txdesc_dma_addr_get(struct mvpp2_port *port,
|
static dma_addr_t mvpp2_txdesc_dma_addr_get(struct mvpp2_port *port,
|
||||||
|
@ -385,17 +391,17 @@ static void mvpp2_bm_bufs_get_addrs(struct device *dev, struct mvpp2 *priv,
|
||||||
dma_addr_t *dma_addr,
|
dma_addr_t *dma_addr,
|
||||||
phys_addr_t *phys_addr)
|
phys_addr_t *phys_addr)
|
||||||
{
|
{
|
||||||
unsigned int cpu = get_cpu();
|
unsigned int thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
|
|
||||||
*dma_addr = mvpp2_percpu_read(priv, cpu,
|
*dma_addr = mvpp2_percpu_read(priv, thread,
|
||||||
MVPP2_BM_PHY_ALLOC_REG(bm_pool->id));
|
MVPP2_BM_PHY_ALLOC_REG(bm_pool->id));
|
||||||
*phys_addr = mvpp2_percpu_read(priv, cpu, MVPP2_BM_VIRT_ALLOC_REG);
|
*phys_addr = mvpp2_percpu_read(priv, thread, MVPP2_BM_VIRT_ALLOC_REG);
|
||||||
|
|
||||||
if (priv->hw_version == MVPP22) {
|
if (priv->hw_version == MVPP22) {
|
||||||
u32 val;
|
u32 val;
|
||||||
u32 dma_addr_highbits, phys_addr_highbits;
|
u32 dma_addr_highbits, phys_addr_highbits;
|
||||||
|
|
||||||
val = mvpp2_percpu_read(priv, cpu, MVPP22_BM_ADDR_HIGH_ALLOC);
|
val = mvpp2_percpu_read(priv, thread, MVPP22_BM_ADDR_HIGH_ALLOC);
|
||||||
dma_addr_highbits = (val & MVPP22_BM_ADDR_HIGH_PHYS_MASK);
|
dma_addr_highbits = (val & MVPP22_BM_ADDR_HIGH_PHYS_MASK);
|
||||||
phys_addr_highbits = (val & MVPP22_BM_ADDR_HIGH_VIRT_MASK) >>
|
phys_addr_highbits = (val & MVPP22_BM_ADDR_HIGH_VIRT_MASK) >>
|
||||||
MVPP22_BM_ADDR_HIGH_VIRT_SHIFT;
|
MVPP22_BM_ADDR_HIGH_VIRT_SHIFT;
|
||||||
|
@ -626,7 +632,7 @@ static inline void mvpp2_bm_pool_put(struct mvpp2_port *port, int pool,
|
||||||
dma_addr_t buf_dma_addr,
|
dma_addr_t buf_dma_addr,
|
||||||
phys_addr_t buf_phys_addr)
|
phys_addr_t buf_phys_addr)
|
||||||
{
|
{
|
||||||
unsigned int cpu = get_cpu();
|
unsigned int thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
|
|
||||||
if (port->priv->hw_version == MVPP22) {
|
if (port->priv->hw_version == MVPP22) {
|
||||||
u32 val = 0;
|
u32 val = 0;
|
||||||
|
@ -640,7 +646,7 @@ static inline void mvpp2_bm_pool_put(struct mvpp2_port *port, int pool,
|
||||||
<< MVPP22_BM_ADDR_HIGH_VIRT_RLS_SHIFT) &
|
<< MVPP22_BM_ADDR_HIGH_VIRT_RLS_SHIFT) &
|
||||||
MVPP22_BM_ADDR_HIGH_VIRT_RLS_MASK;
|
MVPP22_BM_ADDR_HIGH_VIRT_RLS_MASK;
|
||||||
|
|
||||||
mvpp2_percpu_write_relaxed(port->priv, cpu,
|
mvpp2_percpu_write_relaxed(port->priv, thread,
|
||||||
MVPP22_BM_ADDR_HIGH_RLS_REG, val);
|
MVPP22_BM_ADDR_HIGH_RLS_REG, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -649,9 +655,9 @@ static inline void mvpp2_bm_pool_put(struct mvpp2_port *port, int pool,
|
||||||
* descriptor. Instead of storing the virtual address, we
|
* descriptor. Instead of storing the virtual address, we
|
||||||
* store the physical address
|
* store the physical address
|
||||||
*/
|
*/
|
||||||
mvpp2_percpu_write_relaxed(port->priv, cpu,
|
mvpp2_percpu_write_relaxed(port->priv, thread,
|
||||||
MVPP2_BM_VIRT_RLS_REG, buf_phys_addr);
|
MVPP2_BM_VIRT_RLS_REG, buf_phys_addr);
|
||||||
mvpp2_percpu_write_relaxed(port->priv, cpu,
|
mvpp2_percpu_write_relaxed(port->priv, thread,
|
||||||
MVPP2_BM_PHY_RLS_REG(pool), buf_dma_addr);
|
MVPP2_BM_PHY_RLS_REG(pool), buf_dma_addr);
|
||||||
|
|
||||||
put_cpu();
|
put_cpu();
|
||||||
|
@ -886,7 +892,7 @@ static inline void mvpp2_qvec_interrupt_disable(struct mvpp2_queue_vector *qvec)
|
||||||
MVPP2_ISR_DISABLE_INTERRUPT(qvec->sw_thread_mask));
|
MVPP2_ISR_DISABLE_INTERRUPT(qvec->sw_thread_mask));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Mask the current CPU's Rx/Tx interrupts
|
/* Mask the current thread's Rx/Tx interrupts
|
||||||
* Called by on_each_cpu(), guaranteed to run with migration disabled,
|
* Called by on_each_cpu(), guaranteed to run with migration disabled,
|
||||||
* using smp_processor_id() is OK.
|
* using smp_processor_id() is OK.
|
||||||
*/
|
*/
|
||||||
|
@ -894,11 +900,11 @@ static void mvpp2_interrupts_mask(void *arg)
|
||||||
{
|
{
|
||||||
struct mvpp2_port *port = arg;
|
struct mvpp2_port *port = arg;
|
||||||
|
|
||||||
mvpp2_percpu_write(port->priv, smp_processor_id(),
|
mvpp2_percpu_write(port->priv, mvpp2_cpu_to_thread(smp_processor_id()),
|
||||||
MVPP2_ISR_RX_TX_MASK_REG(port->id), 0);
|
MVPP2_ISR_RX_TX_MASK_REG(port->id), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Unmask the current CPU's Rx/Tx interrupts.
|
/* Unmask the current thread's Rx/Tx interrupts.
|
||||||
* Called by on_each_cpu(), guaranteed to run with migration disabled,
|
* Called by on_each_cpu(), guaranteed to run with migration disabled,
|
||||||
* using smp_processor_id() is OK.
|
* using smp_processor_id() is OK.
|
||||||
*/
|
*/
|
||||||
|
@ -912,7 +918,7 @@ static void mvpp2_interrupts_unmask(void *arg)
|
||||||
if (port->has_tx_irqs)
|
if (port->has_tx_irqs)
|
||||||
val |= MVPP2_CAUSE_TXQ_OCCUP_DESC_ALL_MASK;
|
val |= MVPP2_CAUSE_TXQ_OCCUP_DESC_ALL_MASK;
|
||||||
|
|
||||||
mvpp2_percpu_write(port->priv, smp_processor_id(),
|
mvpp2_percpu_write(port->priv, mvpp2_cpu_to_thread(smp_processor_id()),
|
||||||
MVPP2_ISR_RX_TX_MASK_REG(port->id), val);
|
MVPP2_ISR_RX_TX_MASK_REG(port->id), val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1624,7 +1630,7 @@ mvpp2_txq_next_desc_get(struct mvpp2_tx_queue *txq)
|
||||||
static void mvpp2_aggr_txq_pend_desc_add(struct mvpp2_port *port, int pending)
|
static void mvpp2_aggr_txq_pend_desc_add(struct mvpp2_port *port, int pending)
|
||||||
{
|
{
|
||||||
/* aggregated access - relevant TXQ number is written in TX desc */
|
/* aggregated access - relevant TXQ number is written in TX desc */
|
||||||
mvpp2_percpu_write(port->priv, smp_processor_id(),
|
mvpp2_percpu_write(port->priv, mvpp2_cpu_to_thread(smp_processor_id()),
|
||||||
MVPP2_AGGR_TXQ_UPDATE_REG, pending);
|
MVPP2_AGGR_TXQ_UPDATE_REG, pending);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1639,9 +1645,9 @@ static int mvpp2_aggr_desc_num_check(struct mvpp2 *priv,
|
||||||
{
|
{
|
||||||
if ((aggr_txq->count + num) > MVPP2_AGGR_TXQ_SIZE) {
|
if ((aggr_txq->count + num) > MVPP2_AGGR_TXQ_SIZE) {
|
||||||
/* Update number of occupied aggregated Tx descriptors */
|
/* Update number of occupied aggregated Tx descriptors */
|
||||||
unsigned int cpu = smp_processor_id();
|
unsigned int thread = mvpp2_cpu_to_thread(smp_processor_id());
|
||||||
u32 val = mvpp2_read_relaxed(priv,
|
u32 val = mvpp2_read_relaxed(priv,
|
||||||
MVPP2_AGGR_TXQ_STATUS_REG(cpu));
|
MVPP2_AGGR_TXQ_STATUS_REG(thread));
|
||||||
|
|
||||||
aggr_txq->count = val & MVPP2_AGGR_TXQ_PENDING_MASK;
|
aggr_txq->count = val & MVPP2_AGGR_TXQ_PENDING_MASK;
|
||||||
|
|
||||||
|
@ -1661,12 +1667,12 @@ static int mvpp2_txq_alloc_reserved_desc(struct mvpp2 *priv,
|
||||||
struct mvpp2_tx_queue *txq, int num)
|
struct mvpp2_tx_queue *txq, int num)
|
||||||
{
|
{
|
||||||
u32 val;
|
u32 val;
|
||||||
unsigned int cpu = smp_processor_id();
|
unsigned int thread = mvpp2_cpu_to_thread(smp_processor_id());
|
||||||
|
|
||||||
val = (txq->id << MVPP2_TXQ_RSVD_REQ_Q_OFFSET) | num;
|
val = (txq->id << MVPP2_TXQ_RSVD_REQ_Q_OFFSET) | num;
|
||||||
mvpp2_percpu_write_relaxed(priv, cpu, MVPP2_TXQ_RSVD_REQ_REG, val);
|
mvpp2_percpu_write_relaxed(priv, thread, MVPP2_TXQ_RSVD_REQ_REG, val);
|
||||||
|
|
||||||
val = mvpp2_percpu_read_relaxed(priv, cpu, MVPP2_TXQ_RSVD_RSLT_REG);
|
val = mvpp2_percpu_read_relaxed(priv, thread, MVPP2_TXQ_RSVD_RSLT_REG);
|
||||||
|
|
||||||
return val & MVPP2_TXQ_RSVD_RSLT_MASK;
|
return val & MVPP2_TXQ_RSVD_RSLT_MASK;
|
||||||
}
|
}
|
||||||
|
@ -1760,7 +1766,7 @@ static u32 mvpp2_txq_desc_csum(int l3_offs, int l3_proto,
|
||||||
|
|
||||||
/* Get number of sent descriptors and decrement counter.
|
/* Get number of sent descriptors and decrement counter.
|
||||||
* The number of sent descriptors is returned.
|
* The number of sent descriptors is returned.
|
||||||
* Per-CPU access
|
* Per-thread access
|
||||||
*
|
*
|
||||||
* Called only from mvpp2_txq_done(), called from mvpp2_tx()
|
* Called only from mvpp2_txq_done(), called from mvpp2_tx()
|
||||||
* (migration disabled) and from the TX completion tasklet (migration
|
* (migration disabled) and from the TX completion tasklet (migration
|
||||||
|
@ -1772,7 +1778,8 @@ static inline int mvpp2_txq_sent_desc_proc(struct mvpp2_port *port,
|
||||||
u32 val;
|
u32 val;
|
||||||
|
|
||||||
/* Reading status reg resets transmitted descriptor counter */
|
/* Reading status reg resets transmitted descriptor counter */
|
||||||
val = mvpp2_percpu_read_relaxed(port->priv, smp_processor_id(),
|
val = mvpp2_percpu_read_relaxed(port->priv,
|
||||||
|
mvpp2_cpu_to_thread(smp_processor_id()),
|
||||||
MVPP2_TXQ_SENT_REG(txq->id));
|
MVPP2_TXQ_SENT_REG(txq->id));
|
||||||
|
|
||||||
return (val & MVPP2_TRANSMITTED_COUNT_MASK) >>
|
return (val & MVPP2_TRANSMITTED_COUNT_MASK) >>
|
||||||
|
@ -1790,7 +1797,8 @@ static void mvpp2_txq_sent_counter_clear(void *arg)
|
||||||
for (queue = 0; queue < port->ntxqs; queue++) {
|
for (queue = 0; queue < port->ntxqs; queue++) {
|
||||||
int id = port->txqs[queue]->id;
|
int id = port->txqs[queue]->id;
|
||||||
|
|
||||||
mvpp2_percpu_read(port->priv, smp_processor_id(),
|
mvpp2_percpu_read(port->priv,
|
||||||
|
mvpp2_cpu_to_thread(smp_processor_id()),
|
||||||
MVPP2_TXQ_SENT_REG(id));
|
MVPP2_TXQ_SENT_REG(id));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1850,13 +1858,13 @@ static void mvpp2_txp_max_tx_size_set(struct mvpp2_port *port)
|
||||||
static void mvpp2_rx_pkts_coal_set(struct mvpp2_port *port,
|
static void mvpp2_rx_pkts_coal_set(struct mvpp2_port *port,
|
||||||
struct mvpp2_rx_queue *rxq)
|
struct mvpp2_rx_queue *rxq)
|
||||||
{
|
{
|
||||||
unsigned int cpu = get_cpu();
|
unsigned int thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
|
|
||||||
if (rxq->pkts_coal > MVPP2_OCCUPIED_THRESH_MASK)
|
if (rxq->pkts_coal > MVPP2_OCCUPIED_THRESH_MASK)
|
||||||
rxq->pkts_coal = MVPP2_OCCUPIED_THRESH_MASK;
|
rxq->pkts_coal = MVPP2_OCCUPIED_THRESH_MASK;
|
||||||
|
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_NUM_REG, rxq->id);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_NUM_REG, rxq->id);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_THRESH_REG,
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_THRESH_REG,
|
||||||
rxq->pkts_coal);
|
rxq->pkts_coal);
|
||||||
|
|
||||||
put_cpu();
|
put_cpu();
|
||||||
|
@ -1866,15 +1874,15 @@ static void mvpp2_rx_pkts_coal_set(struct mvpp2_port *port,
|
||||||
static void mvpp2_tx_pkts_coal_set(struct mvpp2_port *port,
|
static void mvpp2_tx_pkts_coal_set(struct mvpp2_port *port,
|
||||||
struct mvpp2_tx_queue *txq)
|
struct mvpp2_tx_queue *txq)
|
||||||
{
|
{
|
||||||
unsigned int cpu = get_cpu();
|
unsigned int thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
u32 val;
|
u32 val;
|
||||||
|
|
||||||
if (txq->done_pkts_coal > MVPP2_TXQ_THRESH_MASK)
|
if (txq->done_pkts_coal > MVPP2_TXQ_THRESH_MASK)
|
||||||
txq->done_pkts_coal = MVPP2_TXQ_THRESH_MASK;
|
txq->done_pkts_coal = MVPP2_TXQ_THRESH_MASK;
|
||||||
|
|
||||||
val = (txq->done_pkts_coal << MVPP2_TXQ_THRESH_OFFSET);
|
val = (txq->done_pkts_coal << MVPP2_TXQ_THRESH_OFFSET);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_NUM_REG, txq->id);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_NUM_REG, txq->id);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_THRESH_REG, val);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_THRESH_REG, val);
|
||||||
|
|
||||||
put_cpu();
|
put_cpu();
|
||||||
}
|
}
|
||||||
|
@ -1991,7 +1999,7 @@ static void mvpp2_txq_done(struct mvpp2_port *port, struct mvpp2_tx_queue *txq,
|
||||||
}
|
}
|
||||||
|
|
||||||
static unsigned int mvpp2_tx_done(struct mvpp2_port *port, u32 cause,
|
static unsigned int mvpp2_tx_done(struct mvpp2_port *port, u32 cause,
|
||||||
unsigned int cpu)
|
unsigned int thread)
|
||||||
{
|
{
|
||||||
struct mvpp2_tx_queue *txq;
|
struct mvpp2_tx_queue *txq;
|
||||||
struct mvpp2_txq_pcpu *txq_pcpu;
|
struct mvpp2_txq_pcpu *txq_pcpu;
|
||||||
|
@ -2002,7 +2010,7 @@ static unsigned int mvpp2_tx_done(struct mvpp2_port *port, u32 cause,
|
||||||
if (!txq)
|
if (!txq)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
txq_pcpu = per_cpu_ptr(txq->pcpu, cpu);
|
txq_pcpu = per_cpu_ptr(txq->pcpu, thread);
|
||||||
|
|
||||||
if (txq_pcpu->count) {
|
if (txq_pcpu->count) {
|
||||||
mvpp2_txq_done(port, txq, txq_pcpu);
|
mvpp2_txq_done(port, txq, txq_pcpu);
|
||||||
|
@ -2019,7 +2027,7 @@ static unsigned int mvpp2_tx_done(struct mvpp2_port *port, u32 cause,
|
||||||
/* Allocate and initialize descriptors for aggr TXQ */
|
/* Allocate and initialize descriptors for aggr TXQ */
|
||||||
static int mvpp2_aggr_txq_init(struct platform_device *pdev,
|
static int mvpp2_aggr_txq_init(struct platform_device *pdev,
|
||||||
struct mvpp2_tx_queue *aggr_txq,
|
struct mvpp2_tx_queue *aggr_txq,
|
||||||
unsigned int cpu, struct mvpp2 *priv)
|
unsigned int thread, struct mvpp2 *priv)
|
||||||
{
|
{
|
||||||
u32 txq_dma;
|
u32 txq_dma;
|
||||||
|
|
||||||
|
@ -2034,7 +2042,7 @@ static int mvpp2_aggr_txq_init(struct platform_device *pdev,
|
||||||
|
|
||||||
/* Aggr TXQ no reset WA */
|
/* Aggr TXQ no reset WA */
|
||||||
aggr_txq->next_desc_to_proc = mvpp2_read(priv,
|
aggr_txq->next_desc_to_proc = mvpp2_read(priv,
|
||||||
MVPP2_AGGR_TXQ_INDEX_REG(cpu));
|
MVPP2_AGGR_TXQ_INDEX_REG(thread));
|
||||||
|
|
||||||
/* Set Tx descriptors queue starting address indirect
|
/* Set Tx descriptors queue starting address indirect
|
||||||
* access
|
* access
|
||||||
|
@ -2045,8 +2053,8 @@ static int mvpp2_aggr_txq_init(struct platform_device *pdev,
|
||||||
txq_dma = aggr_txq->descs_dma >>
|
txq_dma = aggr_txq->descs_dma >>
|
||||||
MVPP22_AGGR_TXQ_DESC_ADDR_OFFS;
|
MVPP22_AGGR_TXQ_DESC_ADDR_OFFS;
|
||||||
|
|
||||||
mvpp2_write(priv, MVPP2_AGGR_TXQ_DESC_ADDR_REG(cpu), txq_dma);
|
mvpp2_write(priv, MVPP2_AGGR_TXQ_DESC_ADDR_REG(thread), txq_dma);
|
||||||
mvpp2_write(priv, MVPP2_AGGR_TXQ_DESC_SIZE_REG(cpu),
|
mvpp2_write(priv, MVPP2_AGGR_TXQ_DESC_SIZE_REG(thread),
|
||||||
MVPP2_AGGR_TXQ_SIZE);
|
MVPP2_AGGR_TXQ_SIZE);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -2057,7 +2065,7 @@ static int mvpp2_rxq_init(struct mvpp2_port *port,
|
||||||
struct mvpp2_rx_queue *rxq)
|
struct mvpp2_rx_queue *rxq)
|
||||||
|
|
||||||
{
|
{
|
||||||
unsigned int cpu;
|
unsigned int thread;
|
||||||
u32 rxq_dma;
|
u32 rxq_dma;
|
||||||
|
|
||||||
rxq->size = port->rx_ring_size;
|
rxq->size = port->rx_ring_size;
|
||||||
|
@ -2075,15 +2083,15 @@ static int mvpp2_rxq_init(struct mvpp2_port *port,
|
||||||
mvpp2_write(port->priv, MVPP2_RXQ_STATUS_REG(rxq->id), 0);
|
mvpp2_write(port->priv, MVPP2_RXQ_STATUS_REG(rxq->id), 0);
|
||||||
|
|
||||||
/* Set Rx descriptors queue starting address - indirect access */
|
/* Set Rx descriptors queue starting address - indirect access */
|
||||||
cpu = get_cpu();
|
thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_NUM_REG, rxq->id);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_NUM_REG, rxq->id);
|
||||||
if (port->priv->hw_version == MVPP21)
|
if (port->priv->hw_version == MVPP21)
|
||||||
rxq_dma = rxq->descs_dma;
|
rxq_dma = rxq->descs_dma;
|
||||||
else
|
else
|
||||||
rxq_dma = rxq->descs_dma >> MVPP22_DESC_ADDR_OFFS;
|
rxq_dma = rxq->descs_dma >> MVPP22_DESC_ADDR_OFFS;
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_DESC_ADDR_REG, rxq_dma);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_DESC_ADDR_REG, rxq_dma);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_DESC_SIZE_REG, rxq->size);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_DESC_SIZE_REG, rxq->size);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_INDEX_REG, 0);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_INDEX_REG, 0);
|
||||||
put_cpu();
|
put_cpu();
|
||||||
|
|
||||||
/* Set Offset */
|
/* Set Offset */
|
||||||
|
@ -2128,7 +2136,7 @@ static void mvpp2_rxq_drop_pkts(struct mvpp2_port *port,
|
||||||
static void mvpp2_rxq_deinit(struct mvpp2_port *port,
|
static void mvpp2_rxq_deinit(struct mvpp2_port *port,
|
||||||
struct mvpp2_rx_queue *rxq)
|
struct mvpp2_rx_queue *rxq)
|
||||||
{
|
{
|
||||||
unsigned int cpu;
|
unsigned int thread;
|
||||||
|
|
||||||
mvpp2_rxq_drop_pkts(port, rxq);
|
mvpp2_rxq_drop_pkts(port, rxq);
|
||||||
|
|
||||||
|
@ -2147,10 +2155,10 @@ static void mvpp2_rxq_deinit(struct mvpp2_port *port,
|
||||||
* free descriptor number
|
* free descriptor number
|
||||||
*/
|
*/
|
||||||
mvpp2_write(port->priv, MVPP2_RXQ_STATUS_REG(rxq->id), 0);
|
mvpp2_write(port->priv, MVPP2_RXQ_STATUS_REG(rxq->id), 0);
|
||||||
cpu = get_cpu();
|
thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_NUM_REG, rxq->id);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_NUM_REG, rxq->id);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_DESC_ADDR_REG, 0);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_DESC_ADDR_REG, 0);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_RXQ_DESC_SIZE_REG, 0);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_RXQ_DESC_SIZE_REG, 0);
|
||||||
put_cpu();
|
put_cpu();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2159,7 +2167,7 @@ static int mvpp2_txq_init(struct mvpp2_port *port,
|
||||||
struct mvpp2_tx_queue *txq)
|
struct mvpp2_tx_queue *txq)
|
||||||
{
|
{
|
||||||
u32 val;
|
u32 val;
|
||||||
unsigned int cpu;
|
unsigned int cpu, thread;
|
||||||
int desc, desc_per_txq, tx_port_num;
|
int desc, desc_per_txq, tx_port_num;
|
||||||
struct mvpp2_txq_pcpu *txq_pcpu;
|
struct mvpp2_txq_pcpu *txq_pcpu;
|
||||||
|
|
||||||
|
@ -2175,18 +2183,18 @@ static int mvpp2_txq_init(struct mvpp2_port *port,
|
||||||
txq->last_desc = txq->size - 1;
|
txq->last_desc = txq->size - 1;
|
||||||
|
|
||||||
/* Set Tx descriptors queue starting address - indirect access */
|
/* Set Tx descriptors queue starting address - indirect access */
|
||||||
cpu = get_cpu();
|
thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_NUM_REG, txq->id);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_NUM_REG, txq->id);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_DESC_ADDR_REG,
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_DESC_ADDR_REG,
|
||||||
txq->descs_dma);
|
txq->descs_dma);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_DESC_SIZE_REG,
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_DESC_SIZE_REG,
|
||||||
txq->size & MVPP2_TXQ_DESC_SIZE_MASK);
|
txq->size & MVPP2_TXQ_DESC_SIZE_MASK);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_INDEX_REG, 0);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_INDEX_REG, 0);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_RSVD_CLR_REG,
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_RSVD_CLR_REG,
|
||||||
txq->id << MVPP2_TXQ_RSVD_CLR_OFFSET);
|
txq->id << MVPP2_TXQ_RSVD_CLR_OFFSET);
|
||||||
val = mvpp2_percpu_read(port->priv, cpu, MVPP2_TXQ_PENDING_REG);
|
val = mvpp2_percpu_read(port->priv, thread, MVPP2_TXQ_PENDING_REG);
|
||||||
val &= ~MVPP2_TXQ_PENDING_MASK;
|
val &= ~MVPP2_TXQ_PENDING_MASK;
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_PENDING_REG, val);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_PENDING_REG, val);
|
||||||
|
|
||||||
/* Calculate base address in prefetch buffer. We reserve 16 descriptors
|
/* Calculate base address in prefetch buffer. We reserve 16 descriptors
|
||||||
* for each existing TXQ.
|
* for each existing TXQ.
|
||||||
|
@ -2197,7 +2205,7 @@ static int mvpp2_txq_init(struct mvpp2_port *port,
|
||||||
desc = (port->id * MVPP2_MAX_TXQ * desc_per_txq) +
|
desc = (port->id * MVPP2_MAX_TXQ * desc_per_txq) +
|
||||||
(txq->log_id * desc_per_txq);
|
(txq->log_id * desc_per_txq);
|
||||||
|
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_PREF_BUF_REG,
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_PREF_BUF_REG,
|
||||||
MVPP2_PREF_BUF_PTR(desc) | MVPP2_PREF_BUF_SIZE_16 |
|
MVPP2_PREF_BUF_PTR(desc) | MVPP2_PREF_BUF_SIZE_16 |
|
||||||
MVPP2_PREF_BUF_THRESH(desc_per_txq / 2));
|
MVPP2_PREF_BUF_THRESH(desc_per_txq / 2));
|
||||||
put_cpu();
|
put_cpu();
|
||||||
|
@ -2251,7 +2259,7 @@ static void mvpp2_txq_deinit(struct mvpp2_port *port,
|
||||||
struct mvpp2_tx_queue *txq)
|
struct mvpp2_tx_queue *txq)
|
||||||
{
|
{
|
||||||
struct mvpp2_txq_pcpu *txq_pcpu;
|
struct mvpp2_txq_pcpu *txq_pcpu;
|
||||||
unsigned int cpu;
|
unsigned int cpu, thread;
|
||||||
|
|
||||||
for_each_present_cpu(cpu) {
|
for_each_present_cpu(cpu) {
|
||||||
txq_pcpu = per_cpu_ptr(txq->pcpu, cpu);
|
txq_pcpu = per_cpu_ptr(txq->pcpu, cpu);
|
||||||
|
@ -2280,10 +2288,10 @@ static void mvpp2_txq_deinit(struct mvpp2_port *port,
|
||||||
mvpp2_write(port->priv, MVPP2_TXQ_SCHED_TOKEN_CNTR_REG(txq->id), 0);
|
mvpp2_write(port->priv, MVPP2_TXQ_SCHED_TOKEN_CNTR_REG(txq->id), 0);
|
||||||
|
|
||||||
/* Set Tx descriptors queue starting address and size */
|
/* Set Tx descriptors queue starting address and size */
|
||||||
cpu = get_cpu();
|
thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_NUM_REG, txq->id);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_NUM_REG, txq->id);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_DESC_ADDR_REG, 0);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_DESC_ADDR_REG, 0);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_DESC_SIZE_REG, 0);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_DESC_SIZE_REG, 0);
|
||||||
put_cpu();
|
put_cpu();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2292,14 +2300,13 @@ static void mvpp2_txq_clean(struct mvpp2_port *port, struct mvpp2_tx_queue *txq)
|
||||||
{
|
{
|
||||||
struct mvpp2_txq_pcpu *txq_pcpu;
|
struct mvpp2_txq_pcpu *txq_pcpu;
|
||||||
int delay, pending;
|
int delay, pending;
|
||||||
unsigned int cpu;
|
unsigned int cpu, thread = mvpp2_cpu_to_thread(get_cpu());
|
||||||
u32 val;
|
u32 val;
|
||||||
|
|
||||||
cpu = get_cpu();
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_NUM_REG, txq->id);
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_NUM_REG, txq->id);
|
val = mvpp2_percpu_read(port->priv, thread, MVPP2_TXQ_PREF_BUF_REG);
|
||||||
val = mvpp2_percpu_read(port->priv, cpu, MVPP2_TXQ_PREF_BUF_REG);
|
|
||||||
val |= MVPP2_TXQ_DRAIN_EN_MASK;
|
val |= MVPP2_TXQ_DRAIN_EN_MASK;
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_PREF_BUF_REG, val);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_PREF_BUF_REG, val);
|
||||||
|
|
||||||
/* The napi queue has been stopped so wait for all packets
|
/* The napi queue has been stopped so wait for all packets
|
||||||
* to be transmitted.
|
* to be transmitted.
|
||||||
|
@ -2315,13 +2322,13 @@ static void mvpp2_txq_clean(struct mvpp2_port *port, struct mvpp2_tx_queue *txq)
|
||||||
mdelay(1);
|
mdelay(1);
|
||||||
delay++;
|
delay++;
|
||||||
|
|
||||||
pending = mvpp2_percpu_read(port->priv, cpu,
|
pending = mvpp2_percpu_read(port->priv, thread,
|
||||||
MVPP2_TXQ_PENDING_REG);
|
MVPP2_TXQ_PENDING_REG);
|
||||||
pending &= MVPP2_TXQ_PENDING_MASK;
|
pending &= MVPP2_TXQ_PENDING_MASK;
|
||||||
} while (pending);
|
} while (pending);
|
||||||
|
|
||||||
val &= ~MVPP2_TXQ_DRAIN_EN_MASK;
|
val &= ~MVPP2_TXQ_DRAIN_EN_MASK;
|
||||||
mvpp2_percpu_write(port->priv, cpu, MVPP2_TXQ_PREF_BUF_REG, val);
|
mvpp2_percpu_write(port->priv, thread, MVPP2_TXQ_PREF_BUF_REG, val);
|
||||||
put_cpu();
|
put_cpu();
|
||||||
|
|
||||||
for_each_present_cpu(cpu) {
|
for_each_present_cpu(cpu) {
|
||||||
|
@ -3030,7 +3037,7 @@ static int mvpp2_poll(struct napi_struct *napi, int budget)
|
||||||
int rx_done = 0;
|
int rx_done = 0;
|
||||||
struct mvpp2_port *port = netdev_priv(napi->dev);
|
struct mvpp2_port *port = netdev_priv(napi->dev);
|
||||||
struct mvpp2_queue_vector *qv;
|
struct mvpp2_queue_vector *qv;
|
||||||
unsigned int cpu = smp_processor_id();
|
unsigned int thread = mvpp2_cpu_to_thread(smp_processor_id());
|
||||||
|
|
||||||
qv = container_of(napi, struct mvpp2_queue_vector, napi);
|
qv = container_of(napi, struct mvpp2_queue_vector, napi);
|
||||||
|
|
||||||
|
@ -3053,7 +3060,7 @@ static int mvpp2_poll(struct napi_struct *napi, int budget)
|
||||||
|
|
||||||
/* Clear the cause register */
|
/* Clear the cause register */
|
||||||
mvpp2_write(port->priv, MVPP2_ISR_MISC_CAUSE_REG, 0);
|
mvpp2_write(port->priv, MVPP2_ISR_MISC_CAUSE_REG, 0);
|
||||||
mvpp2_percpu_write(port->priv, cpu,
|
mvpp2_percpu_write(port->priv, thread,
|
||||||
MVPP2_ISR_RX_TX_CAUSE_REG(port->id),
|
MVPP2_ISR_RX_TX_CAUSE_REG(port->id),
|
||||||
cause_rx_tx & ~MVPP2_CAUSE_MISC_SUM_MASK);
|
cause_rx_tx & ~MVPP2_CAUSE_MISC_SUM_MASK);
|
||||||
}
|
}
|
||||||
|
@ -3141,7 +3148,7 @@ static void mvpp2_start_dev(struct mvpp2_port *port)
|
||||||
for (i = 0; i < port->nqvecs; i++)
|
for (i = 0; i < port->nqvecs; i++)
|
||||||
napi_enable(&port->qvecs[i].napi);
|
napi_enable(&port->qvecs[i].napi);
|
||||||
|
|
||||||
/* Enable interrupts on all CPUs */
|
/* Enable interrupts on all threads */
|
||||||
mvpp2_interrupts_enable(port);
|
mvpp2_interrupts_enable(port);
|
||||||
|
|
||||||
if (port->priv->hw_version == MVPP22)
|
if (port->priv->hw_version == MVPP22)
|
||||||
|
@ -3171,7 +3178,7 @@ static void mvpp2_stop_dev(struct mvpp2_port *port)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Disable interrupts on all CPUs */
|
/* Disable interrupts on all threads */
|
||||||
mvpp2_interrupts_disable(port);
|
mvpp2_interrupts_disable(port);
|
||||||
|
|
||||||
for (i = 0; i < port->nqvecs; i++)
|
for (i = 0; i < port->nqvecs; i++)
|
||||||
|
|
Loading…
Reference in New Issue