mirror of
https://github.com/torvalds/linux.git
synced 2024-11-25 13:41:51 +00:00
vmxnet3: use DMA memory barriers where required
The gen bits must be read first from (resp. written last to) DMA memory. The proper way to enforce this on Linux is to call dma_rmb() (resp. dma_wmb()). Signed-off-by: Regis Duchesne <hpreg@vmware.com> Acked-by: Ronak Doshi <doshir@vmware.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
61aeecea40
commit
f3002c1374
@ -369,6 +369,11 @@ vmxnet3_tq_tx_complete(struct vmxnet3_tx_queue *tq,
|
||||
|
||||
gdesc = tq->comp_ring.base + tq->comp_ring.next2proc;
|
||||
while (VMXNET3_TCD_GET_GEN(&gdesc->tcd) == tq->comp_ring.gen) {
|
||||
/* Prevent any &gdesc->tcd field from being (speculatively)
|
||||
* read before (&gdesc->tcd)->gen is read.
|
||||
*/
|
||||
dma_rmb();
|
||||
|
||||
completed += vmxnet3_unmap_pkt(VMXNET3_TCD_GET_TXIDX(
|
||||
&gdesc->tcd), tq, adapter->pdev,
|
||||
adapter);
|
||||
@ -1103,6 +1108,11 @@ vmxnet3_tq_xmit(struct sk_buff *skb, struct vmxnet3_tx_queue *tq,
|
||||
gdesc->txd.tci = skb_vlan_tag_get(skb);
|
||||
}
|
||||
|
||||
/* Ensure that the write to (&gdesc->txd)->gen will be observed after
|
||||
* all other writes to &gdesc->txd.
|
||||
*/
|
||||
dma_wmb();
|
||||
|
||||
/* finally flips the GEN bit of the SOP desc. */
|
||||
gdesc->dword[2] = cpu_to_le32(le32_to_cpu(gdesc->dword[2]) ^
|
||||
VMXNET3_TXD_GEN);
|
||||
@ -1298,6 +1308,12 @@ vmxnet3_rq_rx_complete(struct vmxnet3_rx_queue *rq,
|
||||
*/
|
||||
break;
|
||||
}
|
||||
|
||||
/* Prevent any rcd field from being (speculatively) read before
|
||||
* rcd->gen is read.
|
||||
*/
|
||||
dma_rmb();
|
||||
|
||||
BUG_ON(rcd->rqID != rq->qid && rcd->rqID != rq->qid2 &&
|
||||
rcd->rqID != rq->dataRingQid);
|
||||
idx = rcd->rxdIdx;
|
||||
@ -1528,6 +1544,12 @@ rcd_done:
|
||||
ring->next2comp = idx;
|
||||
num_to_alloc = vmxnet3_cmd_ring_desc_avail(ring);
|
||||
ring = rq->rx_ring + ring_idx;
|
||||
|
||||
/* Ensure that the writes to rxd->gen bits will be observed
|
||||
* after all other writes to rxd objects.
|
||||
*/
|
||||
dma_wmb();
|
||||
|
||||
while (num_to_alloc) {
|
||||
vmxnet3_getRxDesc(rxd, &ring->base[ring->next2fill].rxd,
|
||||
&rxCmdDesc);
|
||||
|
@ -69,12 +69,12 @@
|
||||
/*
|
||||
* Version numbers
|
||||
*/
|
||||
#define VMXNET3_DRIVER_VERSION_STRING "1.4.15.0-k"
|
||||
#define VMXNET3_DRIVER_VERSION_STRING "1.4.16.0-k"
|
||||
|
||||
/* Each byte of this 32-bit integer encodes a version number in
|
||||
* VMXNET3_DRIVER_VERSION_STRING.
|
||||
*/
|
||||
#define VMXNET3_DRIVER_VERSION_NUM 0x01040f00
|
||||
#define VMXNET3_DRIVER_VERSION_NUM 0x01041000
|
||||
|
||||
#if defined(CONFIG_PCI_MSI)
|
||||
/* RSS only makes sense if MSI-X is supported. */
|
||||
|
Loading…
Reference in New Issue
Block a user