ieee80211_rx

ieee80211rx.c(E:\code\linux\net\ieee80211)

所有接收到的帧都送到这个函数中去

int ieee80211_rx(struct ieee80211_device *ieee, struct sk_buff *skb,struct ieee80211_rx_stats *rx_stats) 进行处理。

函数的实现过程如下:

(1)判断接收的帧的长度是否符合数据帧或管理帧的长度。若不符合,则丢弃。

   fc = le16_to_cpu(hdr->frame_ctl);

hdrlen = ieee80211_get_hdrlen(fc);

if (skb->len < hdrlen) {

     printk(KERN_INFO "%s: invalid SKB length %d\n",

    dev->name, skb->len);

    goto rx_dropped;

  }

(2)如果ap处于监听模式IW_MODE_MONITOR

ieee80211_monitor_rx(ieee, skb, rx_stats);

(3)

=================================================

补充:

1、ieee80211_get_hdrlen

作用:根据传入的帧的类型进行长度的判断。 对于802.11的帧,只有数据帧和管理帧这两类。

2、在双向列表末尾插入

static inline void __skb_queue_tail(struct sk_buff_head *list,        struct sk_buff *newsk)

{

struct sk_buff *prev, *next;

list->qlen++;

next = (struct sk_buff *)list;

prev = next->prev;

newsk->next = next;

newsk->prev = prev;

next->prev  = prev->next = newsk;

}

3、static void ieee80211_monitor_rx(struct ieee80211_device *ieee,      struct sk_buff *skb,      struct ieee80211_rx_stats *rx_stats)  {   netif_rx(skb);  } 4、传统方法处理报文的网络层代码

将接收到的报文放到特定CPU的等待队列中,并退出中断上下文

int netif_rx(struct sk_buff *skb)    {

/* if netpoll wants it, pretend we never saw it */

if (netpoll_rx(skb))/* netpoll功能需要处理该报文,退出。该功能用于内核调试 */

return NET_RX_DROP;    }

5、处理ieee80211管理帧

static int   ieee80211_rx_frame_mgmt(struct ieee80211_device *ieee, struct sk_buff *skb,     struct ieee80211_rx_stats *rx_stats, u16 type, u16 stype)   {

}

6、帧类型的定义

#define IEEE80211_FTYPE_MGMT  0x0000   // 管理帧

#define IEEE80211_FTYPE_CTL  0x0004     // 控制帧

#define IEEE80211_FTYPE_DATA  0x0008   // 数据帧

7、从跟ap连接的sta中查找相关

sta static struct sta_info* ap_get_sta(struct ap_data *ap, u8 *sta)

{

struct sta_info *s;

s = ap->sta_hash[STA_HASH(sta)];

while (s != NULL && memcmp(s->addr, sta, ETH_ALEN) != 0)

s = s->hnext;

return s;

}

时间: 2024-08-30 18:27:11

ieee80211_rx的相关文章

Linux 内核无线子系统

Linux 内核无线子系统 浅谈 Linux 内核无线子系统 Table of Contents 1. 全局概览 2. 模块间接口 3. 数据路径与管理路径 4. 数据包是如何被发送? 5. 谈谈管理路径 6. 数据包又是如何被接收? 7. 总结一下 Linux 内核是如何实现无线网络接口呢?数据包是通过怎样的方式被发送和接收呢?刚开始工作接触 Linux 无线网络时,我曾迷失在浩瀚的基础代码中,寻找具有介绍性的材料来回答如上面提到的那些高层次的问题.跟踪探索了一段时间的源代码后,我写下了这篇总

OpenWRT数据接收过程【Linux内核-OpenWRT】

OpenWRT数据接收过程 这里使用的是ath9k网卡驱动,硬件平台是TP-link TL-WR841N V7.1 路由器 1.  ieee80211_tasklet_handler() Linux内核是通过中断来对接收到的数据进行响应的.当硬件检测到有接收数据的时候,产生一个中断,中断触发下半部的tasklet机制,在802.11协议栈这里会调用ieee80211_tasklet_handler()函数.我们来看一看函数体:(位于OpenWRT内核文件夹子目录/net/mac80211,文件m

(转)浅谈 Linux 内核无线子系统

前言 Linux 内核是如何实现无线网络接口呢?数据包是通过怎样的方式被发送和接收呢? 刚开始工作接触 Linux 无线网络时,我曾迷失在浩瀚的基础代码中,寻找具有介绍性的材料来回答如上面提到的那些高层次的问题. 跟踪探索了一段时间的源代码后,我写下了这篇总结,希望在 Linux 无线网络的工作原理上,读者能从这篇文章获得一个具有帮助性的概览. 1.全局概览 在开始探索 Linux 无线具体细节之前,让我们先来把握一下 Linux 无线子系统整体结构.如图1,展示了 Linux 无线子系统各个模