blob: 805bb1e7067094d07ae1293c66157c7cbf51fe60 [file] [log] [blame]
/*
* Copyright (c) 2011-2013, 2016-2017 The Linux Foundation. All rights reserved.
*
* Previously licensed under the ISC license by Qualcomm Atheros, Inc.
*
*
* 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.
*/
/*
* This file was originally distributed by Qualcomm Atheros, Inc.
* under proprietary terms before Copyright ownership was assigned
* to the Linux Foundation.
*/
/**
* @file ol_txrx_api.h
* @brief Definitions used in multiple external interfaces to the txrx SW.
*/
#ifndef _OL_TXRX_API__H_
#define _OL_TXRX_API__H_
/**
* @typedef ol_txrx_pdev_handle
* @brief opaque handle for txrx physical device object
*/
struct ol_txrx_pdev_t;
typedef struct ol_txrx_pdev_t* ol_txrx_pdev_handle;
/**
* @typedef ol_txrx_vdev_handle
* @brief opaque handle for txrx virtual device object
*/
struct ol_txrx_vdev_t;
typedef struct ol_txrx_vdev_t* ol_txrx_vdev_handle;
/**
* @typedef ol_txrx_peer_handle
* @brief opaque handle for txrx peer object
*/
struct ol_txrx_peer_t;
typedef struct ol_txrx_peer_t* ol_txrx_peer_handle;
/**
* @brief ADDBA negotiation status, used both during requests and confirmations
*/
enum ol_addba_status {
/* status: negotiation started or completed successfully */
ol_addba_success,
/* reject: aggregation is not applicable - don't try again */
ol_addba_reject,
/* busy: ADDBA negotiation couldn't be performed - try again later */
ol_addba_busy,
};
enum pn_replay_type {
OL_RX_TKIP_REPLAYS,
OL_RX_CCMP_REPLAYS,
OL_RX_OTHER_REPLAYS,
/* total replays */
OL_RX_NUM_PN_REPLAY_TYPES
};
enum ol_sec_type {
ol_sec_type_none,
ol_sec_type_wep128,
ol_sec_type_wep104,
ol_sec_type_wep40,
ol_sec_type_tkip,
ol_sec_type_tkip_nomic,
ol_sec_type_aes_ccmp,
ol_sec_type_wapi,
/* keep this last! */
ol_sec_type_types
};
/**
* @enum ol_tx_spec
* @brief indicate what non-standard transmission actions to apply
* @details
* Indicate one or more of the following:
* - The tx frame already has a complete 802.11 header.
* Thus, skip 802.3/native-WiFi to 802.11 header encapsulation and
* A-MSDU aggregation.
* - The tx frame should not be aggregated (A-MPDU or A-MSDU)
* - The tx frame is already encrypted - don't attempt encryption.
* - The tx frame is a segment of a TCP jumbo frame.
* - This tx frame should not be unmapped and freed by the txrx layer
* after transmission, but instead given to a registered tx completion
* callback.
* More than one of these specification can apply, though typically
* only a single specification is applied to a tx frame.
* A compound specification can be created, as a bit-OR of these
* specifications.
*/
enum ol_tx_spec {
ol_tx_spec_std = 0x0, /* do regular processing */
ol_tx_spec_raw = 0x1, /* skip encap + A-MSDU aggr */
ol_tx_spec_no_aggr = 0x2, /* skip encap + all aggr */
ol_tx_spec_no_encrypt = 0x4, /* skip encap + encrypt */
ol_tx_spec_tso = 0x8, /* TCP segmented */
ol_tx_spec_nwifi_no_encrypt = 0x10, /* skip encrypt for nwifi */
ol_tx_spec_no_free = 0x20, /* give to cb rather than free */
};
typedef void (*tp_ol_packetdump_cb)(adf_nbuf_t netbuf,
uint8_t status, uint8_t vdev_id, uint8_t type);
void ol_register_packetdump_callback(tp_ol_packetdump_cb ol_tx_packetdump_cb,
tp_ol_packetdump_cb ol_rx_packetdump_cb);
void ol_deregister_packetdump_callback(void);
#ifdef WLAN_FEATURE_TSF_PLUS
typedef int (*tp_ol_timestamp_cb)(adf_nbuf_t netbuf, uint64_t target_time);
/**
* ol_register_timestamp_callback() - set callbacks for timestamp tx msdu.
* @ol_tx_timestamp_cb: callback function for time stamp tx msdu
*
* This function register timestamp callback, the callback will
* be called when tx a msdu
*
* Return: nothing
*/
void ol_register_timestamp_callback(tp_ol_timestamp_cb ol_tx_timestamp_cb);
/**
* ol_deregister_timestamp_callback() - reset callbacks for timestamp
* tx msdu to NULL.
*
* This function reset the timestamp callbacks for tx
*
* Return: nothing
*/
void ol_deregister_timestamp_callback(void);
#endif
#endif /* _OL_TXRX_API__H_ */