Search Linux Wireless

Re: [PATCH 14/25] iwlegacy: remove ctx interface_modes

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Stanislaw,



On 3 feb. 2012, at 13:07, Stanislaw Gruszka <sgruszka@xxxxxxxxxx> wrote:

> Signed-off-by: Stanislaw Gruszka <sgruszka@xxxxxxxxxx>
> ---
> drivers/net/wireless/iwlegacy/3945-mac.c |    6 ++----
> drivers/net/wireless/iwlegacy/4965-mac.c |    6 ++----
> drivers/net/wireless/iwlegacy/common.c   |   29 ++++-------------------------
> drivers/net/wireless/iwlegacy/common.h   |    2 --
> drivers/net/wireless/rt2x00/rt2800usb.c  |   16 ++--------------
> 5 files changed, 10 insertions(+), 49 deletions(-)
> 

There's a change to rt2800usb here that doesn't belong here.


> diff --git a/drivers/net/wireless/iwlegacy/3945-mac.c b/drivers/net/wireless/iwlegacy/3945-mac.c
> index 52cac0c..7c81f5a 100644
> --- a/drivers/net/wireless/iwlegacy/3945-mac.c
> +++ b/drivers/net/wireless/iwlegacy/3945-mac.c
> @@ -3557,7 +3557,8 @@ il3945_setup_mac(struct il_priv *il)
>    /* Tell mac80211 our characteristics */
>    hw->flags = IEEE80211_HW_SIGNAL_DBM | IEEE80211_HW_SPECTRUM_MGMT;
> 
> -    hw->wiphy->interface_modes = il->ctx.interface_modes;
> +    hw->wiphy->interface_modes =
> +        BIT(NL80211_IFTYPE_STATION) | BIT(NL80211_IFTYPE_ADHOC);
> 
>    hw->wiphy->flags |=
>        WIPHY_FLAG_CUSTOM_REGULATORY | WIPHY_FLAG_DISABLE_BEACON_HINTS |
> @@ -3617,9 +3618,6 @@ il3945_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
> 
>    il->cmd_queue = IL39_CMD_QUEUE_NUM;
> 
> -    il->ctx.interface_modes =
> -        BIT(NL80211_IFTYPE_STATION) | BIT(NL80211_IFTYPE_ADHOC);
> -
>    /*
>     * Disabling hardware scan means that mac80211 will perform scans
>     * "the hard way", rather than using device's scan.
> diff --git a/drivers/net/wireless/iwlegacy/4965-mac.c b/drivers/net/wireless/iwlegacy/4965-mac.c
> index 35d868c..1dd0014 100644
> --- a/drivers/net/wireless/iwlegacy/4965-mac.c
> +++ b/drivers/net/wireless/iwlegacy/4965-mac.c
> @@ -5454,8 +5454,8 @@ il4965_mac_setup_register(struct il_priv *il, u32 max_probe_length)
>    hw->sta_data_size = sizeof(struct il_station_priv);
>    hw->vif_data_size = sizeof(struct il_vif_priv);
> 
> -    hw->wiphy->interface_modes |= il->ctx.interface_modes;
> -    hw->wiphy->interface_modes |= il->ctx.exclusive_interface_modes;
> +    hw->wiphy->interface_modes =
> +        BIT(NL80211_IFTYPE_STATION) | BIT(NL80211_IFTYPE_ADHOC);
> 
>    hw->wiphy->flags |=
>        WIPHY_FLAG_CUSTOM_REGULATORY | WIPHY_FLAG_DISABLE_BEACON_HINTS;
> @@ -6141,8 +6141,6 @@ il4965_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
>    il->ctx.is_active = true;
>    il->ctx.ac_to_fifo = il4965_bss_ac_to_fifo;
>    il->ctx.ac_to_queue = il4965_bss_ac_to_queue;
> -    il->ctx.exclusive_interface_modes = BIT(NL80211_IFTYPE_ADHOC);
> -    il->ctx.interface_modes = BIT(NL80211_IFTYPE_STATION);
> 
>    SET_IEEE80211_DEV(hw, &pdev->dev);
> 
> diff --git a/drivers/net/wireless/iwlegacy/common.c b/drivers/net/wireless/iwlegacy/common.c
> index ac26985..7f4c6bf 100644
> --- a/drivers/net/wireless/iwlegacy/common.c
> +++ b/drivers/net/wireless/iwlegacy/common.c
> @@ -4566,7 +4566,6 @@ il_mac_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
>    struct il_priv *il = hw->priv;
>    struct il_vif_priv *vif_priv = (void *)vif->drv_priv;
>    int err;
> -    u32 modes;
> 
>    D_MAC80211("enter: type %d, addr %pM\n", vif->type, vif->addr);
> 
> @@ -4578,15 +4577,7 @@ il_mac_add_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
>        goto out;
>    }
> 
> -    /* check if busy context is exclusive */
> -    if (il->ctx.vif &&
> -        (il->ctx.exclusive_interface_modes & BIT(il->ctx.vif->type))) {
> -        err = -EINVAL;
> -        goto out;
> -    }
> -
> -    modes = il->ctx.interface_modes | il->ctx.exclusive_interface_modes;
> -    if (!(modes & BIT(vif->type))) {
> +    if (il->ctx.vif) {
>        err = -EOPNOTSUPP;
>        goto out;
>    }
> @@ -4979,10 +4970,10 @@ il_mac_change_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
> {
>    struct il_priv *il = hw->priv;
>    struct il_rxon_context *ctx = il_rxon_ctx_from_vif(vif);
> -    u32 modes;
>    int err;
> 
> -    newtype = ieee80211_iftype_p2p(newtype, newp2p);
> +    if (newp2p)
> +        return -EOPNOTSUPP;
> 
>    mutex_lock(&il->mutex);
> 
> @@ -4995,22 +4986,10 @@ il_mac_change_interface(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
>        goto out;
>    }
> 
> -    modes = ctx->interface_modes | ctx->exclusive_interface_modes;
> -    if (!(modes & BIT(newtype))) {
> -        err = -EOPNOTSUPP;
> -        goto out;
> -    }
> -
> -    if ((il->ctx.exclusive_interface_modes & BIT(il->ctx.vif->type)) ||
> -        (il->ctx.exclusive_interface_modes & BIT(newtype))) {
> -        err = -EINVAL;
> -        goto out;
> -    }
> -
>    /* success */
>    il_teardown_interface(il, vif, true);
>    vif->type = newtype;
> -    vif->p2p = newp2p;
> +    vif->p2p = false;
>    err = il_setup_interface(il, ctx);
>    WARN_ON(err);
>    /*
> diff --git a/drivers/net/wireless/iwlegacy/common.h b/drivers/net/wireless/iwlegacy/common.h
> index a872175..eddf22d 100644
> --- a/drivers/net/wireless/iwlegacy/common.h
> +++ b/drivers/net/wireless/iwlegacy/common.h
> @@ -1165,8 +1165,6 @@ struct il_rxon_context {
>     */
>    bool always_active, is_active;
> 
> -    u32 interface_modes, exclusive_interface_modes;
> -
>    struct il_qos_info qos_data;
> 
>    struct {
> diff --git a/drivers/net/wireless/rt2x00/rt2800usb.c b/drivers/net/wireless/rt2x00/rt2800usb.c
> index f0074bc..0807c09 100644
> --- a/drivers/net/wireless/rt2x00/rt2800usb.c
> +++ b/drivers/net/wireless/rt2x00/rt2800usb.c
> @@ -272,17 +272,6 @@ static void rt2800usb_disable_radio(struct rt2x00_dev *rt2x00dev)
>    rt2x00usb_disable_radio(rt2x00dev);
> }
> 
> -static int rt2800usb_set_state(struct rt2x00_dev *rt2x00dev,
> -                   enum dev_state state)
> -{
> -    if (state == STATE_AWAKE)
> -        rt2800_mcu_request(rt2x00dev, MCU_WAKEUP, 0xff, 0, 2);
> -    else
> -        rt2800_mcu_request(rt2x00dev, MCU_SLEEP, 0xff, 0xff, 2);
> -
> -    return 0;
> -}
> -
> static int rt2800usb_set_device_state(struct rt2x00_dev *rt2x00dev,
>                      enum dev_state state)
> {
> @@ -295,7 +284,7 @@ static int rt2800usb_set_device_state(struct rt2x00_dev *rt2x00dev,
>         * to be woken up. After that it needs a bit of time
>         * to be fully awake and then the radio can be enabled.
>         */
> -        rt2800usb_set_state(rt2x00dev, STATE_AWAKE);
> +        rt2800_mcu_request(rt2x00dev, MCU_WAKEUP, 0xff, 0, 0);
>        msleep(1);
>        retval = rt2800usb_enable_radio(rt2x00dev);
>        break;
> @@ -305,7 +294,6 @@ static int rt2800usb_set_device_state(struct rt2x00_dev *rt2x00dev,
>         * be put to sleep for powersaving.
>         */
>        rt2800usb_disable_radio(rt2x00dev);
> -        rt2800usb_set_state(rt2x00dev, STATE_SLEEP);
>        break;
>    case STATE_RADIO_IRQ_ON:
>    case STATE_RADIO_IRQ_OFF:
> @@ -315,7 +303,7 @@ static int rt2800usb_set_device_state(struct rt2x00_dev *rt2x00dev,
>    case STATE_SLEEP:
>    case STATE_STANDBY:
>    case STATE_AWAKE:
> -        retval = rt2800usb_set_state(rt2x00dev, state);
> +        rt2800_mcu_request(rt2x00dev, MCU_SLEEP, 0xff, 0xff, 2);
>        break;
>    default:
>        retval = -ENOTSUPP;
> -- 
> 1.7.1
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux