1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2020 The Android Open Source Project 3*795d594fSAndroid Build Coastguard Worker * 4*795d594fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*795d594fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*795d594fSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*795d594fSAndroid Build Coastguard Worker * 8*795d594fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*795d594fSAndroid Build Coastguard Worker * 10*795d594fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*795d594fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*795d594fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*795d594fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*795d594fSAndroid Build Coastguard Worker * limitations under the License. 15*795d594fSAndroid Build Coastguard Worker */ 16*795d594fSAndroid Build Coastguard Worker 17*795d594fSAndroid Build Coastguard Worker #include "compat_framework.h" 18*795d594fSAndroid Build Coastguard Worker 19*795d594fSAndroid Build Coastguard Worker #include <sys/types.h> 20*795d594fSAndroid Build Coastguard Worker #include <unistd.h> 21*795d594fSAndroid Build Coastguard Worker 22*795d594fSAndroid Build Coastguard Worker #include "android-base/logging.h" 23*795d594fSAndroid Build Coastguard Worker #include "thread-current-inl.h" 24*795d594fSAndroid Build Coastguard Worker 25*795d594fSAndroid Build Coastguard Worker namespace art HIDDEN { 26*795d594fSAndroid Build Coastguard Worker 27*795d594fSAndroid Build Coastguard Worker // Compat change states as strings. 28*795d594fSAndroid Build Coastguard Worker static constexpr char kUnknownChangeState[] = "UNKNOWN"; 29*795d594fSAndroid Build Coastguard Worker static constexpr char kEnabledChangeState[] = "ENABLED"; 30*795d594fSAndroid Build Coastguard Worker static constexpr char kDisabledChangeState[] = "DISABLED"; 31*795d594fSAndroid Build Coastguard Worker static constexpr char kLoggedState[] = "LOGGED"; 32*795d594fSAndroid Build Coastguard Worker CompatFramework()33*795d594fSAndroid Build Coastguard WorkerCompatFramework::CompatFramework() 34*795d594fSAndroid Build Coastguard Worker : reported_compat_changes_lock_("reported compat changes lock") {} 35*795d594fSAndroid Build Coastguard Worker ~CompatFramework()36*795d594fSAndroid Build Coastguard WorkerCompatFramework::~CompatFramework() {} 37*795d594fSAndroid Build Coastguard Worker IsChangeEnabled(uint64_t change_id)38*795d594fSAndroid Build Coastguard Workerbool CompatFramework::IsChangeEnabled(uint64_t change_id) { 39*795d594fSAndroid Build Coastguard Worker const auto enabled = disabled_compat_changes_.count(change_id) == 0; 40*795d594fSAndroid Build Coastguard Worker ReportChange(change_id, enabled ? ChangeState::kEnabled : ChangeState::kDisabled); 41*795d594fSAndroid Build Coastguard Worker return enabled; 42*795d594fSAndroid Build Coastguard Worker } 43*795d594fSAndroid Build Coastguard Worker LogChange(uint64_t change_id)44*795d594fSAndroid Build Coastguard Workervoid CompatFramework::LogChange(uint64_t change_id) { 45*795d594fSAndroid Build Coastguard Worker ReportChange(change_id, ChangeState::kLogged); 46*795d594fSAndroid Build Coastguard Worker } 47*795d594fSAndroid Build Coastguard Worker ReportChange(uint64_t change_id,ChangeState state)48*795d594fSAndroid Build Coastguard Workervoid CompatFramework::ReportChange(uint64_t change_id, ChangeState state) { 49*795d594fSAndroid Build Coastguard Worker MutexLock mu(Thread::Current(), reported_compat_changes_lock_); 50*795d594fSAndroid Build Coastguard Worker bool already_reported = reported_compat_changes_.count(change_id) != 0; 51*795d594fSAndroid Build Coastguard Worker if (already_reported) { 52*795d594fSAndroid Build Coastguard Worker return; 53*795d594fSAndroid Build Coastguard Worker } 54*795d594fSAndroid Build Coastguard Worker LOG(DEBUG) << "Compat change id reported: " << change_id << "; UID " << getuid() 55*795d594fSAndroid Build Coastguard Worker << "; state: " << ChangeStateToString(state); 56*795d594fSAndroid Build Coastguard Worker // TODO(145743810): add an up call to java to log to statsd 57*795d594fSAndroid Build Coastguard Worker reported_compat_changes_.emplace(change_id); 58*795d594fSAndroid Build Coastguard Worker } 59*795d594fSAndroid Build Coastguard Worker ChangeStateToString(ChangeState state)60*795d594fSAndroid Build Coastguard Workerstd::string_view CompatFramework::ChangeStateToString(ChangeState state) { 61*795d594fSAndroid Build Coastguard Worker switch (state) { 62*795d594fSAndroid Build Coastguard Worker case ChangeState::kUnknown: 63*795d594fSAndroid Build Coastguard Worker return kUnknownChangeState; 64*795d594fSAndroid Build Coastguard Worker case ChangeState::kEnabled: 65*795d594fSAndroid Build Coastguard Worker return kEnabledChangeState; 66*795d594fSAndroid Build Coastguard Worker case ChangeState::kDisabled: 67*795d594fSAndroid Build Coastguard Worker return kDisabledChangeState; 68*795d594fSAndroid Build Coastguard Worker case ChangeState::kLogged: 69*795d594fSAndroid Build Coastguard Worker return kLoggedState; 70*795d594fSAndroid Build Coastguard Worker } 71*795d594fSAndroid Build Coastguard Worker } 72*795d594fSAndroid Build Coastguard Worker 73*795d594fSAndroid Build Coastguard Worker } // namespace art 74