Acinonyx wrote:
> The following patch enables txpower setting for hostap driver and restores 
> txpower after card resets.
> 
> Signed-off-by: Vasilis Tsiligiannis <[EMAIL PROTECTED]>
> 
> ---
>  .../patches-2.6.24/903-hostap_txpower.patch        |  160 
> ++++++++++++++++++++
>  1 files changed, 160 insertions(+), 0 deletions(-)
>  create mode 100644 
> trunk/target/linux/generic-2.6/patches-2.6.24/903-hostap_txpower.patch
> 
> diff --git 
> a/trunk/target/linux/generic-2.6/patches-2.6.24/903-hostap_txpower.patch 
> b/trunk/target/linux/generic-2.6/patches-2.6.24/903-hostap_txpower.patch
> new file mode 100644
> index 0000000..6f82cdb
> --- /dev/null
> +++ b/trunk/target/linux/generic-2.6/patches-2.6.24/903-hostap_txpower.patch
> @@ -0,0 +1,160 @@
> +diff -Nur linux-2.6.17/drivers/net/wireless/hostap/hostap_ap.c 
> linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_ap.c
> +--- linux-2.6.17/drivers/net/wireless/hostap/hostap_ap.c     2006-06-18 
> 04:49:35.000000000 +0300
> ++++ linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_ap.c     
> 2006-12-10 19:13:33.000000000 +0200
> +@@ -2345,13 +2345,13 @@
> +             addr[count].sa_family = ARPHRD_ETHER;
> +             memcpy(addr[count].sa_data, sta->addr, ETH_ALEN);
> +             if (sta->last_rx_silence == 0)
> +-                    qual[count].qual = sta->last_rx_signal < 27 ?
> +-                            0 : (sta->last_rx_signal - 27) * 92 / 127;
> ++                        qual[count].qual = (sta->last_rx_signal - 156) == 0 
> ?
> ++                                0 : (sta->last_rx_signal - 156) * 92 / 64;
> +             else
> +-                    qual[count].qual = sta->last_rx_signal -
> +-                            sta->last_rx_silence - 35;
> +-            qual[count].level = HFA384X_LEVEL_TO_dBm(sta->last_rx_signal);
> +-            qual[count].noise = HFA384X_LEVEL_TO_dBm(sta->last_rx_silence);
> ++                        qual[count].qual = (sta->last_rx_signal -
> ++                                sta->last_rx_silence) * 92 / 64;
> ++                qual[count].level = sta->last_rx_signal;
> ++                qual[count].noise = sta->last_rx_silence;
> +             qual[count].updated = sta->last_rx_updated;
> + 
> +             sta->last_rx_updated = IW_QUAL_DBM;
> +@@ -2416,13 +2416,13 @@
> +             memset(&iwe, 0, sizeof(iwe));
> +             iwe.cmd = IWEVQUAL;
> +             if (sta->last_rx_silence == 0)
> +-                    iwe.u.qual.qual = sta->last_rx_signal < 27 ?
> +-                            0 : (sta->last_rx_signal - 27) * 92 / 127;
> ++                    iwe.u.qual.qual = (sta->last_rx_signal -156) == 0 ?
> ++                            0 : (sta->last_rx_signal - 156) * 92 / 64;
> +             else
> +-                    iwe.u.qual.qual = sta->last_rx_signal -
> +-                            sta->last_rx_silence - 35;
> +-            iwe.u.qual.level = HFA384X_LEVEL_TO_dBm(sta->last_rx_signal);
> +-            iwe.u.qual.noise = HFA384X_LEVEL_TO_dBm(sta->last_rx_silence);
> ++                        iwe.u.qual.qual = (sta->last_rx_signal -
> ++                                sta->last_rx_silence) * 92 / 64;
> ++                iwe.u.qual.level = sta->last_rx_signal;
> ++                iwe.u.qual.noise = sta->last_rx_silence;
> +             iwe.u.qual.updated = sta->last_rx_updated;
> +             iwe.len = IW_EV_QUAL_LEN;
> +             current_ev = iwe_stream_add_event(current_ev, end_buf, &iwe,
> +diff -Nur linux-2.6.17/drivers/net/wireless/hostap/hostap_config.h 
> linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_config.h
> +--- linux-2.6.17/drivers/net/wireless/hostap/hostap_config.h 2006-06-18 
> 04:49:35.000000000 +0300
> ++++ linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_config.h 
> 2006-12-10 19:13:33.000000000 +0200
> +@@ -47,4 +47,9 @@
> +  */
> + /* #define PRISM2_NO_STATION_MODES */
> + 
> ++/* Enable TX power Setting functions
> ++ * (min att = -128 , max att =  127)
> ++ */
> ++#define RAW_TXPOWER_SETTING
> ++
> + #endif /* HOSTAP_CONFIG_H */
> +diff -Nur linux-2.6.17/drivers/net/wireless/hostap/hostap.h 
> linux-2.6.17-patched/drivers/net/wireless/hostap/hostap.h
> +--- linux-2.6.17/drivers/net/wireless/hostap/hostap.h        2006-06-18 
> 04:49:35.000000000 +0300
> ++++ linux-2.6.17-patched/drivers/net/wireless/hostap/hostap.h        
> 2006-12-10 19:20:00.000000000 +0200
> +@@ -89,6 +89,7 @@
> + extern struct ethtool_ops prism2_ethtool_ops;
> + 
> + int hostap_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd);
> ++int hostap_restore_power(struct net_device *dev);
> + 
> + 
> + #endif /* HOSTAP_H */
> +diff -Nur linux-2.6.17/drivers/net/wireless/hostap/hostap_hw.c 
> linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_hw.c
> +--- linux-2.6.17/drivers/net/wireless/hostap/hostap_hw.c     2006-06-18 
> 04:49:35.000000000 +0300
> ++++ linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_hw.c     
> 2006-12-10 19:13:33.000000000 +0200
> +@@ -1043,6 +1043,7 @@
> +                    dev->name, local->fragm_threshold);
> +     }
> + 
> ++    hostap_restore_power(dev);
> +     return res;
> + }
> + 
> +diff -Nur linux-2.6.17/drivers/net/wireless/hostap/hostap_info.c 
> linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_info.c
> +--- linux-2.6.17/drivers/net/wireless/hostap/hostap_info.c   2006-06-18 
> 04:49:35.000000000 +0300
> ++++ linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_info.c   
> 2006-12-10 19:13:33.000000000 +0200
> +@@ -429,6 +429,11 @@
> +     }
> + 
> +     /* Get BSSID if we have a valid AP address */
> ++
> ++    if ( val == HFA384X_LINKSTATUS_CONNECTED ||
> ++         val == HFA384X_LINKSTATUS_DISCONNECTED ) 
> ++                    hostap_restore_power(local->dev);
> ++
> +     if (connected) {
> +             netif_carrier_on(local->dev);
> +             netif_carrier_on(local->ddev);
> +diff -Nur linux-2.6.17/drivers/net/wireless/hostap/hostap_ioctl.c 
> linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_ioctl.c
> +--- linux-2.6.17/drivers/net/wireless/hostap/hostap_ioctl.c  2006-06-18 
> 04:49:35.000000000 +0300
> ++++ linux-2.6.17-patched/drivers/net/wireless/hostap/hostap_ioctl.c  
> 2006-12-10 21:21:03.000000000 +0200
> +@@ -1506,23 +1506,20 @@
> +             val = 255;
> + 
> +     tmp = val;
> +-    tmp >>= 2;
> + 
> +-    return -12 - tmp;
> ++    return tmp;
> + }
> + 
> + static u16 prism2_txpower_dBm_to_hfa386x(int val)
> + {
> +     signed char tmp;
> + 
> +-    if (val > 20)
> +-            return 128;
> +-    else if (val < -43)
> ++    if (val > 127)
> +             return 127;
> ++    else if (val < -128)
> ++            return 128;
> + 
> +     tmp = val;
> +-    tmp = -12 - tmp;
> +-    tmp <<= 2;
> + 
> +     return (unsigned char) tmp;
> + }
> +@@ -4086,3 +4083,35 @@
> + 
> +     return ret;
> + }
> ++
> ++/* BUG FIX: Restore power setting value when lost due to F/W bug */
> ++
> ++int hostap_restore_power(struct net_device *dev)
> ++{
> ++        struct hostap_interface *iface = dev->priv;
> ++       local_info_t *local = iface->local;
> ++               
> ++       u16 val;
> ++       int ret = 0;
> ++
> ++       if (local->txpower_type == PRISM2_TXPOWER_OFF) {
> ++                       val = 0xff; /* use all standby and sleep modes */
> ++                       ret = local->func->cmd(dev, HFA384X_CMDCODE_WRITEMIF,
> ++                                              HFA386X_CR_A_D_TEST_MODES2,
> ++                                              &val, NULL);
> ++       }
> ++
> ++#ifdef RAW_TXPOWER_SETTING
> ++       if (local->txpower_type == PRISM2_TXPOWER_FIXED) {
> ++               val = HFA384X_TEST_CFG_BIT_ALC;
> ++               local->func->cmd(dev, HFA384X_CMDCODE_TEST |
> ++                                (HFA384X_TEST_CFG_BITS << 8), 0, &val, 
> NULL);
> ++               val = prism2_txpower_dBm_to_hfa386x(local->txpower);
> ++               ret = (local->func->cmd(dev, HFA384X_CMDCODE_WRITEMIF,
> ++                            HFA386X_CR_MANUAL_TX_POWER, &val, NULL));
> ++       }
> ++#endif /* RAW_TXPOWER_SETTING */
> ++       return (ret ? -EOPNOTSUPP : 0);
> ++}
> ++
> ++EXPORT_SYMBOL(hostap_restore_power);
> 
> 
> ------------------------------------------------------------------------
> 
> _______________________________________________
> openwrt-devel mailing list
> [email protected]
> http://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel

Committed r10656. Thanks

Travis
_______________________________________________
openwrt-devel mailing list
[email protected]
http://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel

Reply via email to