diff options
-rw-r--r-- | include/hardware_legacy/nan.h | 877 | ||||
-rw-r--r-- | include/hardware_legacy/wifi_hal.h | 1 |
2 files changed, 0 insertions, 878 deletions
diff --git a/include/hardware_legacy/nan.h b/include/hardware_legacy/nan.h deleted file mode 100644 index 4bb6e26..0000000 --- a/include/hardware_legacy/nan.h +++ /dev/null @@ -1,877 +0,0 @@ -/* - * 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 __NAN_H__ -#define __NAN_H__ - -#include "wifi_hal.h" - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ - -/***************************************************************************** - * Neighbour Aware Network Service Structures and Functions - *****************************************************************************/ - -/* - Definitions - All multi-byte fields within all NAN protocol stack messages are assumed to be in Little Endian order. -*/ - -typedef int NanVersion; - -#define NAN_MAC_ADDR_LEN 6 -#define NAN_COUNTRY_STRING_LEN 3 -#define NAN_MAJOR_VERSION 1 -#define NAN_MINOR_VERSION 0 -#define NAN_MICRO_VERSION 0 - -/* NAN Maximum Lengths */ -#define NAN_MAX_SERVICE_NAME_LEN 255 -#define NAN_MAX_MATCH_FILTER_LEN 255 -#define NAN_MAX_SERVICE_SPECIFIC_INFO_LEN 1024 - -/* - Definition of various NanRequestType -*/ -typedef enum { - NAN_REQUEST_ENABLE =0, - NAN_REQUEST_DISABLE =1, - NAN_REQUEST_PUBLISH =2, - NAN_REQUEST_PUBLISH_CANCEL =3, - NAN_REQUEST_TRANSMIT_FOLLOWUP =4, - NAN_REQUEST_SUBSCRIBE =5, - NAN_REQUEST_SUBSCRIBE_CANCEL =6, - NAN_REQUEST_STATS =7, - NAN_REQUEST_CONFIG =8, - NAN_REQUEST_TCA =9, - NAN_REQUEST_LAST =0xFFFF -} NanRequestType; - -/* - Definition of various NanResponseType -*/ -typedef enum { - NAN_RESPONSE_ENABLED =0, - NAN_RESPONSE_DISABLED =1, - NAN_RESPONSE_PUBLISH =2, - NAN_RESPONSE_PUBLISH_CANCEL =3, - NAN_RESPONSE_TRANSMIT_FOLLOWUP =4, - NAN_RESPONSE_SUBSCRIBE =5, - NAN_RESPONSE_SUBSCRIBE_CANCEL =6, - NAN_RESPONSE_STATS =7, - NAN_RESPONSE_CONFIG =8, - NAN_RESPONSE_TCA =9, - NAN_RESPONSE_ERROR =10, - NAN_RESPONSE_UNKNOWN =0xFFFF -} NanResponseType; - -/* - Definition of various NanIndication(events) -*/ -typedef enum { - NAN_INDICATION_PUBLISH_REPLIED =0, - NAN_INDICATION_PUBLISH_TERMINATED =1, - NAN_INDICATION_SUBSCRIBE_MATCH =2, - NAN_INDICATION_SUBSCRIBE_UNMATCH =3, - NAN_INDICATION_SUBSCRIBE_TERMINATED =4, - NAN_INDICATION_DE_EVENT =5, - NAN_INDICATION_FOLLOWUP =6, - NAN_INDICATION_DISABLED =7, - NAN_INDICATION_TCA =8, - NAN_INDICATION_UNKNOWN =0xFFFF -} NanIndicationType; - - -/* NAN Publish Types */ -typedef enum { - NAN_PUBLISH_TYPE_UNSOLICITED = 0, - NAN_PUBLISH_TYPE_SOLICITED, - NAN_PUBLISH_TYPE_UNSOLICITED_SOLICITED, - NAN_PUBLISH_TYPE_LAST, -} NanPublishType; - -/* NAN Transmit Priorities */ -typedef enum { - NAN_TX_PRIORITY_LOW = 0, - NAN_TX_PRIORITY_NORMAL, - NAN_TX_PRIORITY_HIGH, - NAN_TX_PRIORITY_LAST -} NanTxPriority; - -/* NAN Statistics Request ID Codes */ -typedef enum -{ - NAN_STATS_ID_FIRST = 0, - NAN_STATS_ID_DE_PUBLISH = NAN_STATS_ID_FIRST, - NAN_STATS_ID_DE_SUBSCRIBE, - NAN_STATS_ID_DE_MAC, - NAN_STATS_ID_DE_TIMING_SYNC, - NAN_STATS_ID_DE_DW, - NAN_STATS_ID_DE, - NAN_STATS_ID_LAST -} NanStatsId; - -/* NAN Protocol Event ID Codes */ -typedef enum -{ - NAN_EVENT_ID_FIRST = 0, - NAN_EVENT_ID_SELF_STA_MAC_ADDR = NAN_EVENT_ID_FIRST, - NAN_EVENT_ID_STARTED_CLUSTER, - NAN_EVENT_ID_JOINED_CLUSTER, - NAN_EVENT_ID_LAST -} NanEventId; - -/* TCA IDs */ -typedef enum -{ - NAN_TCA_ID_FIRST = 0, - NAN_TCA_ID_CLUSTER_SIZE = NAN_TCA_ID_FIRST, - NAN_TCA_ID_LAST -} NanTcaId; - -/* - Various NAN Protocol Response code -*/ -typedef enum -{ - /* NAN Protocol Response Codes */ - NAN_STATUS_SUCCESS = 0, - NAN_STATUS_TIMEOUT, - NAN_STATUS_DE_FAILURE, - NAN_STATUS_INVALID_MSG_VERSION, - NAN_STATUS_INVALID_MSG_LEN, - NAN_STATUS_INVALID_MSG_ID, - NAN_STATUS_INVALID_HANDLE, - NAN_STATUS_NO_SPACE_AVAILABLE, - NAN_STATUS_INVALID_PUBLISH_TYPE, - NAN_STATUS_INVALID_TX_TYPE, - NAN_STATUS_INVALID_MATCH_ALGORITHM, - NAN_STATUS_DISABLE_IN_PROGRESS, - NAN_STATUS_INVALID_TLV_LEN, - NAN_STATUS_INVALID_TLV_TYPE, - NAN_STATUS_MISSING_TLV_TYPE, - NAN_STATUS_INVALID_TOTAL_TLVS_LEN, - NAN_STATUS_INVALID_MATCH_HANDLE, - NAN_STATUS_INVALID_TLV_VALUE, - NAN_STATUS_INVALID_TX_PRIORITY, - NAN_STATUS_INVALID_TCA_ID, - NAN_STATUS_INVALID_STATS_ID, - - /* NAN Configuration Response codes */ - NAN_STATUS_INVALID_RSSI_CLOSE_VALUE = 128, - NAN_STATUS_INVALID_RSSI_MEDIUM_VALUE, - NAN_STATUS_INVALID_HOP_COUNT_LIMIT, - NAN_STATUS_INVALID_CLUSTER_JOIN_COUNT, - NAN_STATUS_INVALID_MIN_WAKE_DW_DURATION_VALUE, - NAN_STATUS_INVALID_OFDM_DATA_RATE_VALUE, - NAN_STATUS_INVALID_RANDOM_FACTOR_UPDATE_TIME_VALUE, - NAN_STATUS_INVALID_MASTER_PREFERENCE_VALUE, - NAN_STATUS_INVALID_EARLY_DW_WAKE_INTERVAL_VALUE, - NAN_STATUS_INVALID_LOW_CLUSTER_ID_VALUE, - NAN_STATUS_INVALID_HIGH_CLUSTER_ID_VALUE, - NAN_STATUS_INVALID_INITIAL_SCAN_PERIOD, - NAN_STATUS_INVALID_ONGOING_SCAN_PERIOD, - NAN_STATUS_INVALID_RSSI_PROXIMITY_VALUE -} NanStatusType; - -/* - Various NAN Terminated Indication Code -*/ -typedef enum -{ - NAN_TERMINATED_REASON_INVALID = 0, - NAN_TERMINATED_REASON_TIMEOUT, - NAN_TERMINATED_REASON_USER_REQUEST, - NAN_TERMINATED_REASON_FAILURE, - NAN_TERMINATED_REASON_COUNT_REACHED, - NAN_TERMINATED_REASON_DE_SHUTDOWN, - NAN_TERMINATED_REASON_DISABLE_IN_PROGRESS -} NanTerminatedStatus; - -/* NAN Transmit Types */ -typedef enum -{ - NAN_TX_TYPE_BROADCAST = 0, - NAN_TX_TYPE_UNICAST, - NAN_TX_TYPE_LAST -} NanTxType; - -/* NAN Subscribe Type Bit */ -#define NAN_SUBSCRIBE_TYPE_PASSIVE 0 -#define NAN_SUBSCRIBE_TYPE_ACTIVE 1 - -/* NAN Service Response Filter Attribute Bit */ -#define NAN_SRF_ATTR_BLOOM_FILTER 0 -#define NAN_SRF_ATTR_PARTIAL_MAC_ADDR 1 - -/* NAN Service Response Filter Include Bit */ -#define NAN_SRF_INCLUDE_DO_NOT_RESPOND 0 -#define NAN_SRF_INCLUDE_RESPOND 1 - -/* NAN Match Algorithms */ -typedef enum -{ - NAN_MATCH_ALG_FIRST = 0, - NAN_MATCH_ALG_MATCH_ONCE = NAN_MATCH_ALG_FIRST, - NAN_MATCH_ALG_MATCH_CONTINUOUS, - NAN_MATCH_ALG_LAST -} NanMatchAlg; - -/* NAN Header */ -typedef struct { - /* - 16-bit quantity which is allocated by the FW. - Pass the Handle as 0xFFFF if the Host would like to set up a new - Publish/Subscribe and the FW will pass back a valid handle in response msg. - To update an already opened Publish/Subscribe Host can pass a Handle - which has already been allocated by the FW. - */ - u16 handle; - - /* - 16-bit quantity which is allocated in 2 contexts. For all Request - messages the TransactionId is allocated by the Service Layer and - passed down to the DE. In all Indication messages the TransactionId - field is allocated by the DE. There is no correlation between the - TransactionIds allocated by the Service Layer and those allocated by the DE - */ - u16 transaction_id; -} NanHeader; - -/* - Enable Request Message Structure - The NanEnableReq message instructs the Discovery Engine to enter an operational state -*/ -typedef struct { - NanHeader header; - u8 support_5g; /* default = 0 */ - u16 cluster_low; /* default = 0 */ - u16 cluster_high; /* default = 0 */ - u8 sid_beacon; /* default = 0x80 */ - u8 sync_disc_5g; /* default = 1 i.e 5G Discovery frames only*/ - u8 rssi_close; /* default = 60 (-60 dBm) */ - u8 rssi_middle; /* default = 70 (-70 dBm) */ - u8 rssi_proximity; /* default = 70 (-70 dBm) */ - u8 hop_count_limit; /* default = 2 */ - u8 random_time; /* default = 120 (DWs) */ - u8 master_pref; /* default = 0 */ - u8 periodic_scan_interval; /* default = 20 seconds */ - /* TBD: Google specific IE */ -} NanEnableRequest; - -/* - Disable Request Message Structure - The NanDisableReq message instructs the Discovery Engine to exit an operational state. -*/ -typedef struct { - NanHeader header; -} NanDisableRequest; - -/* - Publish Msg Structure - Message is used to request the DE to publish the Service Name - using the parameters passed into the Discovery Window -*/ -typedef struct { - NanHeader header; - u16 ttl; /* how many seconds to run for. 0 means forever until canceled */ - u16 period; /* periodicity of OTA unsolicited publish. Specified in increments of 500 ms */ - u8 replied_event_flag; /* 1= RepliedEventInd needed, 0 = Not needed */ - NanPublishType publish_type;/* 0= unsolicited, solicited = 1, 2= both */ - NanTxType tx_type; /* 0 = broadcast, 1= unicast if solicited publish */ - u8 publish_count; /* number of OTA Publish, 0 means forever until canceled */ - u16 service_name_len; /* length of service name */ - u8 service_name[NAN_MAX_SERVICE_NAME_LEN];/* UTF-8 encoded string identifying the service */ - - /* Sequence of values which should be conveyed to the Discovery Engine of a - NAN Device that has invoked a Subscribe method corresponding to this Publish method - */ - u16 service_specific_info_len; - u8 service_specific_info[NAN_MAX_SERVICE_SPECIFIC_INFO_LEN]; - - /* Ordered sequence of <length, value> pairs which specify further response conditions - beyond the service name used to filter subscribe messages to respond to. - This is only needed when the PT is set to NAN_SOLICITED or NAN_SOLICITED_UNSOLICITED. - */ - u16 rx_match_filter_len; - u8 rx_match_filter[NAN_MAX_MATCH_FILTER_LEN]; - - /* Ordered sequence of <length, value> pairs to be included in the Discovery Frame. - If present it is always sent in a Discovery Frame - */ - u16 tx_match_filter_len; - u8 tx_match_filter[NAN_MAX_MATCH_FILTER_LEN]; -} NanPublishRequest; - -/* - Publish Cancel Msg Structure - The PublishServiceCancelReq Message is used to request the DE to stop publishing - the Service Name identified by the handle in the message. -*/ -typedef struct { - NanHeader header; -} NanPublishCancelRequest; - -/* - NAN Subscribe Structure - The SubscribeServiceReq message is sent to the Discovery Engine - whenever the Upper layers would like to listen for a Service Name -*/ -typedef struct { - NanHeader header; - u16 ttl; /* how many seconds to run for. 0 means forever until canceled */ - u16 period;/* periodicity of OTA Active Subscribe. Units in increments of 500 ms , 0 = attempt every DW*/ - - /* Flag which specifies how the Subscribe request shall be processed. */ - u8 subscribe_type; /* 0 - PASSIVE , 1- ACTIVE */ - - /* Flag which specifies on Active Subscribes how the Service Response Filter attribute is populated.*/ - u8 serviceResponseFilter; /* 0 - Bloom Filter, 1 - MAC Addr */ - - /* Flag which specifies how the Service Response Filter Include bit is populated.*/ - u8 serviceResponseInclude; /* 0=Do not respond if in the Address Set, 1= Respond */ - - /* Flag which specifies if the Service Response Filter should be used when creating Subscribes.*/ - u8 useServiceResponseFilter; /* 0=Do not send the Service Response Filter,1= send */ - - /* Flag which specifies if the Service Specific Info is needed in the Publish message before creating the MatchIndication*/ - u8 ssiRequiredForMatchIndication; /* 0=Not needed, 1= Required */ - - /* Field which allows the matching behavior to be controlled. */ - NanMatchAlg subscribe_match; /* 0 - Match Once, 1 - Match continuous */ - - /* The number of Subscribe Matches which should occur before the Subscribe request is automatically terminated.*/ - u8 subscribe_count; /* If this value is 0 this field is not used by the DE.*/ - - u16 service_name_len;/* length of service name */ - u8 service_name[NAN_MAX_SERVICE_NAME_LEN]; /* UTF-8 encoded string identifying the service */ - - /* Sequence of values which further specify the published service beyond the service name*/ - u16 service_specific_info_len; - u8 service_specific_info[NAN_MAX_SERVICE_SPECIFIC_INFO_LEN]; - - /* Ordered sequence of <length, value> pairs used to filter out received publish discovery messages. - This can be sent both for a Passive or an Active Subscribe - */ - u16 rx_match_filter_len; - u8 rx_match_filter[NAN_MAX_MATCH_FILTER_LEN]; - - /* Ordered sequence of <length, value> pairs included in the Discovery Frame when an Active Subscribe is used.*/ - u16 tx_match_filter_len; - u8 tx_match_filter[NAN_MAX_MATCH_FILTER_LEN]; -} NanSubscribeRequest; - - -/* - NAN Subscribe Cancel Structure - The SubscribeCancelReq Message is used to request the DE to stop looking for the Service Name. -*/ -typedef struct { - NanHeader header; -} NanSubscribeCancelRequest; - - -/* - Transmit follow up Structure - The TransmitFollowupReq message is sent to the DE to allow the sending of the Service_Specific_Info - to a particular MAC address. -*/ -typedef struct { - NanHeader header; - u8 addr[NAN_MAC_ADDR_LEN]; /* Can be a broadcast/multicast or unicast address */ - NanTxPriority priority; /* priority of the request 0 = low, 1=normal, 2=high */ - u8 dw_or_faw; /* 0= send in a DW, 1=send in FAW */ - - /* Sequence of values which further specify the published service beyond the service name - Treated as service specific info in case dw_or_faw is set to 0 - Treated as extended service specific info in case dw_or_faw is set to non-zero*/ - u16 service_specific_info_len; - u8 service_specific_info[NAN_MAX_SERVICE_SPECIFIC_INFO_LEN]; -} NanTransmitFollowupRequest; - -/* - Stats Request structure - The Discovery Engine can be queried at runtime by the Host processor for statistics - concerning various parts of the Discovery Engine. -*/ -typedef struct { - NanHeader header; - NanStatsId stats_id; /* NAN Statistics Request ID Codes */ - u8 clear; /* 0= Do not clear the stats and return the current contents , 1= Clear the associated stats */ -} NanStatsRequest; - -/* - Config Structure - The NanConfigurationReq message is sent by the Host to the - Discovery Engine in order to configure the Discovery Engine during runtime. -*/ -typedef struct { - NanHeader header; - u8 sid_beacon; /* default = 0x80 */ - u8 sync_disc_5g; /* default = 1 i.e 5G Discovery frames only*/ - u8 rssi_proximity; /* default = 70 (-70 dBm) */ - u8 random_time; /* default = 120 (DWs) */ - u8 master_pref; /* default = 0 */ - u8 periodic_scan_interval; /* default = 20 seconds */ - /* The number of Additional Discovery Window slots in - increments of 16 ms. Since each DW is 512 TUs apart - and the DW takes up 1 slot, the maximum number of additional - slots which can be specified is 31. This is a hint to the - scheduler and there is no guarantee that all 31 slots will - be available because of MCC and BT Coexistence channel usage - */ - u8 additional_disc_window_slots; /* default = 0.*/ -} NanConfigRequest; - -/* - TCA Structure - The Discovery Engine can be configured to send up Events whenever a configured - Threshold Crossing Alert (TCA) Id crosses an integral threshold in a particular direction. -*/ -typedef struct { - NanHeader header; - NanTcaId tca_id; /* Nan Protocol Threshold Crossing Alert (TCA) Codes */ - - /* flag which control whether or not an event is generated for the Rising direction */ - u8 rising_direction_evt_flag; /* 0 - no event, 1 - event */ - - /* flag which control whether or not an event is generated for the Falling direction */ - u8 falling_direction_evt_flag;/* 0 - no event, 1 - event */ - - /* flag which requests a previous TCA request to be cleared from the DE */ - u8 clear;/*0= Do not clear the TCA, 1=Clear the TCA */ - - /* 32 bit value which represents the threshold to be used.*/ - u32 threshold; -} NanTCARequest; - -/* Publish statistics. */ -typedef struct -{ - u32 validPublishServiceReqMsgs; - u32 validPublishServiceRspMsgs; - u32 validPublishServiceCancelReqMsgs; - u32 validPublishServiceCancelRspMsgs; - u32 validPublishRepliedIndMsgs; - u32 validPublishTerminatedIndMsgs; - u32 validActiveSubscribes; - u32 validMatches; - u32 validFollowups; - u32 invalidPublishServiceReqMsgs; - u32 invalidPublishServiceCancelReqMsgs; - u32 invalidActiveSubscribes; - u32 invalidMatches; - u32 invalidFollowups; - u32 publishCount; -} NanPublishStats; - -/* Subscribe statistics. */ -typedef struct -{ - u32 validSubscribeServiceReqMsgs; - u32 validSubscribeServiceRspMsgs; - u32 validSubscribeServiceCancelReqMsgs; - u32 validSubscribeServiceCancelRspMsgs; - u32 validSubscribeTerminatedIndMsgs; - u32 validSubscribeMatchIndMsgs; - u32 validSubscribeUnmatchIndMsgs; - u32 validSolicitedPublishes; - u32 validMatches; - u32 validFollowups; - u32 invalidSubscribeServiceReqMsgs; - u32 invalidSubscribeServiceCancelReqMsgs; - u32 invalidSubscribeFollowupReqMsgs; - u32 invalidSolicitedPublishes; - u32 invalidMatches; - u32 invalidFollowups; - u32 subscribeCount; - u32 bloomFilterIndex; -} NanSubscribeStats; - -/* NAN MAC Statistics. Used for MAC and DW statistics. */ -typedef struct -{ - /* RX stats */ - u32 validFrames; - u32 validActionFrames; - u32 validBeaconFrames; - u32 ignoredActionFrames; - u32 ignoredBeaconFrames; - u32 invalidFrames; - u32 invalidActionFrames; - u32 invalidBeaconFrames; - u32 invalidMacHeaders; - u32 invalidPafHeaders; - u32 nonNanBeaconFrames; - - u32 earlyActionFrames; - u32 inDwActionFrames; - u32 lateActionFrames; - - /* TX stats */ - u32 framesQueued; - u32 totalTRSpUpdates; - u32 completeByTRSp; - u32 completeByTp75DW; - u32 completeByTendDW; - u32 lateActionFramesTx; - - /* Misc stats - ignored for DW. */ - u32 twIncreases; - u32 twDecreases; - u32 twChanges; - u32 twHighwater; - u32 bloomFilterIndex; -} NanMacStats; - -/* NAN Sync Statistics*/ -typedef struct -{ - u64 currTsf; - u64 myRank; - u64 currAmRank; - u64 lastAmRank; - u32 currAmBTT; - u32 lastAmBTT; - u8 currAmHopCount; - u8 currRole; - u16 currClusterId; - - u64 timeSpentInCurrRole; - u64 totalTimeSpentAsMaster; - u64 totalTimeSpentAsNonMasterSync; - u64 totalTimeSpentAsNonMasterNonSync; - u32 transitionsToAnchorMaster; - u32 transitionsToMaster; - u32 transitionsToNonMasterSync; - u32 transitionsToNonMasterNonSync; - u32 amrUpdateCount; - u32 amrUpdateRankChangedCount; - u32 amrUpdateBTTChangedCount; - u32 amrUpdateHcChangedCount; - u32 amrUpdateNewDeviceCount; - u32 amrExpireCount; - u32 mergeCount; - u32 beaconsAboveHcLimit; - u32 beaconsBelowRssiThresh; - u32 beaconsIgnoredNoSpace; - u32 beaconsForOurCluster; - u32 beaconsForOtherCluster; - u32 beaconCancelRequests; - u32 beaconCancelFailures; - u32 beaconUpdateRequests; - u32 beaconUpdateFailures; - u32 syncBeaconTxAttempts; - u32 discBeaconTxAttempts; -} NanSyncStats; - -/* NAN Misc DE Statistics */ -typedef struct -{ - u32 validErrorRspMsgs; - u32 validTransmitFollowupReqMsgs; - u32 validTransmitFollowupRspMsgs; - u32 validFollowupIndMsgs; - u32 validConfigurationReqMsgs; - u32 validConfigurationRspMsgs; - u32 validStatsReqMsgs; - u32 validStatsRspMsgs; - u32 validEnableReqMsgs; - u32 validEnableRspMsgs; - u32 validDisableReqMsgs; - u32 validDisableRspMsgs; - u32 validDisableIndMsgs; - u32 validEventIndMsgs; - u32 validTcaReqMsgs; - u32 validTcaRspMsgs; - u32 validTcaIndMsgs; - u32 invalidTransmitFollowupReqMsgs; - u32 invalidConfigurationReqMsgs; - u32 invalidStatsReqMsgs; - u32 invalidEnableReqMsgs; - u32 invalidDisableReqMsgs; - u32 invalidTcaReqMsgs; -} NanDeStats; - -/* - Stats Response Message structure - The Discovery Engine response to a request by the Host for statistics. -*/ -typedef struct { - NanStatsId stats_id; - union { - NanPublishStats publish_stats; - NanSubscribeStats subscribe_stats; - NanMacStats mac_stats; - NanSyncStats sync_stats; - NanDeStats de_stats; - } data; -} NanStatsResponse; - -/* - NAN Response messages -*/ -typedef struct { - NanHeader header; - u16 status; /* contains the result code */ - u16 value; /* For error returns the value is returned which was in error */ - NanResponseType response_type; /* NanResponseType Definitions */ - union { - NanStatsResponse stats_response; - } body; -} NanResponseMsg; - - -/* - Publish Replied Indication - The PublishRepliedInd Message is sent by the DE when an Active Subscribe is - received over the air and it matches a Solicited PublishServiceReq which had - been created with the replied_event_flag set. -*/ -typedef struct { - NanHeader header; - u8 addr[NAN_MAC_ADDR_LEN]; -} NanPublishRepliedInd; - -/* - Publish Terminated - The PublishTerminatedInd message is sent by the DE whenever a Publish - terminates from a user-specified timeout or a unrecoverable error in the DE. -*/ -typedef struct { - NanHeader header; - NanTerminatedStatus reason; -} NanPublishTerminatedInd; - -/* - Subscribe Match Indication - The SubscribeMatchInd message is sent once per responding MAC address whenever - the Discovery Engine detects a match for a previous SubscribeServiceReq. -*/ -typedef struct { - NanHeader header; - - /* a 16 bit Handle which is sent to the Application. This handle will be sent in any subsequent - UnmatchInd messages rather than resending the Match_Filter/Service_Specific_Info TLVs - The Match_Handle is a DE resource and it is of limited quantity. In the event that the DE - runs out of Match_Handles the DE will still send the SubscribeMatchInd message but will - set the Match_Handle to MATCH_HANDLE_MATCH_POOL_EXHAUSTED=0xFFFF - */ - u16 match_handle; - u8 addr[NAN_MAC_ADDR_LEN]; - - /* Sequence of octets which were received in a Discovery Frame matching this - Subscribe Request.*/ - u16 service_specific_info_len; - u8 service_specific_info[NAN_MAX_SERVICE_NAME_LEN]; - - /* Ordered sequence of <length, value> pairs received in the Discovery Frame - matching this Subscribe Request.*/ - u16 sdf_match_filter_len; - u8 sdf_match_filter[NAN_MAX_MATCH_FILTER_LEN]; -} NanSubscribeMatchInd; - -/* - Subscribe UnMatch - The SubscribeUnmatchInd message is sent whenever the Discovery Engine detects that - a previously Matched Subscribed Service Name has been gone for too long. - If the previous SubscribeMatchInd message contained a Match_Handle equal to - MATCH_HANDLE_MATCH_POOL_EXHAUSTED then this message will not be sent to the Host. -*/ -typedef struct { - NanHeader header; - /* 16 bit value sent by the DE in a previous SubscribeMatchInd to the application. */ - u16 match_handle; -} NanSubscribeUnmatchInd; - -/* - Subscribe Terminated - The SubscribeTerminatedInd message is sent by the DE whenever a - Subscribe terminates from a user-specified timeout or a unrecoverable error in the DE. -*/ -typedef struct { - NanHeader header; - NanTerminatedStatus reason; -} NanSubscribeTerminatedInd; - -/* - Followup Indication Message - The FollowupInd message is sent by the DE to the Host whenever it receives a - Followup message from another peer. -*/ -typedef struct { - NanHeader header; - u8 addr[NAN_MAC_ADDR_LEN]; - - /* Flag which the DE uses to decide if received in a DW or a FAW*/ - u8 dw_or_faw; /* 0=Received in a DW, 1 = Received in a FAW*/ - - /* Sequence of values which further specify the published service beyond the service name - Service specific info in case dw_or_faw is set to 0 - Extended service specific info in case dw_or_faw is set to non-zero*/ - u16 service_specific_info_len; - u8 service_specific_info[NAN_MAX_SERVICE_SPECIFIC_INFO_LEN]; -} NanFollowupInd; - -/* Selfstaevent data*/ -typedef struct { - u8 addr[NAN_MAC_ADDR_LEN]; -} NanSelfStaEvent; - -/* joined or Started cluster data*/ -typedef struct { - u8 addr[NAN_MAC_ADDR_LEN]; -} NanClusterEventData; - -/* - Discovery Engine Event Indication - The Discovery Engine can inform the Host when significant events occur - The data following the EventId is dependent upon the EventId type. - In other words, each new event defined will carry a different - structure of information back to the host. -*/ -typedef struct { - NanHeader header; - NanEventId event_id; /* NAN Protocol Event Codes */ - union { - /* SelfStaEvent which will have 6 byte mac address - of the Discovery engine.*/ - NanSelfStaEvent self_sta; - /* Cluster Event Data which will be obtained when the - device starts a new cluster or joins a cluster. - The event data will have 6 byte octet string of the - cluster started or joined.*/ - NanClusterEventData cluster; - } data; -} NanDiscEngEventInd; - -/* Cluster size TCA data*/ -typedef struct { - u16 cluster_size; -} NanTcaClusterData; - -/* - NAN TCA Indication - The Discovery Engine can inform the Host when significant events occur. - The data following the TcaId is dependent upon the TcaId type. - In other words, each new event defined will carry a different structure - of information back to the host. -*/ -typedef struct { - NanHeader header; - NanTcaId tca_id; - union { - /* This event in obtained when the cluser size threshold - is crossed. Event will have the cluster size */ - NanTcaClusterData cluster; - } data; -} NanTCAInd; - -/* - NAN Disabled Indication - The NanDisableInd message indicates to the upper layers that the Discovery - Engine has flushed all state and has been shutdown. When this message is received - the DE is guaranteed to have left the NAN cluster it was part of and will have terminated - any in progress Publishes or Subscribes. -*/ -typedef struct { - NanHeader header; - NanStatusType reason; -} NanDisabledInd; - -/* Response and Event Callbacks */ -typedef struct { - /* NotifyResponse invoked to notify the status of the Request */ - void (*NotifyResponse)(NanResponseMsg* rsp_data); - /* Various Events Callback */ - void (*EventPublishReplied)(NanPublishRepliedInd* event); - void (*EventPublishTerminated)(NanPublishTerminatedInd* event); - void (*EventSubscribeMatch) (NanSubscribeMatchInd* event); - void (*EventSubscribeUnMatch) (NanSubscribeUnmatchInd* event); - void (*EventSubscribeTerminated) (NanSubscribeTerminatedInd* event); - void (*EventFollowup) (NanFollowupInd* event); - void (*EventDiscEngEvent) (NanDiscEngEventInd* event); - void (*EventDisabled) (NanDisabledInd* event); - void (*EventTca) (NanTCAInd* event); -} NanCallbackHandler; - - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_enable_request(wifi_request_id id, - wifi_handle handle, - NanEnableRequest* msg); - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_disable_request(wifi_request_id id, - wifi_handle handle, - NanDisableRequest* msg); - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_publish_request(wifi_request_id id, - wifi_handle handle, - NanPublishRequest* msg); - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_publish_cancel_request(wifi_request_id id, - wifi_handle handle, - NanPublishCancelRequest* msg); - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_subscribe_request(wifi_request_id id, - wifi_handle handle, - NanSubscribeRequest* msg); - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_subscribe_cancel_request(wifi_request_id id, - wifi_handle handle, - NanSubscribeCancelRequest* msg); - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_transmit_followup_request(wifi_request_id id, - wifi_handle handle, - NanTransmitFollowupRequest* msg); - -/* Function to send NAN statistics request to the wifi driver.*/ -wifi_error nan_stats_request(wifi_request_id id, - wifi_handle handle, - NanStatsRequest* msg); - -/* Function to send NAN configuration request to the wifi driver.*/ -wifi_error nan_config_request(wifi_request_id id, - wifi_handle handle, - NanConfigRequest* msg); - -/* Function to send NAN request to the wifi driver.*/ -wifi_error nan_tca_request(wifi_request_id id, - wifi_handle handle, - NanTCARequest* msg); - -/* Function to register NAN callback */ -wifi_error nan_register_handler(wifi_handle handle, - NanCallbackHandler handlers); - -/* Function to get version of the NAN HAL */ -wifi_error nan_get_version(wifi_handle handle, - NanVersion* version); - -#ifdef __cplusplus -} -#endif /* __cplusplus */ - -#endif /* __NAN_H__ */ diff --git a/include/hardware_legacy/wifi_hal.h b/include/hardware_legacy/wifi_hal.h index 020156e..7b24776 100644 --- a/include/hardware_legacy/wifi_hal.h +++ b/include/hardware_legacy/wifi_hal.h @@ -122,7 +122,6 @@ wifi_error wifi_set_nodfs_flag(wifi_interface_handle handle, u32 nodfs); #include "gscan.h" #include "link_layer_stats.h" #include "rtt.h" -#include "nan.h" #include "tdls.h" #endif |