Staging: et131x: clean up the avail fields in the rx registers
These have a wrap bit but again need little work to clean out. There are a couple of uglies left that want addressing in later clean up. Notably we should probably keep the local psr copy and wrap as two values. Signed-off-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
2e5e0b890d
commit
99fd99f618
@@ -393,40 +393,20 @@ typedef union _RXDMA_CSR_t {
|
|||||||
/*
|
/*
|
||||||
* structure for packet status ring available offset reg in rxdma address map
|
* structure for packet status ring available offset reg in rxdma address map
|
||||||
* located at address 0x202C
|
* located at address 0x202C
|
||||||
|
*
|
||||||
|
* 31-13: unused
|
||||||
|
* 12: psr avail wrap
|
||||||
|
* 11-0: psr avail
|
||||||
*/
|
*/
|
||||||
typedef union _RXDMA_PSR_AVAIL_OFFSET_t {
|
|
||||||
u32 value;
|
|
||||||
struct {
|
|
||||||
#ifdef _BIT_FIELDS_HTOL
|
|
||||||
u32 unused:19; /* bits 13-31 */
|
|
||||||
u32 psr_avail_wrap:1; /* bit 12 */
|
|
||||||
u32 psr_avail:12; /* bit 0-11 */
|
|
||||||
#else
|
|
||||||
u32 psr_avail:12; /* bit 0-11 */
|
|
||||||
u32 psr_avail_wrap:1; /* bit 12 */
|
|
||||||
u32 unused:19; /* bits 13-31 */
|
|
||||||
#endif
|
|
||||||
} bits;
|
|
||||||
} RXDMA_PSR_AVAIL_OFFSET_t, *PRXDMA_PSR_AVAIL_OFFSET_t;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* structure for packet status ring full offset reg in rxdma address map
|
* structure for packet status ring full offset reg in rxdma address map
|
||||||
* located at address 0x2030
|
* located at address 0x2030
|
||||||
|
*
|
||||||
|
* 31-13: unused
|
||||||
|
* 12: psr full wrap
|
||||||
|
* 11-0: psr full
|
||||||
*/
|
*/
|
||||||
typedef union _RXDMA_PSR_FULL_OFFSET_t {
|
|
||||||
u32 value;
|
|
||||||
struct {
|
|
||||||
#ifdef _BIT_FIELDS_HTOL
|
|
||||||
u32 unused:19; /* bits 13-31 */
|
|
||||||
u32 psr_full_wrap:1; /* bit 12 */
|
|
||||||
u32 psr_full:12; /* bit 0-11 */
|
|
||||||
#else
|
|
||||||
u32 psr_full:12; /* bit 0-11 */
|
|
||||||
u32 psr_full_wrap:1; /* bit 12 */
|
|
||||||
u32 unused:19; /* bits 13-31 */
|
|
||||||
#endif
|
|
||||||
} bits;
|
|
||||||
} RXDMA_PSR_FULL_OFFSET_t, *PRXDMA_PSR_FULL_OFFSET_t;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* structure for packet status ring access index reg in rxdma address map
|
* structure for packet status ring access index reg in rxdma address map
|
||||||
@@ -556,8 +536,8 @@ typedef struct _RXDMA_t { /* Location: */
|
|||||||
u32 psr_base_lo; /* 0x2020 */
|
u32 psr_base_lo; /* 0x2020 */
|
||||||
u32 psr_base_hi; /* 0x2024 */
|
u32 psr_base_hi; /* 0x2024 */
|
||||||
u32 psr_num_des; /* 0x2028 */
|
u32 psr_num_des; /* 0x2028 */
|
||||||
RXDMA_PSR_AVAIL_OFFSET_t psr_avail_offset; /* 0x202C */
|
u32 psr_avail_offset; /* 0x202C */
|
||||||
RXDMA_PSR_FULL_OFFSET_t psr_full_offset; /* 0x2030 */
|
u32 psr_full_offset; /* 0x2030 */
|
||||||
u32 psr_access_index; /* 0x2034 */
|
u32 psr_access_index; /* 0x2034 */
|
||||||
u32 psr_min_des; /* 0x2038 */
|
u32 psr_min_des; /* 0x2038 */
|
||||||
u32 fbr0_base_lo; /* 0x203C */
|
u32 fbr0_base_lo; /* 0x203C */
|
||||||
|
@@ -624,7 +624,7 @@ void ConfigRxDmaRegs(struct et131x_adapter *etdev)
|
|||||||
&rx_dma->psr_base_hi);
|
&rx_dma->psr_base_hi);
|
||||||
writel((u32) rx_local->pPSRingPa, &rx_dma->psr_base_lo);
|
writel((u32) rx_local->pPSRingPa, &rx_dma->psr_base_lo);
|
||||||
writel(rx_local->PsrNumEntries - 1, &rx_dma->psr_num_des);
|
writel(rx_local->PsrNumEntries - 1, &rx_dma->psr_num_des);
|
||||||
writel(0, &rx_dma->psr_full_offset.value);
|
writel(0, &rx_dma->psr_full_offset);
|
||||||
|
|
||||||
psr_num_des = readl(&rx_dma->psr_num_des) & 0xFFF;
|
psr_num_des = readl(&rx_dma->psr_num_des) & 0xFFF;
|
||||||
writel((psr_num_des * LO_MARK_PERCENT_FOR_PSR) / 100,
|
writel((psr_num_des * LO_MARK_PERCENT_FOR_PSR) / 100,
|
||||||
@@ -633,8 +633,7 @@ void ConfigRxDmaRegs(struct et131x_adapter *etdev)
|
|||||||
spin_lock_irqsave(&etdev->RcvLock, flags);
|
spin_lock_irqsave(&etdev->RcvLock, flags);
|
||||||
|
|
||||||
/* These local variables track the PSR in the adapter structure */
|
/* These local variables track the PSR in the adapter structure */
|
||||||
rx_local->local_psr_full.bits.psr_full = 0;
|
rx_local->local_psr_full = 0;
|
||||||
rx_local->local_psr_full.bits.psr_full_wrap = 0;
|
|
||||||
|
|
||||||
/* Now's the best time to initialize FBR1 contents */
|
/* Now's the best time to initialize FBR1 contents */
|
||||||
fbr_entry = (PFBR_DESC_t) rx_local->pFbr1RingVa;
|
fbr_entry = (PFBR_DESC_t) rx_local->pFbr1RingVa;
|
||||||
@@ -808,17 +807,18 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
|
|||||||
*/
|
*/
|
||||||
status = (PRX_STATUS_BLOCK_t) rx_local->pRxStatusVa;
|
status = (PRX_STATUS_BLOCK_t) rx_local->pRxStatusVa;
|
||||||
|
|
||||||
|
/* FIXME: tidy later when conversions complete */
|
||||||
if (status->Word1.bits.PSRoffset ==
|
if (status->Word1.bits.PSRoffset ==
|
||||||
rx_local->local_psr_full.bits.psr_full &&
|
(rx_local->local_psr_full & 0xFFF) &&
|
||||||
status->Word1.bits.PSRwrap ==
|
status->Word1.bits.PSRwrap ==
|
||||||
rx_local->local_psr_full.bits.psr_full_wrap) {
|
((rx_local->local_psr_full >> 12) & 1)) {
|
||||||
/* Looks like this ring is not updated yet */
|
/* Looks like this ring is not updated yet */
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* The packet status ring indicates that data is available. */
|
/* The packet status ring indicates that data is available. */
|
||||||
psr = (PPKT_STAT_DESC_t) (rx_local->pPSRingVa) +
|
psr = (PPKT_STAT_DESC_t) (rx_local->pPSRingVa) +
|
||||||
rx_local->local_psr_full.bits.psr_full;
|
(rx_local->local_psr_full & 0xFFF);
|
||||||
|
|
||||||
/* Grab any information that is required once the PSR is
|
/* Grab any information that is required once the PSR is
|
||||||
* advanced, since we can no longer rely on the memory being
|
* advanced, since we can no longer rely on the memory being
|
||||||
@@ -830,14 +830,16 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
|
|||||||
Word0 = psr->word0;
|
Word0 = psr->word0;
|
||||||
|
|
||||||
/* Indicate that we have used this PSR entry. */
|
/* Indicate that we have used this PSR entry. */
|
||||||
if (++rx_local->local_psr_full.bits.psr_full >
|
/* FIXME wrap 12 */
|
||||||
rx_local->PsrNumEntries - 1) {
|
rx_local->local_psr_full = (rx_local->local_psr_full + 1) & 0xFFF;
|
||||||
rx_local->local_psr_full.bits.psr_full = 0;
|
if (rx_local->local_psr_full > rx_local->PsrNumEntries - 1) {
|
||||||
rx_local->local_psr_full.bits.psr_full_wrap ^= 1;
|
/* Clear psr full and toggle the wrap bit */
|
||||||
|
rx_local->local_psr_full &= 0xFFF;
|
||||||
|
rx_local->local_psr_full ^= 0x1000;
|
||||||
}
|
}
|
||||||
|
|
||||||
writel(rx_local->local_psr_full.value,
|
writel(rx_local->local_psr_full,
|
||||||
&etdev->regs->rxdma.psr_full_offset.value);
|
&etdev->regs->rxdma.psr_full_offset);
|
||||||
|
|
||||||
#ifndef USE_FBR0
|
#ifndef USE_FBR0
|
||||||
if (rindex != 1) {
|
if (rindex != 1) {
|
||||||
@@ -860,7 +862,7 @@ PMP_RFD nic_rx_pkts(struct et131x_adapter *etdev)
|
|||||||
dev_err(&etdev->pdev->dev,
|
dev_err(&etdev->pdev->dev,
|
||||||
"NICRxPkts PSR Entry %d indicates "
|
"NICRxPkts PSR Entry %d indicates "
|
||||||
"length of %d and/or bad bi(%d)\n",
|
"length of %d and/or bad bi(%d)\n",
|
||||||
rx_local->local_psr_full.bits.psr_full,
|
rx_local->local_psr_full & 0xFFF,
|
||||||
len, bindex);
|
len, bindex);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@@ -300,7 +300,7 @@ typedef struct _rx_ring_t {
|
|||||||
|
|
||||||
void *pPSRingVa;
|
void *pPSRingVa;
|
||||||
dma_addr_t pPSRingPa;
|
dma_addr_t pPSRingPa;
|
||||||
RXDMA_PSR_FULL_OFFSET_t local_psr_full;
|
u32 local_psr_full;
|
||||||
u32 PsrNumEntries;
|
u32 PsrNumEntries;
|
||||||
|
|
||||||
void *pRxStatusVa;
|
void *pRxStatusVa;
|
||||||
|
Reference in New Issue
Block a user