/* * Copyright (C) 2021 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. */ #define DEBUG false // STOPSHIP if true #define LOG_TAG "StatsAidl" #include #include #include "StatsAidl.h" namespace aidl { namespace android { namespace frameworks { namespace stats { StatsHal::StatsHal() {} ndk::ScopedAStatus StatsHal::reportVendorAtom(const VendorAtom& vendorAtom) { std::string reverseDomainName = (std::string) vendorAtom.reverseDomainName; if (vendorAtom.atomId < 100000 || vendorAtom.atomId >= 200000) { ALOGE("Atom ID %ld is not a valid vendor atom ID", (long) vendorAtom.atomId); return ndk::ScopedAStatus::fromServiceSpecificErrorWithMessage( -1, "Not a valid vendor atom ID"); } if (reverseDomainName.length() > 50) { ALOGE("Vendor atom reverse domain name %s is too long.", reverseDomainName.c_str()); return ndk::ScopedAStatus::fromServiceSpecificErrorWithMessage( -1, "Vendor atom reverse domain name is too long"); } AStatsEvent* event = AStatsEvent_obtain(); AStatsEvent_setAtomId(event, vendorAtom.atomId); AStatsEvent_writeString(event, vendorAtom.reverseDomainName.c_str()); for (const auto& atomValue : vendorAtom.values) { switch (atomValue.getTag()) { case VendorAtomValue::intValue: AStatsEvent_writeInt32(event, atomValue.get()); break; case VendorAtomValue::longValue: AStatsEvent_writeInt64(event, atomValue.get()); break; case VendorAtomValue::floatValue: AStatsEvent_writeFloat(event, atomValue.get()); break; case VendorAtomValue::stringValue: AStatsEvent_writeString(event, atomValue.get().c_str()); break; } } AStatsEvent_build(event); const int ret = AStatsEvent_write(event); AStatsEvent_release(event); return ret <= 0 ? ndk::ScopedAStatus::fromServiceSpecificErrorWithMessage(ret, "report atom failed") : ndk::ScopedAStatus::ok(); } } // namespace stats } // namespace frameworks } // namespace android } // namespace aidl