diff options
author | Vinit Deshpande <vinitd@google.com> | 2014-07-07 11:45:54 -0700 |
---|---|---|
committer | Vinit Deshpande <vinitd@google.com> | 2014-07-10 10:51:28 -0700 |
commit | 044c10e9efb994584b1fcf34be877b7957cb5f48 (patch) | |
tree | c72e562fd09200981ea810a5676e3762a05c9529 | |
parent | 93f677b67008faa0995d9283d04aa2ee3ef3a582 (diff) | |
download | hardware_libhardware_legacy-044c10e9efb994584b1fcf34be877b7957cb5f48.zip hardware_libhardware_legacy-044c10e9efb994584b1fcf34be877b7957cb5f48.tar.gz hardware_libhardware_legacy-044c10e9efb994584b1fcf34be877b7957cb5f48.tar.bz2 |
Introduce TDLS APIs in wifi HAL
Change-Id: I611012412f58682ea11179631622023eda5393e7
-rw-r--r-- | include/hardware_legacy/tdls.h | 73 | ||||
-rw-r--r-- | include/hardware_legacy/wifi_hal.h | 1 |
2 files changed, 74 insertions, 0 deletions
diff --git a/include/hardware_legacy/tdls.h b/include/hardware_legacy/tdls.h new file mode 100644 index 0000000..c1cd33e --- /dev/null +++ b/include/hardware_legacy/tdls.h @@ -0,0 +1,73 @@ + +#include "wifi_hal.h" + +#ifndef _TDLS_H_ +#define _TDLS_H_ + +typedef enum { + WIFI_TDLS_DISABLED, /* TDLS is not enabled, or is disabled now */ + WIFI_TDLS_ENABLED, /* TDLS is enabled, but not yet tried */ + WIFI_TDLS_TRYING, /* Direct link is being attempted (optional) */ + WIFI_TDLS_ESTABLISHED, /* Direct link is established */ + WIFI_TDLS_ESTABLISHED_OFF_CHANNEL, /* Direct link is established using MCC */ + WIFI_TDLS_DROPPED, /* Direct link was established, but is now dropped */ + WIFI_TDLS_FAILED /* Direct link failed */ +} wifi_tdls_state; + +typedef enum { + WIFI_TDLS_SUCCESS, /* Success */ + WIFI_TDLS_UNSPECIFIED = -1, /* Unspecified reason */ + WIFI_TDLS_NOT_SUPPORTED = -2, /* Remote side doesn't support TDLS */ + WIFI_TDLS_UNSUPPORTED_BAND = -3, /* Remote side doesn't support this band */ + WIFI_TDLS_NOT_BENEFICIAL = -4, /* Going to AP is better than going direct */ + WIFI_TDLS_DROPPED_BY_REMOTE = -5 /* Remote side doesn't want it anymore */ +} wifi_tdls_reason; + +typedef struct { + int channel; /* channel hint, in channel number (NOT frequency ) */ + int global_operating_class; /* operating class to use */ + int max_latency_ms; /* max latency that can be tolerated by apps */ + int min_bandwidth_kbps; /* bandwidth required by apps, in kilo bits per second */ +} wifi_tdls_params; + +typedef struct { + int channel; + int global_operating_class; + wifi_tdls_state state; + wifi_tdls_reason reason; +} wifi_tdls_status; + +typedef struct { + /* on_tdls_state_changed - reports state to TDLS link + * Report this event when the state of TDLS link changes */ + void (*on_tdls_state_changed)(mac_addr addr, wifi_tdls_status status); +} wifi_tdls_handler; + + +/* wifi_enable_tdls - enables TDLS-auto mode for a specific route + * + * params specifies hints, which provide more information about + * why TDLS is being sought. The firmware should do its best to + * honor the hints before downgrading regular AP link + * + * On successful completion, must fire on_tdls_state_changed event + * to indicate the status of TDLS operation. + */ +wifi_error wifi_enable_tdls(wifi_interface_handle iface, mac_addr addr, + wifi_tdls_params params, wifi_tdls_handler handler); + +/* wifi_disable_tdls - disables TDLS-auto mode for a specific route + * + * This terminates any existing TDLS with addr device, and frees the + * device resources to make TDLS connections on new routes. + * + * DON'T fire any more events on 'handler' specified in earlier call to + * wifi_enable_tdls after this action. + */ +wifi_error wifi_disable_tdls(wifi_interface_handle iface, mac_addr addr); + +/* wifi_get_tdls_status - allows getting the status of TDLS for a specific route */ +wifi_error wifi_get_tdls_status(wifi_interface_handle iface, mac_addr addr, + wifi_tdls_status *status); + +#endif
\ No newline at end of file diff --git a/include/hardware_legacy/wifi_hal.h b/include/hardware_legacy/wifi_hal.h index 9a82505..0d11c82 100644 --- a/include/hardware_legacy/wifi_hal.h +++ b/include/hardware_legacy/wifi_hal.h @@ -117,6 +117,7 @@ wifi_error wifi_reset_iface_event_handler(wifi_request_id id, wifi_interface_han #include "link_layer_stats.h" #include "rtt.h" #include "nan.h" +#include "tdls.h" #endif |