summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHenrik Brix Andersen <brix@gentoo.org>2005-09-06 14:58:35 +0000
committerHenrik Brix Andersen <brix@gentoo.org>2005-09-06 14:58:35 +0000
commitc918a84b04c6389072ce89da2a7723ecae070f0d (patch)
treec553b15d3b2cc586cf51c5dc973602fb94013e47 /net-wireless/ipw2200
parentVersion bump. (diff)
downloadgentoo-2-c918a84b04c6389072ce89da2a7723ecae070f0d.tar.gz
gentoo-2-c918a84b04c6389072ce89da2a7723ecae070f0d.tar.bz2
gentoo-2-c918a84b04c6389072ce89da2a7723ecae070f0d.zip
Apply bugfixes from upstream, bail out if no ieee80211 kernel module is found.
(Portage version: 2.0.51.22-r2)
Diffstat (limited to 'net-wireless/ipw2200')
-rw-r--r--net-wireless/ipw2200/ChangeLog16
-rw-r--r--net-wireless/ipw2200/Manifest16
-rw-r--r--net-wireless/ipw2200/files/digest-ipw2200-1.0.6-r31
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-a_txpow.patch183
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-broadcast.patch2
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-channel_change_fw_err.patch89
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-dup-without-retry.patch32
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-ibss-wep.patch41
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-init_scan.patch30
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-irq_override.patch37
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-monitor_wep_fix.patch17
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-open_frag.patch23
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-pci_link-fix.patch37
-rw-r--r--net-wireless/ipw2200/files/ipw2200-1.0.6-reset-mode-fix.patch21
-rw-r--r--net-wireless/ipw2200/ipw2200-1.0.6-r3.ebuild109
15 files changed, 650 insertions, 4 deletions
diff --git a/net-wireless/ipw2200/ChangeLog b/net-wireless/ipw2200/ChangeLog
index a4d0d5ec4787..3768afab02fd 100644
--- a/net-wireless/ipw2200/ChangeLog
+++ b/net-wireless/ipw2200/ChangeLog
@@ -1,6 +1,20 @@
# ChangeLog for net-wireless/ipw2200
# Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/net-wireless/ipw2200/ChangeLog,v 1.43 2005/09/02 17:34:44 brix Exp $
+# $Header: /var/cvsroot/gentoo-x86/net-wireless/ipw2200/ChangeLog,v 1.44 2005/09/06 14:58:35 brix Exp $
+
+*ipw2200-1.0.6-r3 (06 Sep 2005)
+
+ 06 Sep 2005; Henrik Brix Andersen <brix@gentoo.org>
+ +files/ipw2200-1.0.6-a_txpow.patch, files/ipw2200-1.0.6-broadcast.patch,
+ +files/ipw2200-1.0.6-channel_change_fw_err.patch,
+ +files/ipw2200-1.0.6-dup-without-retry.patch,
+ +files/ipw2200-1.0.6-ibss-wep.patch, +files/ipw2200-1.0.6-init_scan.patch,
+ +files/ipw2200-1.0.6-irq_override.patch,
+ +files/ipw2200-1.0.6-monitor_wep_fix.patch,
+ +files/ipw2200-1.0.6-open_frag.patch,
+ +files/ipw2200-1.0.6-pci_link-fix.patch,
+ +files/ipw2200-1.0.6-reset-mode-fix.patch, +ipw2200-1.0.6-r3.ebuild:
+ Apply bugfixes from upstream, bail out if no ieee80211 kernel module is found.
*ipw2200-1.0.6-r2 (02 Sep 2005)
diff --git a/net-wireless/ipw2200/Manifest b/net-wireless/ipw2200/Manifest
index 77c17b3c1058..cfce897516cc 100644
--- a/net-wireless/ipw2200/Manifest
+++ b/net-wireless/ipw2200/Manifest
@@ -1,3 +1,4 @@
+MD5 bbf188972a3aa6a3b0dfcd2e4d1a0b19 ipw2200-1.0.6-r3.ebuild 3106
MD5 03551f14b4409796623fb865ed2abf97 ipw2200-1.0.4.ebuild 2449
MD5 7afca8db2613b9fc32d5f7005b4db15d ipw2200-1.0.6.ebuild 2158
MD5 a1d82c4728a3f608b762fe63c4910f42 ipw2200-1.0.1.ebuild 2488
@@ -5,18 +6,29 @@ MD5 4ce2b88ec5f872d1621a5af9cf1d0da1 ipw2200-1.0.6-r2.ebuild 2304
MD5 b2138b76ba85eeea301d8fa9f72470df ipw2200-1.0.3.ebuild 2488
MD5 8a1b21691e17dc6de38c7238cd4e4522 ipw2200-1.0.5.ebuild 2145
MD5 7453a3247e41a7bf8c6e939cf55c45f0 ipw2200-1.0.6-r1.ebuild 2260
-MD5 37214287af0ae90261ab9bc20ef8d2ca ChangeLog 7383
+MD5 a01be9dd5aabeebe1a93a01e1eda44d9 ChangeLog 8047
MD5 b280eebc74d70d85e664debf1adce2c3 metadata.xml 255
+MD5 57bc9c6eb5f4015c48658642ca771b54 files/ipw2200-1.0.6-ibss-wep.patch 1249
MD5 2dc4d1d726fc4dce22dee416d6028353 files/ipw2200-1.0.4-is_multicast_ether_addr.patch 647
MD5 abdb4f9be556bd09fe711f6a7cd42ee2 files/ipw2200-1.0.6-suspend2.patch 520
+MD5 b0d2d1d8adbf103c40cfff2a0b5a9bd9 files/ipw2200-1.0.6-init_scan.patch 996
MD5 2ba8f54679172b49a799779c1a02127a files/ipw2200-1.0.6-hwcrypt-wpa-fix4.patch 5840
MD5 9e25eeda7c745bca8c5cf72537dd31f5 files/ipw2200-1.0.1-suspend2.patch 448
MD5 af6756863c64cdfc93cd53556f8b397b files/ipw2200-1.0.1-is_multicast_ether_addr.patch 631
+MD5 64c7772c52dad7ac8aceb580288d2eb8 files/ipw2200-1.0.6-dup-without-retry.patch 1124
+MD5 8e45f8fd6f60e9d8b6b343ae2359f456 files/ipw2200-1.0.6-reset-mode-fix.patch 621
+MD5 a09593c7d4c70507961ceb3e9788f282 files/ipw2200-1.0.6-irq_override.patch 1219
MD5 7a64b674dbd99046028827c6417409e1 files/ipw2200-1.0.3-is_multicast_ether_addr.patch 715
-MD5 2833c1b240e20a5b7ecb45f5435cf24f files/ipw2200-1.0.6-broadcast.patch 992
+MD5 b67059711d35db39da22e42fd1a5a7d4 files/ipw2200-1.0.6-open_frag.patch 756
+MD5 2a2177cb34ff1d51ca335f8786a41e92 files/ipw2200-1.0.6-channel_change_fw_err.patch 2830
+MD5 d506e1d6b23fdd00ec0d812db1f3f05a files/ipw2200-1.0.6-broadcast.patch 992
+MD5 3ada2bd4ff1452839bc558b3e5e026f5 files/ipw2200-1.0.6-a_txpow.patch 5085
MD5 ba6c39e9a44ef971292c5f8e6a7c6897 files/ipw2200-1.0.3-suspend2.patch 522
+MD5 d0074a6c01392cb21c47b8f370716a0f files/ipw2200-1.0.6-monitor_wep_fix.patch 714
MD5 aab93fcc37b1a1282d7a02e9b64430a3 files/digest-ipw2200-1.0.6-r1 62
MD5 aab93fcc37b1a1282d7a02e9b64430a3 files/digest-ipw2200-1.0.6-r2 62
+MD5 aab93fcc37b1a1282d7a02e9b64430a3 files/digest-ipw2200-1.0.6-r3 62
+MD5 f20e5c312fa263336e4921aa6e42b56e files/ipw2200-1.0.6-pci_link-fix.patch 1298
MD5 d2a1aca212498ad4de9f4a79ac12026b files/digest-ipw2200-1.0.1 62
MD5 1953868cbb8ae6ee8eee55c5848417ab files/digest-ipw2200-1.0.3 62
MD5 bcf142294729f1a55d7b3fd29c1a8239 files/digest-ipw2200-1.0.4 62
diff --git a/net-wireless/ipw2200/files/digest-ipw2200-1.0.6-r3 b/net-wireless/ipw2200/files/digest-ipw2200-1.0.6-r3
new file mode 100644
index 000000000000..53844e808285
--- /dev/null
+++ b/net-wireless/ipw2200/files/digest-ipw2200-1.0.6-r3
@@ -0,0 +1 @@
+MD5 d49f301ce8cffbd1cfbdb51061df3ac8 ipw2200-1.0.6.tgz 112932
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-a_txpow.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-a_txpow.patch
new file mode 100644
index 000000000000..21d100949b59
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-a_txpow.patch
@@ -0,0 +1,183 @@
+Fix firmware error when setting tx_power.
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+--
+diff -urp ipw2200-1.0.6/ipw2200.c ipw2200-1.0.6-a_txpow/ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c 2005-07-14 03:00:28.000000000 +0800
++++ ipw2200-1.0.6-a_txpow/ipw2200.c 2005-08-11 14:35:00.000000000 +0800
+@@ -2179,6 +2179,50 @@ static int ipw_send_tx_power(struct ipw_
+ return 0;
+ }
+
++static int ipw_set_tx_power(struct ipw_priv *priv)
++{
++ const struct ieee80211_geo *geo = ieee80211_get_geo(priv->ieee);
++ struct ipw_tx_power tx_power;
++ s8 max_power;
++ int i;
++
++ memset(&tx_power, 0, sizeof(tx_power));
++
++ /* configure device for 'G' band */
++ tx_power.ieee_mode = IPW_G_MODE;
++ tx_power.num_channels = geo->bg_channels;
++ for (i = 0; i < geo->bg_channels; i++) {
++ max_power = geo->bg[i].max_power;
++ tx_power.channels_tx_power[i].channel_number =
++ geo->bg[i].channel;
++ tx_power.channels_tx_power[i].tx_power = max_power ?
++ min(max_power, priv->tx_power) : priv->tx_power;
++ }
++ if (ipw_send_tx_power(priv, &tx_power))
++ return -EIO;
++
++ /* configure device to also handle 'B' band */
++ tx_power.ieee_mode = IPW_B_MODE;
++ if (ipw_send_tx_power(priv, &tx_power))
++ return -EIO;
++
++ /* configure device to also handle 'A' band */
++ if (priv->ieee->abg_true) {
++ tx_power.ieee_mode = IPW_A_MODE;
++ tx_power.num_channels = geo->a_channels;
++ for (i = 0; i < tx_power.num_channels; i++) {
++ max_power = geo->a[i].max_power;
++ tx_power.channels_tx_power[i].channel_number =
++ geo->a[i].channel;
++ tx_power.channels_tx_power[i].tx_power = max_power ?
++ min(max_power, priv->tx_power) : priv->tx_power;
++ }
++ if (ipw_send_tx_power(priv, &tx_power))
++ return -EIO;
++ }
++ return 0;
++}
++
+ static int ipw_send_rts_threshold(struct ipw_priv *priv, u16 rts)
+ {
+ struct ipw_rts_threshold rts_threshold = {
+@@ -8744,83 +8788,38 @@ static int ipw_wx_get_rts(struct net_dev
+ return 0;
+ }
+
+-
+ static int ipw_wx_set_txpow(struct net_device *dev,
+ struct iw_request_info *info,
+ union iwreq_data *wrqu, char *extra)
+ {
+ struct ipw_priv *priv = ieee80211_priv(dev);
+- const struct ieee80211_geo *geo = ieee80211_get_geo(priv->ieee);
+- struct ipw_tx_power tx_power;
+- int i;
++ int err = 0;
+
+ down(&priv->sem);
+ if (ipw_radio_kill_sw(priv, wrqu->power.disabled)) {
+- up(&priv->sem);
+- return -EINPROGRESS;
++ err = -EINPROGRESS;
++ goto out;
+ }
+
+ if (!wrqu->power.fixed)
+ wrqu->power.value = IPW_TX_POWER_DEFAULT;
+
+ if (wrqu->power.flags != IW_TXPOW_DBM) {
+- up(&priv->sem);
+- return -EINVAL;
++ err = -EINVAL;
++ goto out;
+ }
+
+ if ((wrqu->power.value > IPW_TX_POWER_MAX) ||
+ (wrqu->power.value < IPW_TX_POWER_MIN)) {
+- up(&priv->sem);
+- return -EINVAL;
++ err = -EINVAL;
++ goto out;
+ }
+
+ priv->tx_power = wrqu->power.value;
+-
+- memset(&tx_power, 0, sizeof(tx_power));
+-
+- /* configure device for 'G' band */
+- tx_power.ieee_mode = IPW_G_MODE;
+- tx_power.num_channels = geo->bg_channels;
+- for (i = 0; i < geo->bg_channels; i++) {
+- int max_power = geo->bg[i].max_power;
+-
+- tx_power.channels_tx_power[i].channel_number = i + 1;
+- if (max_power != 0 && priv->tx_power > max_power)
+- tx_power.channels_tx_power[i].tx_power = max_power;
+- else
+- tx_power.channels_tx_power[i].tx_power = priv->tx_power;
+- }
+- if (ipw_send_tx_power(priv, &tx_power))
+- goto error;
+-
+- /* configure device to also handle 'B' band */
+- tx_power.ieee_mode = IPW_B_MODE;
+- if (ipw_send_tx_power(priv, &tx_power))
+- goto error;
+-
+- /* configure device to also handle 'A' band */
+- if (priv->ieee->abg_true) {
+- tx_power.ieee_mode = IPW_A_MODE;
+- tx_power.num_channels = geo->a_channels;
+- for (i = 0; i < geo->a_channels; i++) {
+- int max_power = geo->a[i].max_power;
+-
+- tx_power.channels_tx_power[i].channel_number = i + 1;
+- if (max_power != 0 && priv->tx_power > max_power)
+- tx_power.channels_tx_power[i].tx_power = max_power;
+- else
+- tx_power.channels_tx_power[i].tx_power = priv->tx_power;
+- }
+- if (ipw_send_tx_power(priv, &tx_power))
+- goto error;
+- }
+-
+- up(&priv->sem);
+- return 0;
+-
+- error:
++ err = ipw_set_tx_power(priv);
++out:
+ up(&priv->sem);
+- return -EIO;
++ return err;
+ }
+
+
+@@ -10302,29 +10301,10 @@ static int init_supported_rates(struct i
+
+ static int ipw_config(struct ipw_priv *priv)
+ {
+- int i;
+- struct ipw_tx_power tx_power;
+-
+- memset(&priv->sys_config, 0, sizeof(priv->sys_config));
+- memset(&tx_power, 0, sizeof(tx_power));
+-
+ /* This is only called from ipw_up, which resets/reloads the firmware
+ so, we don't need to first disable the card before we configure
+ it */
+-
+- /* configure device for 'G' band */
+- tx_power.ieee_mode = IPW_G_MODE;
+- tx_power.num_channels = 11;
+- for (i = 0; i < 11; i++) {
+- tx_power.channels_tx_power[i].channel_number = i + 1;
+- tx_power.channels_tx_power[i].tx_power = priv->tx_power;
+- }
+- if (ipw_send_tx_power(priv, &tx_power))
+- goto error;
+-
+- /* configure device to also handle 'B' band */
+- tx_power.ieee_mode = IPW_B_MODE;
+- if (ipw_send_tx_power(priv, &tx_power))
++ if (ipw_set_tx_power(priv))
+ goto error;
+
+ /* initialize adapter address */
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-broadcast.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-broadcast.patch
index 28061f84af28..0c3f8e386bd1 100644
--- a/net-wireless/ipw2200/files/ipw2200-1.0.6-broadcast.patch
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-broadcast.patch
@@ -1,6 +1,6 @@
diff -urp ipw2200-1.0.6/ipw2200.c ipw2200-1.0.6-broadcast/ipw2200.c
--- ipw2200-1.0.6/ipw2200.c 2005-07-13 21:00:28.000000000 +0200
-+++ ipw2200-1.0.6-broadcast/ipw2200.c 2005-09-02 19:15:03.000000000 +0200
++++ ipw2200-1.0.6-broadcast/ipw2200.c 2005-09-02 19:39:01.000000000 +0200
@@ -7669,7 +7669,8 @@ static inline int is_network_packet(stru
return 0;
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-channel_change_fw_err.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-channel_change_fw_err.patch
new file mode 100644
index 000000000000..e270aa936899
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-channel_change_fw_err.patch
@@ -0,0 +1,89 @@
+[Bug 455] Fix frequent channel change generates firmware fatal error.
+
+Because of the frequent channel change, it is possible that when we are
+try to associate with channel 1 (authenticated but not associated).
+Another channel change comes at this time, then the driver will issue
+disassociate command to the firmware which will cause the fatal error.
+
+It seems that the association/disassociation procedure should not be
+interrupted.
+
+The patch attached adds test on STATUS_ASSOCIATING | STATUS_DISASSOCIATING
+in ipw_send_cmd(), when ensures that commands will not be sent to firmware
+when we are in these two status.
+
+Signed-off-by: Hong Liu <hong.liu@intel.com>
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+--
+diff -Nurp ipw2200-1.0.6-orig/ipw2200.c ipw2200-1.0.6/ipw2200.c
+--- ipw2200-1.0.6-orig/ipw2200.c 2005-04-12 17:03:02.000000000 +0800
++++ ipw2200-1.0.6/ipw2200.c 2005-04-13 13:42:03.496914912 +0800
+@@ -1592,6 +1592,18 @@ static int ipw_send_cmd(struct ipw_priv
+ return -1;
+ }
+
++ if (priv->status & STATUS_ASSOCIATING) {
++ IPW_DEBUG_HC("abandon a command while associating\n");
++ spin_unlock_irqrestore(&priv->lock, flags);
++ return -1;
++ }
++
++ if (priv->status & STATUS_DISASSOCIATING) {
++ IPW_DEBUG_HC("abandon a command while disassociating\n");
++ spin_unlock_irqrestore(&priv->lock, flags);
++ return -1;
++ }
++
+ priv->status |= STATUS_HCMD_ACTIVE;
+
+ IPW_DEBUG_HC("Sending %s command (#%d), %d bytes\n",
+@@ -3385,14 +3397,17 @@ static void ipw_send_disassociate(struct
+ return;
+ }
+
++ if (priv->status & STATUS_ASSOCIATING) {
++ IPW_DEBUG_ASSOC("Disassociating while associating.\n");
++ queue_work(priv->workqueue, &priv->disassociate);
++ return;
++ }
++
+ IPW_DEBUG_ASSOC("Disassocation attempt from " MAC_FMT " "
+ "on channel %d.\n",
+ MAC_ARG(priv->assoc_request.bssid),
+ priv->assoc_request.channel);
+
+- priv->status &= ~(STATUS_ASSOCIATING | STATUS_ASSOCIATED);
+- priv->status |= STATUS_DISASSOCIATING;
+-
+ if (quiet)
+ priv->assoc_request.assoc_type = HC_DISASSOC_QUIET;
+ else
+@@ -3404,6 +3419,9 @@ static void ipw_send_disassociate(struct
+ return;
+ }
+
++ priv->status &= ~(STATUS_ASSOCIATING | STATUS_ASSOCIATED);
++ priv->status |= STATUS_DISASSOCIATING;
++
+ }
+
+ static int ipw_disassociate(void *data)
+@@ -6093,8 +6111,6 @@ static int ipw_associate_network(struct
+ */
+ priv->channel = network->channel;
+ memcpy(priv->bssid, network->bssid, ETH_ALEN);
+- priv->status |= STATUS_ASSOCIATING;
+- priv->status &= ~STATUS_SECURITY_UPDATED;
+
+ priv->assoc_network = network;
+
+@@ -6104,6 +6120,9 @@ static int ipw_associate_network(struct
+ return err;
+ }
+
++ priv->status |= STATUS_ASSOCIATING;
++ priv->status &= ~STATUS_SECURITY_UPDATED;
++
+ IPW_DEBUG(IPW_DL_STATE, "associating: '%s' " MAC_FMT " \n",
+ escape_essid(priv->essid, priv->essid_len),
+ MAC_ARG(priv->bssid));
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-dup-without-retry.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-dup-without-retry.patch
new file mode 100644
index 000000000000..7f79ec0fd32d
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-dup-without-retry.patch
@@ -0,0 +1,32 @@
+Walkaround kernel BUG_ON panic caused by unexpected duplicate packets.
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+---
+
+ ipw2200-1.0.6-chuyee/ipw2200.c | 6 ++++--
+ 1 files changed, 4 insertions(+), 2 deletions(-)
+
+diff -puN ipw2200.c~dup-without-retry ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c~dup-without-retry 2005-08-03 13:59:11.000000000 +0800
++++ ipw2200-1.0.6-chuyee/ipw2200.c 2005-08-03 14:51:52.000000000 +0800
+@@ -7698,7 +7698,6 @@ static inline int is_network_packet(stru
+ static inline int is_duplicate_packet(struct ipw_priv *priv,
+ struct ieee80211_hdr *header)
+ {
+- u16 fc = le16_to_cpu(header->frame_ctl);
+ u16 sc = le16_to_cpu(header->seq_ctl);
+ u16 seq = WLAN_GET_SEQ_SEQ(sc);
+ u16 frag = WLAN_GET_SEQ_FRAG(sc);
+@@ -7759,7 +7758,10 @@ static inline int is_duplicate_packet(st
+ return 0;
+
+ drop:
+- BUG_ON(!(fc & IEEE80211_FCTL_RETRY));
++ /* Comment this line now since we observed the card receives
++ * duplicate packets but the FCTL_RETRY bit is not set in the
++ * IBSS mode with fragmentation enabled.
++ BUG_ON(!(le16_to_cpu(header->frame_ctl) & IEEE80211_FCTL_RETRY)); */
+ return 1;
+ }
+
+_
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-ibss-wep.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-ibss-wep.patch
new file mode 100644
index 000000000000..00dbf4708221
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-ibss-wep.patch
@@ -0,0 +1,41 @@
+Author: Hong Liu <hong.liu@intel.com>
+
+This patch fixes the ah-hoc network issue.
+
+If we configure the wep keys after creating the ibss network, the
+beacons of this network will not show correctly (it still shows "key
+off" in iwlist scan report). This is because we don't update the
+beacon info in firmware.
+
+Signed-off-by: Hong Liu <hong.liu@intel.com>
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+---
+
+ ipw2200-1.0.6-chuyee/ipw2200.c | 10 +++++++++-
+ 1 files changed, 9 insertions(+), 1 deletion(-)
+
+diff -puN ipw2200.c~ibss-wep ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c~ibss-wep 2005-07-15 14:40:29.000000000 +0800
++++ ipw2200-1.0.6-chuyee/ipw2200.c 2005-07-15 14:46:02.000000000 +0800
+@@ -9053,11 +9053,19 @@ static int ipw_wx_set_encode(struct net_
+ {
+ struct ipw_priv *priv = ieee80211_priv(dev);
+ int ret;
++ u32 cap = priv->capability;
+
+ down(&priv->sem);
+ ret = ieee80211_wx_set_encode(priv->ieee, info, wrqu, key);
+- up(&priv->sem);
+
++ /* In IBSS mode, we need to notify the firmware to update
++ * the beacon info after we changed the capability. */
++ if (cap != priv->capability &&
++ priv->ieee->iw_mode == IW_MODE_ADHOC &&
++ priv->status & STATUS_ASSOCIATED)
++ ipw_disassociate(priv);
++
++ up(&priv->sem);
+ return ret;
+ }
+
+_
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-init_scan.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-init_scan.patch
new file mode 100644
index 000000000000..06210bc9cd97
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-init_scan.patch
@@ -0,0 +1,30 @@
+[Bug 751] Fix driver association requires manual scan.
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+--
+diff -urp ipw2200-1.0.6/ipw2200.c ipw2200-1.0.6-init_scan/ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c 2005-07-14 03:00:28.000000000 +0800
++++ ipw2200-1.0.6-init_scan/ipw2200.c 2005-08-11 12:38:34.000000000 +0800
+@@ -10428,13 +10428,13 @@ static int ipw_up(struct ipw_priv *priv)
+ return 0;
+ }
+
++ priv->status |= STATUS_INIT;
+ rc = ipw_config(priv);
+ if (!rc) {
+ IPW_DEBUG_INFO("Configured device on count %i\n", i);
+ ipw_led_init(priv);
+ ipw_led_radio_on(priv);
+ priv->notif_missed_beacons = 0;
+- priv->status |= STATUS_INIT;
+
+ /* Set hardware WEP key if it is configured. */
+ if ((priv->capability & CAP_PRIVACY_ON) &&
+@@ -10445,6 +10445,7 @@ static int ipw_up(struct ipw_priv *priv)
+
+ return 0;
+ }
++ priv->status &= ~STATUS_INIT;
+
+ IPW_DEBUG_INFO("Device configuration failed: 0x%08X\n", rc);
+ IPW_DEBUG_INFO("Failed to config device on retry %d of %d\n",
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-irq_override.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-irq_override.patch
new file mode 100644
index 000000000000..b363afe919c9
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-irq_override.patch
@@ -0,0 +1,37 @@
+Add ability to override default irq assigned by the system. This is used
+to debug IRQ related problems.
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+--
+diff -urp ipw2200-1.0.6/ipw2200.c ipw2200-1.0.6-irq/ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c 2005-08-10 10:29:25.000000000 +0800
++++ ipw2200-1.0.6-irq/ipw2200.c 2005-08-15 17:24:50.000000000 +0800
+@@ -52,6 +52,7 @@ static int auto_create = 1;
+ static int led = 0;
+ static int disable = 0;
+ static int hwcrypto = 1;
++static int irq = 0;
+ static const char ipw_modes[] = {
+ 'a', 'b', 'g', '?'
+ };
+@@ -10714,6 +10715,11 @@ static int ipw_pci_probe(struct pci_dev
+
+ ipw_sw_reset(priv, 1);
+
++ if (irq) {
++ printk(KERN_INFO "Override default irq from %d to %d.\n",
++ pdev->irq, irq);
++ pdev->irq = irq;
++ }
+ err = request_irq(pdev->irq, ipw_isr, SA_SHIRQ, DRV_NAME, priv);
+ if (err) {
+ IPW_ERROR("Error allocating IRQ %d\n", pdev->irq);
+@@ -11004,5 +11010,8 @@ MODULE_PARM_DESC(mode, "network mode (0=
+ module_param(hwcrypto, int, 0444);
+ MODULE_PARM_DESC(hwcrypto, "enable hardware crypto (default on)");
+
++module_param(irq, int, 0444);
++MODULE_PARM_DESC(irq, "override defualt irq assigned by the system");
++
+ module_exit(ipw_exit);
+ module_init(ipw_init);
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-monitor_wep_fix.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-monitor_wep_fix.patch
new file mode 100644
index 000000000000..51a783e46b05
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-monitor_wep_fix.patch
@@ -0,0 +1,17 @@
+[Bug 760] Fix setting WEP key in monitor mode causes IV lost.
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+--
+diff -urp ipw2200-1.0.6/ipw2200.c ipw2200-1.0.6-monitor_wep/ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c 2005-08-25 11:13:57.000000000 +0800
++++ ipw2200-1.0.6-monitor_wep/ipw2200.c 2005-08-25 11:14:19.000000000 +0800
+@@ -7648,7 +7648,8 @@ static void ipw_handle_data_packet(struc
+ IPW_DEBUG_RX("Rx packet of %d bytes.\n", rxb->skb->len);
+
+ /* HW decrypt will not clear the WEP bit, MIC, PN, etc. */
+- if (!priv->ieee->host_decrypt)
++ if (!priv->ieee->host_decrypt &&
++ priv->ieee->iw_mode != IW_MODE_MONITOR)
+ ipw_rebuild_decrypted_skb(priv, rxb->skb);
+
+ if (!ieee80211_rx(priv->ieee, rxb->skb, stats))
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-open_frag.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-open_frag.patch
new file mode 100644
index 000000000000..25ec763e3c53
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-open_frag.patch
@@ -0,0 +1,23 @@
+Disable host fragementation in open mode since hardware support it.
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+---
+
+ ipw2200-1.0.6-chuyee/ipw2200.c | 3 +++
+ 1 files changed, 3 insertions(+)
+
+diff -L ipw2100.c -puN /dev/null /dev/null
+diff -puN ipw2200.c~open_frag ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c~open_frag 2005-08-03 15:54:41.000000000 +0800
++++ ipw2200-1.0.6-chuyee/ipw2200.c 2005-08-03 15:56:55.000000000 +0800
+@@ -8050,6 +8050,9 @@ static int ipw_sw_reset(struct ipw_priv
+ }
+ IPW_DEBUG_INFO("Hardware crypto [%s]\n", hwcrypto ? "on" : "off");
+
++ /* IPW2200/2915 is abled to do hardware fragmentation. */
++ priv->ieee->host_open_frag = 0;
++
+ if ((priv->pci_dev->device == 0x4223) ||
+ (priv->pci_dev->device == 0x4224)) {
+ if (init)
+_
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-pci_link-fix.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-pci_link-fix.patch
new file mode 100644
index 000000000000..1e111ca8b6ed
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-pci_link-fix.patch
@@ -0,0 +1,37 @@
+Free irq in ->suspend and request irq in ->resume to be compliant with
+the latest PM request (Documentation/power/pci.txt).
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+--
+diff -urp ipw2200-1.0.6/ipw2200.c ipw2200-1.0.6-pci_link/ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c 2005-08-10 10:29:25.000000000 +0800
++++ ipw2200-1.0.6-pci_link/ipw2200.c 2005-08-10 10:36:06.000000000 +0800
+@@ -10856,6 +10856,7 @@ static int ipw_pci_suspend(struct pci_de
+
+ /* Take down the device; powers it off, etc. */
+ ipw_down(priv);
++ free_irq(pdev->irq, priv);
+
+ /* Remove the PRESENT state of the device */
+ netif_device_detach(dev);
+@@ -10881,6 +10882,7 @@ static int ipw_pci_resume(struct pci_dev
+ struct ipw_priv *priv = pci_get_drvdata(pdev);
+ struct net_device *dev = priv->net_dev;
+ u32 val;
++ int err;
+
+ printk(KERN_INFO "%s: Coming out of suspend...\n", dev->name);
+
+@@ -10905,6 +10907,12 @@ static int ipw_pci_resume(struct pci_dev
+ if ((val & 0x0000ff00) != 0)
+ pci_write_config_dword(pdev, 0x40, val & 0xffff00ff);
+
++ err = request_irq(pdev->irq, ipw_isr, SA_SHIRQ, DRV_NAME, priv);
++ if (err) {
++ IPW_ERROR("Error allocating IRQ %d\n", pdev->irq);
++ return err;
++ }
++
+ /* Set the device back into the PRESENT state; this will also wake
+ * the queue of needed */
+ netif_device_attach(dev);
diff --git a/net-wireless/ipw2200/files/ipw2200-1.0.6-reset-mode-fix.patch b/net-wireless/ipw2200/files/ipw2200-1.0.6-reset-mode-fix.patch
new file mode 100644
index 000000000000..9d49f98c9aab
--- /dev/null
+++ b/net-wireless/ipw2200/files/ipw2200-1.0.6-reset-mode-fix.patch
@@ -0,0 +1,21 @@
+[Bug 701] Fix a misuse of ieee->mode with ieee->iw_mode.
+
+Signed-off-by: Zhu Yi <yi.zhu@intel.com>
+---
+
+ ipw2200-1.0.6-chuyee/ipw2200.c | 2 +-
+ 1 files changed, 1 insertion(+), 1 deletion(-)
+
+diff -puN ipw2200.c~reset-mode-fix ipw2200.c
+--- ipw2200-1.0.6/ipw2200.c~reset-mode-fix 2005-07-15 14:21:25.000000000 +0800
++++ ipw2200-1.0.6-chuyee/ipw2200.c 2005-07-15 14:22:34.000000000 +0800
+@@ -8093,7 +8093,7 @@ static int ipw_sw_reset(struct ipw_priv
+ priv->power_mode = IPW_POWER_AC;
+ priv->tx_power = IPW_TX_POWER_DEFAULT;
+
+- return old_mode == priv->ieee->mode;
++ return old_mode == priv->ieee->iw_mode;
+ }
+
+
+_
diff --git a/net-wireless/ipw2200/ipw2200-1.0.6-r3.ebuild b/net-wireless/ipw2200/ipw2200-1.0.6-r3.ebuild
new file mode 100644
index 000000000000..45bae3974d2d
--- /dev/null
+++ b/net-wireless/ipw2200/ipw2200-1.0.6-r3.ebuild
@@ -0,0 +1,109 @@
+# Copyright 1999-2005 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/net-wireless/ipw2200/ipw2200-1.0.6-r3.ebuild,v 1.1 2005/09/06 14:58:35 brix Exp $
+
+inherit eutils linux-mod
+
+# The following works with both pre-releases and releases
+MY_P=${P/_/-}
+S=${WORKDIR}/${MY_P}
+
+IEEE80211_VERSION="1.0.3-r1"
+FW_VERSION="2.3"
+
+DESCRIPTION="Driver for the Intel PRO/Wireless 2200BG/2915ABG miniPCI and 2225BG PCI adapters"
+HOMEPAGE="http://ipw2200.sourceforge.net"
+SRC_URI="mirror://sourceforge/${PN}/${MY_P}.tgz"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~x86"
+
+IUSE="debug"
+DEPEND=">=net-wireless/ieee80211-${IEEE80211_VERSION}"
+RDEPEND="${DEPEND}
+ =net-wireless/ipw2200-firmware-${FW_VERSION}
+ net-wireless/wireless-tools"
+
+BUILD_TARGETS="all"
+MODULE_NAMES="ipw2200(net/wireless:)"
+MODULESD_IPW2200_DOCS="README.ipw2200"
+
+CONFIG_CHECK="NET_RADIO FW_LOADER"
+ERROR_NET_RADIO="${P} requires support for Wireless LAN drivers (non-hamradio) & Wireless Extensions (CONFIG_NET_RADIO)."
+ERROR_FW_LOADER="${P} requires Hotplug firmware loading support (CONFIG_FW_LOADER)."
+
+pkg_setup() {
+ linux-mod_pkg_setup
+
+ if kernel_is 2 4; then
+ die "${P} does not support building against kernel 2.4.x"
+ fi
+
+ if [[ ! -f /lib/modules/${KV_FULL}/net/ieee80211/ieee80211.${KV_OBJ} ]]; then
+ eerror
+ eerror "Looks like you forgot to remerge net-wireless/ieee80211 after"
+ eerror "upgrading your kernel."
+ eerror
+ eerror "Hint: use sys-kernel/module-rebuild for keeping track of which"
+ eerror "modules needs to be remerged after a kernel upgrade."
+ eerror
+ die "/lib/modules/${KV_FULL}/net/ieee80211/ieee80211.${KV_OBJ} not found"
+ fi
+
+ BUILD_PARAMS="KSRC=${KV_DIR} KSRC_OUTPUT=${KV_OUT_DIR} IEEE80211_INC=/usr/include"
+}
+
+src_unpack() {
+ local debug="n"
+
+ unpack ${A}
+
+ cd ${S}
+ epatch ${FILESDIR}/${P}-a_txpow.patch
+ epatch ${FILESDIR}/${P}-channel_change_fw_err.patch
+ epatch ${FILESDIR}/${P}-dup-without-retry.patch
+ epatch ${FILESDIR}/${P}-hwcrypt-wpa-fix4.patch
+ epatch ${FILESDIR}/${P}-ibss-wep.patch
+ epatch ${FILESDIR}/${P}-init_scan.patch
+ epatch ${FILESDIR}/${P}-irq_override.patch
+ epatch ${FILESDIR}/${P}-monitor_wep_fix.patch
+ epatch ${FILESDIR}/${P}-open_frag.patch
+ epatch ${FILESDIR}/${P}-pci_link-fix.patch
+ epatch ${FILESDIR}/${P}-reset-mode-fix.patch
+
+ epatch ${FILESDIR}/${P}-broadcast.patch
+ kernel_is gt 2 6 12 && epatch ${FILESDIR}/${P}-suspend2.patch
+
+ use debug && debug="y"
+ sed -i -e "s:^\(CONFIG_IPW_DEBUG\)=.*:\1=${debug}:" ${S}/Makefile
+}
+
+src_compile() {
+ linux-mod_src_compile
+
+ einfo
+ einfo "You may safely ignore any errors from above compilation that contain"
+ einfo "warnings about undefined references to the ieee80211 subsystem."
+ einfo
+}
+
+src_install() {
+ linux-mod_src_install
+
+ dodoc CHANGES ISSUES
+}
+
+pkg_postinst() {
+ linux-mod_pkg_postinst
+
+ if [ -f /lib/modules/${KV_FULL}/net/${PN}.ko ]; then
+ einfo
+ einfo "Modules from an earlier installation detected. You will need to manually"
+ einfo "remove those modules by running the following commands:"
+ einfo " # rm -f /lib/modules/${KV_FULL}/net/${PN}.ko"
+ einfo " # rm -f /lib/modules/${KV_FULL}/net/ieee80211*.ko"
+ einfo " # depmod -a"
+ einfo
+ fi
+}