Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 290758
b: refs/heads/master
c: 53476fe
h: refs/heads/master
v: v3
  • Loading branch information
Emmanuel Grumbach authored and Wey-Yi Guy committed Feb 27, 2012
1 parent a061fca commit ceb71b0
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 9 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 4d660ce52e27957f7181ef662889eec67686c7b5
refs/heads/master: 53476fe11f730e37a6e8f0eabb25d59485e9854b
36 changes: 34 additions & 2 deletions trunk/drivers/net/wireless/iwlwifi/iwl-op-mode.h
Original file line number Diff line number Diff line change
Expand Up @@ -69,17 +69,47 @@ struct sk_buff;
struct iwl_device_cmd;
struct iwl_rx_mem_buffer;

/**
* DOC: Operational mode - what is it ?
*
* The operational mode (a.k.a. op_mode) is the layer that implements
* mac80211's handlers. It knows two APIs: mac80211's and the fw's. It uses
* the transport API to access the HW. The op_mode doesn't need to know how the
* underlying HW works, since the transport layer takes care of that.
*
* There can be several op_mode: i.e. different fw APIs will require two
* different op_modes. This is why the op_mode is virtualized.
*/

/**
* DOC: Life cycle of the Operational mode
*
* The operational mode has a very simple life cycle.
*
* 1) The driver layer (iwl-drv.c) chooses the op_mode based on the
* capabilities advertized by the fw file (in TLV format).
* 2) The driver layer starts the op_mode (ops->start)
* 3) The op_mode registers registers mac80211
* 4) The op_mode is governed by mac80211
* 5) The driver layer stops the op_mode
*/

/**
* struct iwl_op_mode_ops - op_mode specific operations
*
* The op_mode exports its ops so that external components can start it and
* interact with it. The driver layer typically calls the start and stop
* handlers, the transport layer calls the others.
*
* All the handlers MUST be implemented
*
* @start: start the op_mode
* @start: start the op_mode. The transport layer is already allocated.
* May sleep
* @stop: stop the op_mode
* @stop: stop the op_mode. Must free all the memory allocated.
* May sleep
* @rx: Rx notification to the op_mode. rxb is the Rx buffer itself. Cmd is the
* HCMD the this Rx responds to.
* Must be atomic.
* @queue_full: notifies that a HW queue is full. Ac is the ac of the queue
* Must be atomic
* @queue_not_full: notifies that a HW queue is not full any more.
Expand Down Expand Up @@ -120,6 +150,8 @@ struct iwl_op_mode {

static inline void iwl_op_mode_stop(struct iwl_op_mode *op_mode)
{
might_sleep();

op_mode->ops->stop(op_mode);
}

Expand Down
6 changes: 0 additions & 6 deletions trunk/drivers/net/wireless/iwlwifi/iwl-trans.h
Original file line number Diff line number Diff line change
Expand Up @@ -106,12 +106,6 @@
* 6) Eventually, the free function will be called.
*/

/**
* DOC: API needed by the transport layer from the op_mode
*
* TODO
*/

struct iwl_priv;
struct iwl_shared;
struct iwl_op_mode;
Expand Down

0 comments on commit ceb71b0

Please sign in to comment.