All of lore.kernel.org
 help / color / mirror / Atom feed
From: Helmut Schaa <helmut.schaa@googlemail.com>
To: "Tomas Winkler" <tomasw@gmail.com>
Cc: "Helmut Schaa" <helmut.schaa@googlemail.com>,
	linux-wireless@vger.kernel.org, yi.zhu@intel.com
Subject: Re: iwlwifi - rfkill only works if the interface is up
Date: Mon, 1 Dec 2008 16:04:05 +0100	[thread overview]
Message-ID: <200812011604.05700.helmut.schaa@gmail.com> (raw)
In-Reply-To: <1ba2fa240812010508hcb29699m8bd8b3b0ba8574cd@mail.gmail.com>

Am Montag, 1. Dezember 2008 schrieb Tomas Winkler:
> On Mon, Dec 1, 2008 at 2:11 PM, Helmut Schaa
> <helmut.schaa@googlemail.com> wrote:

...

> > diff --git a/drivers/net/wireless/iwlwifi/iwl-agn.c b/drivers/net/wireless/iwlwifi/iwl-agn.c
> > index b935e9d..e2f160b 100644
> > --- a/drivers/net/wireless/iwlwifi/iwl-agn.c
> > +++ b/drivers/net/wireless/iwlwifi/iwl-agn.c
> > @@ -1504,8 +1504,11 @@ static void iwl_irq_tasklet(struct iwl_priv *priv)
> >                 * the driver as well won't allow loading if RFKILL is set
> >                 * therefore no need to restart the driver from this handler
> >                 */
> > -               if (!hw_rf_kill && !test_bit(STATUS_ALIVE, &priv->status))
> > +               if (!hw_rf_kill && !test_bit(STATUS_ALIVE, &priv->status)) {
> >                        clear_bit(STATUS_RF_KILL_HW, &priv->status);
> > +                       if (priv->is_open)
> > +                               queue_work(priv->workqueue, &priv->restart);
> > +               }
> >
> >                handled |= CSR_INT_BIT_RF_KILL;
> >        }
> 
> This is strange, this exact code is part of  patch
> 
> """
> Emmanuel Grumbach <emmanuel.grumbach@intel.com>
> Date:   Sun Jun 22 11:18:52 2008 +0300
>  iwlwifi: clean up HW RF-kill state machine and restarts
>  This patch cleans up HW RF-kill state machine.
> """
> The two other hunks of this patch are in the current code, this one is
> not, I've probably messed up something on they way. I will track this
> down.

Thanks, should I respin the above patch?

> > Nevertheless, I'm wondering if the current behaviour (even with the patch above)
> > makes much sense. I mean, the user space cannot rely on the rfkill state
> > unless an appropriate interface is up. As the device is able to report the
> > killswitch state without firmware being loaded the following approach could
> > be feasible:
> > - iwl_pci_probe enables the device and enables the interrupts
> > - iwl_mac_start just loads the firmware
> > - iwl_mac_stop just releases the firmware but leaves the interrupts enabled
> 
> In 3495  rfkill interrupt is not available and rfkill state is
> delivered only when firmware is loaded, therefore this is not
> possible to bring device down and also expect rfill switch event.

Would it be possible to poll CSR_GP_CNTRL for that information on iwl3945?

> There were few threads about this subject.

Searching for these now ...

> In 4965 and 5000 this will work

Would you agree on that behavior?
Any objections I did not think of yet?

Thanks,
Helmut

  reply	other threads:[~2008-12-01 15:12 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-12-01 12:11 iwlwifi - rfkill only works if the interface is up Helmut Schaa
2008-12-01 13:08 ` Tomas Winkler
2008-12-01 15:04   ` Helmut Schaa [this message]
2008-12-01 17:43     ` Tomas Winkler
2009-01-05 14:43       ` Helmut Schaa
2008-12-01 15:30   ` Marcel Holtmann
2008-12-01 15:34     ` Helmut Schaa
2008-12-01 15:59       ` Marcel Holtmann
2008-12-01 16:16         ` Helmut Schaa
2008-12-01 21:12         ` John W. Linville
2008-12-01 21:50           ` Helmut Schaa
2008-12-03 22:48             ` Dan Williams
2008-12-02 12:59         ` Henrique de Moraes Holschuh
2008-12-02 13:14           ` Marcel Holtmann
2008-12-02 15:03             ` Henrique de Moraes Holschuh

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=200812011604.05700.helmut.schaa@gmail.com \
    --to=helmut.schaa@googlemail.com \
    --cc=linux-wireless@vger.kernel.org \
    --cc=tomasw@gmail.com \
    --cc=yi.zhu@intel.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.