123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- /*
- * Copyright (c) 2016 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 cdp_txrx_raw.h
- * @brief Define the host data path raw mode API functions
- * called by the host control SW and the OS interface module
- */
- #ifndef _CDP_TXRX_RAW_H_
- #define _CDP_TXRX_RAW_H_
- #include "cdp_txrx_ops.h"
- /* TODO: adf need to be replaced with qdf */
- static inline int cdp_get_nwifi_mode(ol_txrx_soc_handle soc,
- void *vdev)
- {
- if (soc->ops->raw_ops->txrx_get_nwifi_mode)
- return soc->ops->raw_ops->txrx_get_nwifi_mode(vdev);
- return 0;
- }
- /* Questionable -- should this be in OL AND/OR is this used? */
- /* Called by ol_tx_ll_umac_raw_process() */
- /**
- * @brief encap nbuf(s) from Ethernet II format to 802.11 Raw format
- * @details
- * Note that in the case of IP fragments, the function takes two fragments at a
- * time and creates an A-MSDU. If it has seen the first of such fragments, it
- * returns 0 to indicate that it needs to consume one more. In this case, the
- * caller shouldn't pass the nbuf to lower layers.
- * The function is simple and doesn't dynamically take decisions on A-MSDU
- * formation. It can be extended to pack more fragments into an A-MSDU if
- * required, but in this case there can be greater losses due to the
- * environment. The objective of the function is only to simulate regular
- * scatter/gather.
- *
- * @param vdev - the data virtual device object
- * @param pnbuf - pointer to nbuf
- *
- * @return - 0 on success, -1 on error, 1 if more nbufs need to be consumed.
- */
- static inline int
- cdp_rsim_tx_encap(ol_txrx_soc_handle soc,
- void *vdev, qdf_nbuf_t *pnbuf)
- {
- if (soc->ops->raw_ops->rsim_tx_encap)
- return soc->ops->raw_ops->rsim_tx_encap(vdev, pnbuf);
- return 0;
- }
- #endif
|