summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAl Viro2007-12-27 07:57:47 +0100
committerDavid S. Miller2008-01-29 00:08:57 +0100
commit4958730e2b4e10d29aa80574a848308ed95f508f (patch)
tree8626307bc0df8dcd308eb06e35737ec36106150f
parentipw2200 fix: ->rt_chbitmask is le16 (diff)
downloadkernel-qcow2-linux-4958730e2b4e10d29aa80574a848308ed95f508f.tar.gz
kernel-qcow2-linux-4958730e2b4e10d29aa80574a848308ed95f508f.tar.xz
kernel-qcow2-linux-4958730e2b4e10d29aa80574a848308ed95f508f.zip
ipw2200: ipw_tx_skb() endianness bug
We'd just set tfd->u.data.chunk_len[i] to cpu_to_le16(remaining_bytes); passing it to pci_map_single() is a bad idea - it expects host-endian. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/ipw2200.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/wireless/ipw2200.c b/drivers/net/wireless/ipw2200.c
index c0591bda0178..7c45ba53f379 100644
--- a/drivers/net/wireless/ipw2200.c
+++ b/drivers/net/wireless/ipw2200.c
@@ -10341,7 +10341,7 @@ static int ipw_tx_skb(struct ipw_priv *priv, struct ieee80211_txb *txb,
tfd->u.data.chunk_ptr[i] =
cpu_to_le32(pci_map_single
(priv->pci_dev, skb->data,
- tfd->u.data.chunk_len[i],
+ remaining_bytes,
PCI_DMA_TODEVICE));
tfd->u.data.num_chunks =