Linux Audio

Check our new training course

Loading...
v6.8
 1/* SPDX-License-Identifier: GPL-2.0-only */
 2/*
 3 * Data transmitting implementation.
 4 *
 5 * Copyright (c) 2017-2020, Silicon Laboratories, Inc.
 6 * Copyright (c) 2010, ST-Ericsson
 7 */
 8#ifndef WFX_DATA_TX_H
 9#define WFX_DATA_TX_H
10
11#include <linux/list.h>
12#include <net/mac80211.h>
13
14#include "hif_api_cmd.h"
15#include "hif_api_mib.h"
16
17struct wfx_tx_priv;
18struct wfx_dev;
19struct wfx_vif;
20
21struct wfx_tx_policy {
22	struct list_head link;
23	int usage_count;
24	u8 rates[12];
25	bool uploaded;
26};
27
28struct wfx_tx_policy_cache {
29	struct wfx_tx_policy cache[HIF_TX_RETRY_POLICY_MAX];
30	/* FIXME: use a trees and drop hash from tx_policy */
31	struct list_head used;
32	struct list_head free;
33	spinlock_t lock;
34};
35
36struct wfx_tx_priv {
37	ktime_t xmit_timestamp;
38	unsigned char icv_size;
39	unsigned char vif_id;
40};
41
42void wfx_tx_policy_init(struct wfx_vif *wvif);
43void wfx_tx_policy_upload_work(struct work_struct *work);
44
45void wfx_tx(struct ieee80211_hw *hw, struct ieee80211_tx_control *control, struct sk_buff *skb);
46void wfx_tx_confirm_cb(struct wfx_dev *wdev, const struct wfx_hif_cnf_tx *arg);
47void wfx_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif, u32 queues, bool drop);
48
49struct wfx_tx_priv *wfx_skb_tx_priv(struct sk_buff *skb);
50struct wfx_hif_req_tx *wfx_skb_txreq(struct sk_buff *skb);
51struct wfx_vif *wfx_skb_wvif(struct wfx_dev *wdev, struct sk_buff *skb);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
52
53#endif
v6.2
 1/* SPDX-License-Identifier: GPL-2.0-only */
 2/*
 3 * Data transmitting implementation.
 4 *
 5 * Copyright (c) 2017-2020, Silicon Laboratories, Inc.
 6 * Copyright (c) 2010, ST-Ericsson
 7 */
 8#ifndef WFX_DATA_TX_H
 9#define WFX_DATA_TX_H
10
11#include <linux/list.h>
12#include <net/mac80211.h>
13
14#include "hif_api_cmd.h"
15#include "hif_api_mib.h"
16
17struct wfx_tx_priv;
18struct wfx_dev;
19struct wfx_vif;
20
21struct wfx_tx_policy {
22	struct list_head link;
23	int usage_count;
24	u8 rates[12];
25	bool uploaded;
26};
27
28struct wfx_tx_policy_cache {
29	struct wfx_tx_policy cache[HIF_TX_RETRY_POLICY_MAX];
30	/* FIXME: use a trees and drop hash from tx_policy */
31	struct list_head used;
32	struct list_head free;
33	spinlock_t lock;
34};
35
36struct wfx_tx_priv {
37	ktime_t xmit_timestamp;
38	unsigned char icv_size;
 
39};
40
41void wfx_tx_policy_init(struct wfx_vif *wvif);
42void wfx_tx_policy_upload_work(struct work_struct *work);
43
44void wfx_tx(struct ieee80211_hw *hw, struct ieee80211_tx_control *control, struct sk_buff *skb);
45void wfx_tx_confirm_cb(struct wfx_dev *wdev, const struct wfx_hif_cnf_tx *arg);
46void wfx_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif, u32 queues, bool drop);
47
48static inline struct wfx_tx_priv *wfx_skb_tx_priv(struct sk_buff *skb)
49{
50	struct ieee80211_tx_info *tx_info;
51
52	if (!skb)
53		return NULL;
54	tx_info = IEEE80211_SKB_CB(skb);
55	return (struct wfx_tx_priv *)tx_info->rate_driver_data;
56}
57
58static inline struct wfx_hif_req_tx *wfx_skb_txreq(struct sk_buff *skb)
59{
60	struct wfx_hif_msg *hif = (struct wfx_hif_msg *)skb->data;
61	struct wfx_hif_req_tx *req = (struct wfx_hif_req_tx *)hif->body;
62
63	return req;
64}
65
66#endif