/*
* Copyright (C) 2014 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __WIFI_HAL_NAN_COMMAND_H__
#define __WIFI_HAL_NAN_COMMAND_H__
#include "common.h"
#include "cpp_bindings.h"
#include "wifi_hal.h"
#include "vendor_definitions.h"
#include "nan_cert.h"
class NanCommand : public WifiVendorCommand
{
private:
NanCallbackHandler mHandler;
char *mNanVendorEvent;
u32 mNanDataLen;
NanStaParameter *mStaParam;
//Function to check the initial few bytes of data to
//determine whether NanResponse or NanEvent
int isNanResponse();
//Function which unparses the data and calls the NotifyResponse
int handleNanResponse();
//Function which will parse the mVendorData and gets
// the rsp_data appropriately.
int getNanResponse(transaction_id *id, NanResponseMsg *pRsp);
//Function which will return the Nan Indication type based on
//the initial few bytes of mVendorData
NanIndicationType getIndicationType();
//Function which calls the necessaryIndication callback
//based on the indication type
int handleNanIndication();
//Various Functions to get the appropriate indications
int getNanPublishReplied(NanPublishRepliedInd *event);
int getNanPublishTerminated(NanPublishTerminatedInd *event);
int getNanMatch(NanMatchInd *event);
int getNanMatchExpired(NanMatchExpiredInd *event);
int getNanSubscribeTerminated(NanSubscribeTerminatedInd *event);
int getNanFollowup(NanFollowupInd *event);
int getNanDiscEngEvent(NanDiscEngEventInd *event);
int getNanDisabled(NanDisabledInd *event);
int getNanTca(NanTCAInd *event);
int getNanBeaconSdfPayload(NanBeaconSdfPayloadInd *event);
//Internal cleanup function
void cleanup();
static NanCommand *mNanCommandInstance;
// Other private helper functions
int calcNanTransmitPostDiscoverySize(
const NanTransmitPostDiscovery *pPostDiscovery);
void fillNanSocialChannelParamVal(
const NanSocialChannelScanParams *pScanParams,
u32* pChannelParamArr);
u32 getNanTransmitPostConnectivityCapabilityVal(
const NanTransmitPostConnectivityCapability *pCapab);
void fillNanTransmitPostDiscoveryVal(
const NanTransmitPostDiscovery *pTxDisc,
u8 *pOutValue);
int calcNanFurtherAvailabilityMapSize(
const NanFurtherAvailabilityMap *pFam);
void fillNanFurtherAvailabilityMapVal(
const NanFurtherAvailabilityMap *pFam,
u8 *pOutValue);
void getNanReceivePostConnectivityCapabilityVal(
const u8* pInValue,
NanReceivePostConnectivityCapability *pRxCapab);
void getNanReceiveSdeaCtrlParams(const u8* pInValue,
NanSdeaCtrlParams *pPeerSdeaParams);
int getNanReceivePostDiscoveryVal(const u8 *pInValue,
u32 length,
NanReceivePostDiscovery *pRxDisc);
int getNanFurtherAvailabilityMap(const u8 *pInValue,
u32 length,
u8* num_chans,
NanFurtherAvailabilityChannel *pFac);
void handleNanStatsResponse(NanStatsType stats_type,
char* rspBuf,
NanStatsResponse *pRsp,
u32 message_len);
//Function which unparses the data and calls the NotifyResponse
int handleNdpResponse(NanResponseType ndpCmdtyp, struct nlattr **tb_vendor);
int handleNdpIndication(u32 ndpCmdType, struct nlattr **tb_vendor);
int getNdpRequest(struct nlattr **tb_vendor, NanDataPathRequestInd *event);
int getNdpConfirm(struct nlattr **tb_vendor, NanDataPathConfirmInd *event);
int getNdpEnd(struct nlattr **tb_vendor, NanDataPathEndInd *event);
int getNanTransmitFollowupInd(NanTransmitFollowupInd *event);
int getNanRangeRequestReceivedInd(NanRangeRequestInd *event);
int getNanRangeReportInd(NanRangeReportInd *event);
int getNdpScheduleUpdate(struct nlattr **tb_vendor, NanDataPathScheduleUpdateInd *event);
public:
NanCommand(wifi_handle handle, int id, u32 vendor_id, u32 subcmd);
static NanCommand* instance(wifi_handle handle);
virtual ~NanCommand();
// This function implements creation of NAN specific Request
// based on the request type
virtual wifi_error create();
virtual wifi_error requestEvent();
virtual int handleResponse(WifiEvent &reply);
virtual int handleEvent(WifiEvent &event);
wifi_error setCallbackHandler(NanCallbackHandler nHandler);
//Functions to fill the vendor data appropriately
wifi_error putNanEnable(transaction_id id, const NanEnableRequest *pReq);
wifi_error putNanDisable(transaction_id id);
wifi_error putNanPublish(transaction_id id, const NanPublishRequest *pReq);
wifi_error putNanPublishCancel(transaction_id id, const NanPublishCancelRequest *pReq);
wifi_error putNanSubscribe(transaction_id id, const NanSubscribeRequest *pReq);
wifi_error putNanSubscribeCancel(transaction_id id, const NanSubscribeCancelRequest *pReq);
wifi_error putNanTransmitFollowup(transaction_id id, const NanTransmitFollowupRequest *pReq);
wifi_error putNanStats(transaction_id id, const NanStatsRequest *pReq);
wifi_error putNanConfig(transaction_id id, const NanConfigRequest *pReq);
wifi_error putNanTCA(transaction_id id, const NanTCARequest *pReq);
wifi_error putNanBeaconSdfPayload(transaction_id id, const NanBeaconSdfPayloadRequest *pReq);
wifi_error getNanStaParameter(wifi_interface_handle iface, NanStaParameter *pRsp);
wifi_error putNanCapabilities(transaction_id id);
wifi_error putNanDebugCommand(NanDebugParams debug, int debug_msg_length);
/* Functions for NAN error translation
For NanResponse, NanPublishTerminatedInd, NanSubscribeTerminatedInd,
NanDisabledInd, NanTransmitFollowupInd:
function to translate firmware specific errors
to generic freamework error along with the error string
*/
void NanErrorTranslation(NanInternalStatusType firmwareErrorRecvd,
u32 valueRcvd,
void *pRsp,
bool is_ndp_rsp);
};
#endif /* __WIFI_HAL_NAN_COMMAND_H__ */