Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e2d0ab52 authored by Roshan Pius's avatar Roshan Pius
Browse files

wifi: Add logger method implementations in IWifiChip

Hookup the legacy HAL functions to the corresponding HIDL methods in
WifiChip and perform the necessary struct conversions.

Bug: 32221997
Test: Compiles
Change-Id: I2b0cfd6484c7599e96e9edfcef18ac3148e28307
parent 881d1f78
Loading
Loading
Loading
Loading
+59 −15
Original line number Original line Diff line number Diff line
@@ -17,6 +17,7 @@
#include <android-base/logging.h>
#include <android-base/logging.h>


#include "hidl_return_util.h"
#include "hidl_return_util.h"
#include "hidl_struct_util.h"
#include "wifi_chip.h"
#include "wifi_chip.h"
#include "wifi_status_util.h"
#include "wifi_status_util.h"


@@ -307,8 +308,19 @@ WifiStatus WifiChip::registerEventCallbackInternal(
}
}


std::pair<WifiStatus, uint32_t> WifiChip::getCapabilitiesInternal() {
std::pair<WifiStatus, uint32_t> WifiChip::getCapabilitiesInternal() {
  // TODO add implementation
  legacy_hal::wifi_error legacy_status;
  return {createWifiStatus(WifiStatusCode::SUCCESS), 0};
  uint32_t legacy_logger_feature_set;
  std::tie(legacy_status, legacy_logger_feature_set) =
      legacy_hal_.lock()->getLoggerSupportedFeatureSet();
  if (legacy_status != legacy_hal::WIFI_SUCCESS) {
    return {createWifiStatusFromLegacyError(legacy_status), 0};
  }
  uint32_t hidl_caps;
  if (!hidl_struct_util::convertLegacyFeaturesToHidlChipCapabilities(
          legacy_logger_feature_set, &hidl_caps)) {
    return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), 0};
  }
  return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_caps};
}
}


std::pair<WifiStatus, std::vector<IWifiChip::ChipMode>>
std::pair<WifiStatus, std::vector<IWifiChip::ChipMode>>
@@ -561,29 +573,61 @@ WifiChip::createRttControllerInternal(const sp<IWifiIface>& bound_iface) {


std::pair<WifiStatus, std::vector<WifiDebugRingBufferStatus>>
std::pair<WifiStatus, std::vector<WifiDebugRingBufferStatus>>
WifiChip::getDebugRingBuffersStatusInternal() {
WifiChip::getDebugRingBuffersStatusInternal() {
  // TODO implement
  legacy_hal::wifi_error legacy_status;
  return {createWifiStatus(WifiStatusCode::SUCCESS), {}};
  std::vector<legacy_hal::wifi_ring_buffer_status>
      legacy_ring_buffer_status_vec;
  std::tie(legacy_status, legacy_ring_buffer_status_vec) =
      legacy_hal_.lock()->getRingBuffersStatus();
  if (legacy_status != legacy_hal::WIFI_SUCCESS) {
    return {createWifiStatusFromLegacyError(legacy_status), {}};
  }
  std::vector<WifiDebugRingBufferStatus> hidl_ring_buffer_status_vec;
  if (!hidl_struct_util::convertLegacyVectorOfDebugRingBufferStatusToHidl(
          legacy_ring_buffer_status_vec, &hidl_ring_buffer_status_vec)) {
    return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
  }
  return {createWifiStatus(WifiStatusCode::SUCCESS),
          hidl_ring_buffer_status_vec};
}
}


WifiStatus WifiChip::startLoggingToDebugRingBufferInternal(
WifiStatus WifiChip::startLoggingToDebugRingBufferInternal(
    const hidl_string& /* ring_name */,
    const hidl_string& ring_name,
    WifiDebugRingBufferVerboseLevel /* verbose_level */,
    WifiDebugRingBufferVerboseLevel verbose_level,
    uint32_t /* max_interval_in_sec */,
    uint32_t max_interval_in_sec,
    uint32_t /* min_data_size_in_bytes */) {
    uint32_t min_data_size_in_bytes) {
  // TODO implement
  legacy_hal::wifi_error legacy_status =
  return createWifiStatus(WifiStatusCode::SUCCESS);
      legacy_hal_.lock()->startRingBufferLogging(
          ring_name,
          static_cast<
              std::underlying_type<WifiDebugRingBufferVerboseLevel>::type>(
              verbose_level),
          max_interval_in_sec,
          min_data_size_in_bytes);
  return createWifiStatusFromLegacyError(legacy_status);
}
}


WifiStatus WifiChip::forceDumpToDebugRingBufferInternal(
WifiStatus WifiChip::forceDumpToDebugRingBufferInternal(
    const hidl_string& /* ring_name */) {
    const hidl_string& ring_name) {
  // TODO implement
  legacy_hal::wifi_error legacy_status =
  return createWifiStatus(WifiStatusCode::SUCCESS);
      legacy_hal_.lock()->getRingBufferData(ring_name);
  return createWifiStatusFromLegacyError(legacy_status);
}
}


std::pair<WifiStatus, WifiDebugHostWakeReasonStats>
std::pair<WifiStatus, WifiDebugHostWakeReasonStats>
WifiChip::getDebugHostWakeReasonStatsInternal() {
WifiChip::getDebugHostWakeReasonStatsInternal() {
  // TODO implement
  legacy_hal::wifi_error legacy_status;
  return {createWifiStatus(WifiStatusCode::SUCCESS), {}};
  legacy_hal::WakeReasonStats legacy_stats;
  std::tie(legacy_status, legacy_stats) =
      legacy_hal_.lock()->getWakeReasonStats();
  if (legacy_status != legacy_hal::WIFI_SUCCESS) {
    return {createWifiStatusFromLegacyError(legacy_status), {}};
  }
  WifiDebugHostWakeReasonStats hidl_stats;
  if (!hidl_struct_util::convertLegacyWakeReasonStatsToHidl(legacy_stats,
                                                            &hidl_stats)) {
    return {createWifiStatus(WifiStatusCode::ERROR_UNKNOWN), {}};
  }
  return {createWifiStatus(WifiStatusCode::SUCCESS), hidl_stats};
}
}


}  // namespace implementation
}  // namespace implementation