summaryrefslogtreecommitdiff
path: root/system/gd/btaa/linux_generic/wakelock_processor.cc
blob: bd3b3edc89c80ded62482fb5ef6e4c0612f7b30b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/*
 * Copyright 2020 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.
 */

#include "btaa/wakelock_processor.h"

#include "os/log.h"

namespace bluetooth {
namespace activity_attribution {

static const int kWakelockMaxDurationMs(10000);

WakelockProcessor::WakelockProcessor() {
  wakelock_net_count_ = 0;
  wakelock_acquired_time_ = {};
}

uint32_t WakelockProcessor::OnWakelockReleased() {
  auto cur_time = std::chrono::system_clock::now();
  uint32_t wakelock_duration_ms = 0;

  if (wakelock_net_count_ == 0) {
    LOG_INFO("Release a never acquired wakelock, ignored.");
  } else {
    wakelock_net_count_--;
    if (wakelock_net_count_ == 0) {
      wakelock_duration_ms = static_cast<uint32_t>(
          std::chrono::duration_cast<std::chrono::milliseconds>(cur_time - wakelock_acquired_time_).count());
      wakelock_acquired_time_ = {};
    }
  }

  return wakelock_duration_ms;
}

void WakelockProcessor::OnWakelockAcquired() {
  auto cur_time = std::chrono::system_clock::now();

  if (wakelock_net_count_ == 0) {
    if (wakelock_acquired_time_.time_since_epoch().count()) {
      LOG_INFO("Previous wakelock acquired time is not consumed, dropped.");
    }
    wakelock_acquired_time_ = cur_time;
  } else if (cur_time - wakelock_acquired_time_ > std::chrono::milliseconds(kWakelockMaxDurationMs)) {
    LOG_INFO("Wakelock held for too long, likely we missed a release notification. Resetting wakelock stats.");
    wakelock_net_count_ = 0;
    wakelock_acquired_time_ = cur_time;
  }

  wakelock_net_count_++;
}

}  // namespace activity_attribution
}  // namespace bluetooth