/* * Copyright (C) 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. */ package android.util; import android.annotation.NonNull; import android.annotation.SystemApi; import android.annotation.UptimeMillisLong; import android.os.SystemClock; import com.android.internal.annotations.VisibleForTesting; /** * Writes an EventLog event capturing the performance of system config file writes. * The event log entry is formatted like this: * 525000 commit_sys_config_file (name|3),(time|2|3), where name is * a short unique name representing the type of configuration file and time is * duration in the {@link SystemClock#uptimeMillis()} time base. * * @hide */ @SystemApi(client = SystemApi.Client.MODULE_LIBRARIES) public class SystemConfigFileCommitEventLogger { private final String mName; private long mStartTime; /** * @param name The short name of the config file that is included in the event log event, * e.g. "jobs", "appops", "uri-grants" etc. */ public SystemConfigFileCommitEventLogger(@NonNull String name) { mName = name; } /** * Override the start timestamp. Use this method when it's desired to include the time * taken by the preparation of the configuration data in the overall duration of the * "commitSysConfigFile" event. * * @param startTime Overridden start time, in system uptime milliseconds */ public void setStartTime(@UptimeMillisLong long startTime) { mStartTime = startTime; } /** * Invoked just before the configuration file writing begins. * @hide */ public void onStartWrite() { if (mStartTime == 0) { mStartTime = SystemClock.uptimeMillis(); } } /** * Invoked just after the configuration file writing ends. * @hide */ public void onFinishWrite() { writeLogRecord(SystemClock.uptimeMillis() - mStartTime); } /** * The actual write of the log record. * @hide */ @VisibleForTesting public void writeLogRecord(long durationMs) { com.android.internal.logging.EventLogTags.writeCommitSysConfigFile(mName, durationMs); } }