diff options
Diffstat (limited to 'include/hardware_legacy/wifi_hal.h')
-rw-r--r-- | include/hardware_legacy/wifi_hal.h | 123 |
1 files changed, 121 insertions, 2 deletions
diff --git a/include/hardware_legacy/wifi_hal.h b/include/hardware_legacy/wifi_hal.h index 9e9f8ab..9c82e80 100644 --- a/include/hardware_legacy/wifi_hal.h +++ b/include/hardware_legacy/wifi_hal.h @@ -103,6 +103,10 @@ typedef enum { WIFI_POWER_SCENARIO_ON_BODY_HOTSPOT_MMW_UNFOLDED = 23, WIFI_POWER_SCENARIO_ON_BODY_HOTSPOT_BT_MMW_UNFOLDED = 24, WIFI_POWER_SCENARIO_ON_BODY_REAR_CAMERA = 25, + WIFI_POWER_SCENARIO_ON_BODY_CELL_OFF_UNFOLDED_CAP = 26, + WIFI_POWER_SCENARIO_ON_BODY_BT_UNFOLDED_CAP = 27, + WIFI_POWER_SCENARIO_ON_BODY_CELL_ON_UNFOLDED_CAP = 28, + WIFI_POWER_SCENARIO_ON_BODY_CELL_ON_BT_UNFOLDED_CAP = 29, } wifi_power_scenario; typedef enum { @@ -126,7 +130,7 @@ typedef enum { */ typedef enum { WIFI_VOIP_MODE_OFF = 0, - WIFI_VOIP_MODE_ON = 1, + WIFI_VOIP_MODE_VOICE = 1, } wifi_voip_mode; /* List of interface types supported */ @@ -469,6 +473,9 @@ void wifi_get_error_info(wifi_error err, const char **msg); // return a pointer #define WIFI_FEATURE_INFRA_60G (uint64_t)0x100000000 // Support for 60GHz Band #define WIFI_FEATURE_AFC_CHANNEL (uint64_t)0x200000000 // Support for setting 6GHz AFC channel allowance #define WIFI_FEATURE_T2LM_NEGO (uint64_t)0x400000000 // Support for TID-To-Link mapping negotiation +#define WIFI_FEATURE_ROAMING_MODE_CONTROL (uint64_t)0x800000000 // Support for configuring roaming mode +#define WIFI_FEATURE_SET_VOIP_MODE (uint64_t)0x1000000000 // Support Voip mode setting +#define WIFI_FEATURE_CACHED_SCAN_RESULTS (uint64_t)0x2000000000 // Support cached scan result report // Add more features here #define IS_MASK_SET(mask, flags) (((flags) & (mask)) == (mask)) @@ -762,9 +769,12 @@ typedef struct { wifi_error (* wifi_get_valid_channels)(wifi_interface_handle,int, int, wifi_channel *, int *); wifi_error (* wifi_rtt_range_request)(wifi_request_id, wifi_interface_handle, unsigned, wifi_rtt_config[], wifi_rtt_event_handler); + wifi_error (* wifi_rtt_range_request_v3)(wifi_request_id, wifi_interface_handle, unsigned, + wifi_rtt_config_v3[], wifi_rtt_event_handler_v3); wifi_error (* wifi_rtt_range_cancel)(wifi_request_id, wifi_interface_handle, unsigned, mac_addr[]); wifi_error (* wifi_get_rtt_capabilities)(wifi_interface_handle, wifi_rtt_capabilities *); + wifi_error (* wifi_get_rtt_capabilities_v3)(wifi_interface_handle, wifi_rtt_capabilities_v3 *); wifi_error (* wifi_rtt_get_responder_info)(wifi_interface_handle iface, wifi_rtt_responder *responder_info); wifi_error (* wifi_enable_responder)(wifi_request_id id, wifi_interface_handle iface, @@ -988,11 +998,107 @@ typedef struct { */ wifi_error (*wifi_set_voip_mode)(wifi_interface_handle iface, wifi_voip_mode mode); + /** + * Get Target Wake Time (TWT) local device capabilities for the station interface. + * + * @param iface Wifi interface handle + * @param capabilities TWT capabilities + * @return Synchronous wifi_error + */ + wifi_error (*wifi_twt_get_capabilities)(wifi_interface_handle iface, + wifi_twt_capabilities* capabilities); + /** + * Setup a TWT session. + * + * Supported only if wifi_twt_capabilities.is_twt_requester_supported is set. Results in + * asynchronous callback wifi_twt_events.on_twt_session_create on success or + * wifi_twt_events.on_twt_failure with error code. + * + * @param id Identifier for the command. The value 0 is reserved. + * @param iface Wifi interface handle + * @param request TWT request parameters + * @param events TWT events + * @return Synchronous wifi_error + */ + wifi_error (*wifi_twt_session_setup)(wifi_request_id id, wifi_interface_handle iface, + wifi_twt_request request, wifi_twt_events events); + /** + * Update a TWT session. + * + * Supported only if wifi_twt_session.is_updatable is set. Reesults in asynchronous callback + * wifi_twt_events.on_twt_session_update on success or wifi_twt_events.on_twt_failure with + * error code. + * + * @param id Identifier for the command. The value 0 is reserved. + * @param iface Wifi interface handle + * @param session_id TWT session identifier + * @param request TWT request parameters + * @return Synchronous wifi_error + */ + wifi_error (*wifi_twt_session_update)(wifi_request_id id, wifi_interface_handle iface, + int session_id, wifi_twt_request request); + /** + * Suspend a TWT session. + * Supported only if wifi_twt_session.is_suspendable is set. Results in asynchronous callback + * wifi_twt_events.on_twt_session_suspend on success or wifi_twt_events.on_twt_failure with + * error code. + * + * @param id Identifier for the command. The value 0 is reserved. + * @param iface Wifi interface handle + * @param session_id TWT session identifier + * @return Synchronous wifi_error + */ + wifi_error (*wifi_twt_session_suspend)(wifi_request_id id, wifi_interface_handle iface, + int session_id); + /** + * Resume a suspended TWT session. + * + * Supported only if wifi_twt_session.is_suspendable is set. Results in asynchronous callback + * wifi_twt_events.on_twt_session_resume on success or wifi_twt_events.on_twt_failure with + * error code. + * + * @param id Identifier for the command. The value 0 is reserved. + * @param iface Wifi interface handle + * @param session_id TWT session identifier + * @return Synchronous wifi_error + */ + wifi_error (*wifi_twt_session_resume)(wifi_request_id id, wifi_interface_handle iface, + int session_id); + /** + * Teardown a TWT session. + * + * Results in asynchronous callback wifi_twt_events.on_twt_session_teardown on success or + * wifi_twt_events.on_twt_failure with error code. + * + * @param id Identifier for the command. The value 0 is reserved. + * @param iface Wifi interface handle + * @param session_id TWT session identifier + * @return Synchronous wifi_error + */ + wifi_error (*wifi_twt_session_teardown)(wifi_request_id id, wifi_interface_handle iface, + int session_id); + + /** + * Get stats for a TWT session. + * + * Results in asynchronous callback wifi_twt_events.on_twt_session_stats on success or + * wifi_twt_events.on_twt_failure with error code. + * + * @param id Identifier for the command. The value 0 is reserved. + * @param iface Wifi interface handle + * @param session_id TWT session identifier + * @return Synchronous wifi_error + */ + wifi_error (*wifi_twt_session_get_stats)(wifi_request_id id, wifi_interface_handle iface, + int session_id); + /**@brief twt_register_handler * Request to register TWT callback before sending any TWT request * @param wifi_interface_handle: * @param TwtCallbackHandler: callback function pointers * @return Synchronous wifi_error + * + * Note: This function is deprecated */ wifi_error (*wifi_twt_register_handler)(wifi_interface_handle iface, TwtCallbackHandler handler); @@ -1001,6 +1107,8 @@ typedef struct { * Request TWT capability * @param wifi_interface_handle: * @return Synchronous wifi_error and TwtCapabilitySet + * + * Note: This function is deprecated by wifi_twt_get_capabilities */ wifi_error (*wifi_twt_get_capability)(wifi_interface_handle iface, TwtCapabilitySet* twt_cap_set); @@ -1011,7 +1119,9 @@ typedef struct { * @param TwtSetupRequest: detailed parameters of setup request * @return Synchronous wifi_error * @return Asynchronous EventTwtSetupResponse CB return TwtSetupResponse - */ + * + * Note: This function is deprecated by wifi_twt_session_setup + */ wifi_error (*wifi_twt_setup_request)(wifi_interface_handle iface, TwtSetupRequest* msg); @@ -1023,6 +1133,8 @@ typedef struct { * @return Asynchronous EventTwtTeardownCompletion CB return TwtTeardownCompletion * TwtTeardownCompletion may also be received due to other events * like CSA, BTCX, TWT scheduler, MultiConnection, peer-initiated teardown, etc. + * + * Note: This function is deprecated by wifi_twt_session_teardown */ wifi_error (*wifi_twt_teardown_request)(wifi_interface_handle iface, TwtTeardownRequest* msg); @@ -1034,6 +1146,9 @@ typedef struct { * @return Synchronous wifi_error * @return Asynchronous EventTwtInfoFrameReceived CB return TwtInfoFrameReceived * Driver may also receive Peer-initiated TwtInfoFrame + * + * Note: This function is deprecated by wifi_twt_session_suspend and + * wifi_twt_session_resume */ wifi_error (*wifi_twt_info_frame_request)(wifi_interface_handle iface, TwtInfoFrameRequest* msg); @@ -1043,6 +1158,8 @@ typedef struct { * @param wifi_interface_handle: * @param config_id: configuration ID of TWT request * @return Synchronous wifi_error and TwtStats + * + * Note: This function is deprecated by wifi_twt_get_session_stats */ wifi_error (*wifi_twt_get_stats)(wifi_interface_handle iface, u8 config_id, TwtStats* stats); @@ -1052,6 +1169,8 @@ typedef struct { * @param wifi_interface_handle: * @param config_id: configuration ID of TWT request * @return Synchronous wifi_error + * + * Note: This function is deprecated by wifi_twt_session_clear_stats */ wifi_error (*wifi_twt_clear_stats)(wifi_interface_handle iface, u8 config_id); |