Home | History | Annotate | only in /hardware/interfaces/wifi/1.0/default
Up to higher level directory
NameDateSize
android.hardware.wifi@1.0-service.rc05-Oct-2017120
Android.mk05-Oct-20171.5K
hidl_callback_util.h05-Oct-20173.6K
hidl_return_util.h05-Oct-20173.8K
hidl_struct_util.cpp05-Oct-201789.7K
hidl_struct_util.h05-Oct-20177K
hidl_sync_util.cpp05-Oct-20171.1K
hidl_sync_util.h05-Oct-20171.2K
service.cpp05-Oct-20171.4K
THREADING.README05-Oct-20171.9K
wifi.cpp05-Oct-20176.6K
wifi.h05-Oct-20172.6K
wifi_ap_iface.cpp05-Oct-20173.6K
wifi_ap_iface.h05-Oct-20172.2K
wifi_chip.cpp05-Oct-201733.1K
wifi_chip.h05-Oct-20179.2K
wifi_feature_flags.h05-Oct-20171.1K
wifi_legacy_hal.cpp05-Oct-201749.9K
wifi_legacy_hal.h05-Oct-201713.7K
wifi_legacy_hal_stubs.cpp05-Oct-20176.1K
wifi_legacy_hal_stubs.h05-Oct-20171.1K
wifi_mode_controller.cpp05-Oct-20172.3K
wifi_mode_controller.h05-Oct-20171.8K
wifi_nan_iface.cpp05-Oct-201729.6K
wifi_nan_iface.h05-Oct-20176.4K
wifi_p2p_iface.cpp05-Oct-20172.1K
wifi_p2p_iface.h05-Oct-20171.8K
wifi_rtt_controller.cpp05-Oct-201711.3K
wifi_rtt_controller.h05-Oct-20174.3K
wifi_sta_iface.cpp05-Oct-201724.5K
wifi_sta_iface.h05-Oct-20177K
wifi_status_util.cpp05-Oct-20173.5K
wifi_status_util.h05-Oct-20171.4K

THREADING.README

      1 Vendor HAL Threading Model
      2 ==========================
      3 The vendor HAL service has two threads:
      4 1. HIDL thread: This is the main thread which processes all the incoming HIDL
      5 RPC's.
      6 2. Legacy HAL event loop thread: This is the thread forked off for processing
      7 the legacy HAL event loop (wifi_event_loop()). This thread is used to process
      8 any asynchronous netlink events posted by the driver. Any asynchronous
      9 callbacks passed to the legacy HAL API's are invoked on this thread.
     10 
     11 Synchronization Concerns
     12 ========================
     13 wifi_legacy_hal.cpp has a bunch of global "C" style functions to handle the
     14 legacy callbacks. Each of these "C" style function invokes a corresponding
     15 "std::function" version of the callback which does the actual processing.
     16 The variables holding these "std::function" callbacks are reset from the HIDL
     17 thread when they are no longer used. For example: stopGscan() will reset the
     18 corresponding "on_gscan_*" callback variables which were set when startGscan()
     19 was invoked. This is not thread safe since these callback variables are
     20 accesed from the legacy hal event loop thread as well.
     21 
     22 Synchronization Solution
     23 ========================
     24 Adding a global lock seems to be the most trivial solution to the problem.
     25 a) All of the asynchronous "C" style callbacks will acquire the global lock
     26 before invoking the corresponding "std::function" callback variables.
     27 b) All of the HIDL methods will also acquire the global lock before processing
     28 (in hidl_return_util::validateAndCall()).
     29 
     30 Note: It's important that we only acquire the global lock for asynchronous
     31 callbacks, because there is no guarantee (or documentation to clarify) that the
     32 synchronous callbacks are invoked on the same invocation thread. If that is not
     33 the case in some implementation, we will end up deadlocking the system since the
     34 HIDL thread would have acquired the global lock which is needed by the
     35 synchronous callback executed on the legacy hal event loop thread.
     36