blob: 650dbcebde5fc4492a36181a026608bebf991c1a [file] [log] [blame]
Jeff Johnson295189b2012-06-20 16:38:30 -07001/*
Kiet Lam842dad02014-02-18 18:44:02 -08002 * Copyright (c) 2012-2013 The Linux Foundation. All rights reserved.
3 *
4 * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
5 *
6 *
7 * Permission to use, copy, modify, and/or distribute this software for
8 * any purpose with or without fee is hereby granted, provided that the
9 * above copyright notice and this permission notice appear in all
10 * copies.
11 *
12 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
13 * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
14 * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
15 * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
16 * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
17 * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
18 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
19 * PERFORMANCE OF THIS SOFTWARE.
Gopichand Nakkala92f07d82013-01-08 21:16:34 -080020 */
Kiet Lam842dad02014-02-18 18:44:02 -080021
22/*
23 * This file was originally distributed by Qualcomm Atheros, Inc.
24 * under proprietary terms before Copyright ownership was assigned
25 * to the Linux Foundation.
26 */
27
Jeff Johnson295189b2012-06-20 16:38:30 -070028#if !defined( __BAPRSN_TXRX_H )
29#define __BAPRSN_TXRX_H
30
31/**=============================================================================
32
33 bapRsnTxRx.h
34
35 \brief
36
37 Description...
38
39
Jeff Johnson295189b2012-06-20 16:38:30 -070040
41 ==============================================================================*/
42
43#include "vos_types.h"
44#include "vos_status.h"
45#include "vos_packet.h"
46#include "bapRsnAsfPacket.h"
47
48
49typedef int (*pnfTxCompleteHandler)( v_PVOID_t pvosGCtx, vos_pkt_t *pPacket, VOS_STATUS retStatus );
50typedef int (*pnfRxFrameHandler)( v_PVOID_t pvosGCtx, vos_pkt_t *pPacket );
51
52/*
53 \brief bapRsnSendEapolFrame
54 To push an eapol frame to TL.
55
56 \param pAniPkt - a ready eapol frame that is prepared in tAniPacket format
57*/
58VOS_STATUS bapRsnSendEapolFrame( v_PVOID_t pvosGCtx, tAniPacket *pAniPkt );
59
60
61/*
62 \brief bapRsnRegisterTxRxCallbacks
63 To register two callbacks for txcomplete and rxFrames .
64
65 \param pfnTxCom - pointer to a function to handle the tx completion.
66 \param pnfRxFrame - point to a function to handle rx frames
67*/
68VOS_STATUS bapRsnRegisterTxRxCallbacks( pnfTxCompleteHandler pfnTxCom, pnfRxFrameHandler pnfRxFrame );
69
70//To set the callbaks to NULL so it can be change later
71void bapRsnClearTxRxCallbacks(void);
72
73/*
74 \brief bapRsnRegisterRxCallback
75 To register the RX frame callbacks to TL to receive EAPOL frames .
76
77 \param pvosGCtx - pointer to global VOSS context.
78*/
79VOS_STATUS bapRsnRegisterRxCallback( v_PVOID_t pvosGCtx );
80
81VOS_STATUS bapRsnRxCallback(v_PVOID_t pv, vos_pkt_t *pPacket);
82
83#endif //__BAPRSN_TXRX_H
84
85
86
87