70b7d94bcc
TDLS connections require dedicated flowrings. This patches adds TDLS event handling and flowring creation/deletion based on these events. Reviewed-by: Franky (Zhenhui) Lin <frankyl@broadcom.com> Reviewed-by: Pieter-Paul Giesberts <pieterpg@broadcom.com> Reviewed-by: Daniel (Deognyoun) Kim <dekim@broadcom.com> Signed-off-by: Hante Meuleman <meuleman@broadcom.com> Signed-off-by: Arend van Spriel <arend@broadcom.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
85 lines
2.8 KiB
C
85 lines
2.8 KiB
C
/* Copyright (c) 2014 Broadcom Corporation
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
|
* SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
|
|
* OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
#ifndef BRCMFMAC_FLOWRING_H
|
|
#define BRCMFMAC_FLOWRING_H
|
|
|
|
|
|
#define BRCMF_FLOWRING_HASHSIZE 256
|
|
#define BRCMF_FLOWRING_INVALID_ID 0xFFFFFFFF
|
|
|
|
|
|
struct brcmf_flowring_hash {
|
|
u8 mac[ETH_ALEN];
|
|
u8 fifo;
|
|
u8 ifidx;
|
|
u8 flowid;
|
|
};
|
|
|
|
enum ring_status {
|
|
RING_CLOSED,
|
|
RING_CLOSING,
|
|
RING_OPEN
|
|
};
|
|
|
|
struct brcmf_flowring_ring {
|
|
u8 hash_id;
|
|
bool blocked;
|
|
enum ring_status status;
|
|
struct sk_buff_head skblist;
|
|
};
|
|
|
|
struct brcmf_flowring_tdls_entry {
|
|
u8 mac[ETH_ALEN];
|
|
struct brcmf_flowring_tdls_entry *next;
|
|
};
|
|
|
|
struct brcmf_flowring {
|
|
struct device *dev;
|
|
struct brcmf_flowring_hash hash[BRCMF_FLOWRING_HASHSIZE];
|
|
struct brcmf_flowring_ring **rings;
|
|
spinlock_t block_lock;
|
|
enum proto_addr_mode addr_mode[BRCMF_MAX_IFS];
|
|
u16 nrofrings;
|
|
bool tdls_active;
|
|
struct brcmf_flowring_tdls_entry *tdls_entry;
|
|
};
|
|
|
|
|
|
u32 brcmf_flowring_lookup(struct brcmf_flowring *flow, u8 da[ETH_ALEN],
|
|
u8 prio, u8 ifidx);
|
|
u32 brcmf_flowring_create(struct brcmf_flowring *flow, u8 da[ETH_ALEN],
|
|
u8 prio, u8 ifidx);
|
|
void brcmf_flowring_delete(struct brcmf_flowring *flow, u8 flowid);
|
|
void brcmf_flowring_open(struct brcmf_flowring *flow, u8 flowid);
|
|
u8 brcmf_flowring_tid(struct brcmf_flowring *flow, u8 flowid);
|
|
void brcmf_flowring_enqueue(struct brcmf_flowring *flow, u8 flowid,
|
|
struct sk_buff *skb);
|
|
struct sk_buff *brcmf_flowring_dequeue(struct brcmf_flowring *flow, u8 flowid);
|
|
void brcmf_flowring_reinsert(struct brcmf_flowring *flow, u8 flowid,
|
|
struct sk_buff *skb);
|
|
u32 brcmf_flowring_qlen(struct brcmf_flowring *flow, u8 flowid);
|
|
u8 brcmf_flowring_ifidx_get(struct brcmf_flowring *flow, u8 flowid);
|
|
struct brcmf_flowring *brcmf_flowring_attach(struct device *dev, u16 nrofrings);
|
|
void brcmf_flowring_detach(struct brcmf_flowring *flow);
|
|
void brcmf_flowring_configure_addr_mode(struct brcmf_flowring *flow, int ifidx,
|
|
enum proto_addr_mode addr_mode);
|
|
void brcmf_flowring_delete_peer(struct brcmf_flowring *flow, int ifidx,
|
|
u8 peer[ETH_ALEN]);
|
|
void brcmf_flowring_add_tdls_peer(struct brcmf_flowring *flow, int ifidx,
|
|
u8 peer[ETH_ALEN]);
|
|
|
|
|
|
#endif /* BRCMFMAC_FLOWRING_H */
|