Commit 16e15848 authored by David Kilroy's avatar David Kilroy Committed by John W. Linville

orinoco: pass orinoco_set_tkip_key the sequence lengths

When we store the keys for cfg80211, the sequence lengths will also be
stored. So avoid assuming the sequence lengths at this level.
Signed-off-by: default avatarDavid Kilroy <kilroyd@googlemail.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 5c9f41e2
...@@ -905,11 +905,12 @@ int __orinoco_hw_setup_enc(struct orinoco_private *priv) ...@@ -905,11 +905,12 @@ int __orinoco_hw_setup_enc(struct orinoco_private *priv)
} }
/* key must be 32 bytes, including the tx and rx MIC keys. /* key must be 32 bytes, including the tx and rx MIC keys.
* rsc must be 8 bytes * rsc must be NULL or up to 8 bytes
* tsc must be 8 bytes or NULL * tsc must be NULL or up to 8 bytes
*/ */
int __orinoco_hw_set_tkip_key(struct orinoco_private *priv, int key_idx, int __orinoco_hw_set_tkip_key(struct orinoco_private *priv, int key_idx,
int set_tx, u8 *key, u8 *rsc, u8 *tsc) int set_tx, u8 *key, u8 *rsc, size_t rsc_len,
u8 *tsc, size_t tsc_len)
{ {
struct { struct {
__le16 idx; __le16 idx;
...@@ -934,17 +935,22 @@ int __orinoco_hw_set_tkip_key(struct orinoco_private *priv, int key_idx, ...@@ -934,17 +935,22 @@ int __orinoco_hw_set_tkip_key(struct orinoco_private *priv, int key_idx,
memcpy(buf.key, key, memcpy(buf.key, key,
sizeof(buf.key) + sizeof(buf.tx_mic) + sizeof(buf.rx_mic)); sizeof(buf.key) + sizeof(buf.tx_mic) + sizeof(buf.rx_mic));
if (rsc == NULL) if (rsc_len > sizeof(buf.rsc))
memset(buf.rsc, 0, sizeof(buf.rsc)); rsc_len = sizeof(buf.rsc);
else
memcpy(buf.rsc, rsc, sizeof(buf.rsc)); if (tsc_len > sizeof(buf.tsc))
tsc_len = sizeof(buf.tsc);
if (tsc == NULL) { memset(buf.rsc, 0, sizeof(buf.rsc));
memset(buf.tsc, 0, sizeof(buf.tsc)); memset(buf.tsc, 0, sizeof(buf.tsc));
if (rsc != NULL)
memcpy(buf.rsc, rsc, rsc_len);
if (tsc != NULL)
memcpy(buf.tsc, tsc, tsc_len);
else
buf.tsc[4] = 0x10; buf.tsc[4] = 0x10;
} else {
memcpy(buf.tsc, tsc, sizeof(buf.tsc));
}
/* Wait upto 100ms for tx queue to empty */ /* Wait upto 100ms for tx queue to empty */
for (k = 100; k > 0; k--) { for (k = 100; k > 0; k--) {
......
...@@ -38,7 +38,8 @@ int __orinoco_hw_set_wap(struct orinoco_private *priv); ...@@ -38,7 +38,8 @@ int __orinoco_hw_set_wap(struct orinoco_private *priv);
int __orinoco_hw_setup_wepkeys(struct orinoco_private *priv); int __orinoco_hw_setup_wepkeys(struct orinoco_private *priv);
int __orinoco_hw_setup_enc(struct orinoco_private *priv); int __orinoco_hw_setup_enc(struct orinoco_private *priv);
int __orinoco_hw_set_tkip_key(struct orinoco_private *priv, int key_idx, int __orinoco_hw_set_tkip_key(struct orinoco_private *priv, int key_idx,
int set_tx, u8 *key, u8 *rsc, u8 *tsc); int set_tx, u8 *key, u8 *rsc, size_t rsc_len,
u8 *tsc, size_t tsc_len);
int orinoco_clear_tkip_key(struct orinoco_private *priv, int key_idx); int orinoco_clear_tkip_key(struct orinoco_private *priv, int key_idx);
int __orinoco_hw_set_multicast_list(struct orinoco_private *priv, int __orinoco_hw_set_multicast_list(struct orinoco_private *priv,
struct dev_addr_list *mc_list, struct dev_addr_list *mc_list,
......
...@@ -863,7 +863,7 @@ static int orinoco_ioctl_set_encodeext(struct net_device *dev, ...@@ -863,7 +863,7 @@ static int orinoco_ioctl_set_encodeext(struct net_device *dev,
err = __orinoco_hw_set_tkip_key(priv, idx, err = __orinoco_hw_set_tkip_key(priv, idx,
ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY, ext->ext_flags & IW_ENCODE_EXT_SET_TX_KEY,
(u8 *) &priv->tkip_key[idx], (u8 *) &priv->tkip_key[idx],
tkip_iv, NULL); tkip_iv, ORINOCO_SEQ_LEN, NULL, 0);
if (err) if (err)
printk(KERN_ERR "%s: Error %d setting TKIP key" printk(KERN_ERR "%s: Error %d setting TKIP key"
"\n", dev->name, err); "\n", dev->name, err);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment