blob: 2868e2623861a2cf0c2f7801019da6ffc0a0c003 [file] [log] [blame]
Shuzhen Wang316781a2020-08-18 18:11:01 -07001/*
2 * Copyright (C) 2020 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ANDROID_SERVERS_CAMERA_SERVICE_PROXY_WRAPPER_H_
18#define ANDROID_SERVERS_CAMERA_SERVICE_PROXY_WRAPPER_H_
19
20#include <android/hardware/ICameraServiceProxy.h>
21
22#include <utils/Mutex.h>
23#include <utils/String8.h>
24#include <utils/String16.h>
25#include <utils/StrongPointer.h>
26#include <utils/Timers.h>
Avichal Rakesh88fc5222023-03-03 15:00:59 -080027#include <random>
Shuzhen Wang316781a2020-08-18 18:11:01 -070028
29#include <camera/CameraSessionStats.h>
30
31namespace android {
32
33class CameraServiceProxyWrapper {
34private:
35 // Guard mCameraServiceProxy
Austin Borger74fca042022-05-23 12:41:21 -070036 Mutex mProxyMutex;
Shuzhen Wang316781a2020-08-18 18:11:01 -070037 // Cached interface to the camera service proxy in system service
Austin Borger74fca042022-05-23 12:41:21 -070038 sp<hardware::ICameraServiceProxy> mCameraServiceProxy;
Shuzhen Wang316781a2020-08-18 18:11:01 -070039
Austin Borger74fca042022-05-23 12:41:21 -070040 class CameraSessionStatsWrapper {
Avichal Rakesh88fc5222023-03-03 15:00:59 -080041 private:
Shuzhen Wang316781a2020-08-18 18:11:01 -070042 hardware::CameraSessionStats mSessionStats;
43 Mutex mLock; // lock for per camera session stats
44
Austin Borger74fca042022-05-23 12:41:21 -070045 /**
46 * Update the session stats of a given camera device (open/close/active/idle) with
47 * the camera proxy service in the system service
48 */
49 void updateProxyDeviceState(sp<hardware::ICameraServiceProxy>& proxyBinder);
50
Avichal Rakesh88fc5222023-03-03 15:00:59 -080051 public:
Shuzhen Wang316781a2020-08-18 18:11:01 -070052 CameraSessionStatsWrapper(const String16& cameraId, int facing, int newCameraState,
Avichal Rakesh88fc5222023-03-03 15:00:59 -080053 const String16& clientName, int apiLevel, bool isNdk,
54 int32_t latencyMs, int64_t logId)
55 : mSessionStats(cameraId, facing, newCameraState, clientName, apiLevel, isNdk,
56 latencyMs, logId) {}
Shuzhen Wang316781a2020-08-18 18:11:01 -070057
Austin Borger74fca042022-05-23 12:41:21 -070058 void onOpen(sp<hardware::ICameraServiceProxy>& proxyBinder);
Shuzhen Wang03fe6232023-02-05 12:41:15 -080059 void onClose(sp<hardware::ICameraServiceProxy>& proxyBinder, int32_t latencyMs,
60 bool deviceError);
Shuzhen Wang316781a2020-08-18 18:11:01 -070061 void onStreamConfigured(int operatingMode, bool internalReconfig, int32_t latencyMs);
Austin Borger74fca042022-05-23 12:41:21 -070062 void onActive(sp<hardware::ICameraServiceProxy>& proxyBinder, float maxPreviewFps);
63 void onIdle(sp<hardware::ICameraServiceProxy>& proxyBinder,
64 int64_t requestCount, int64_t resultErrorCount, bool deviceError,
Shuzhen Wang9372b0b2022-05-11 18:55:19 -070065 const std::string& userTag, int32_t videoStabilizationMode,
Shuzhen Wang316781a2020-08-18 18:11:01 -070066 const std::vector<hardware::CameraStreamStats>& streamStats);
67 };
68
69 // Lock for camera session stats map
Austin Borger74fca042022-05-23 12:41:21 -070070 Mutex mLock;
Shuzhen Wang316781a2020-08-18 18:11:01 -070071 // Map from camera id to the camera's session statistics
Austin Borger74fca042022-05-23 12:41:21 -070072 std::map<String8, std::shared_ptr<CameraSessionStatsWrapper>> mSessionStatsMap;
Shuzhen Wang316781a2020-08-18 18:11:01 -070073
Avichal Rakesh88fc5222023-03-03 15:00:59 -080074 std::random_device mRandomDevice; // pulls 32-bit random numbers from /dev/urandom
75
Austin Borger74fca042022-05-23 12:41:21 -070076 sp<hardware::ICameraServiceProxy> getCameraServiceProxy();
Shuzhen Wang316781a2020-08-18 18:11:01 -070077
Avichal Rakesh88fc5222023-03-03 15:00:59 -080078 // Returns a randomly generated ID that is suitable for logging the event. A new identifier
79 // should only be generated for an open event. All other events for the cameraId should use the
80 // ID generated for the open event associated with them.
81 static int64_t generateLogId(std::random_device& randomDevice);
82
Shuzhen Wang316781a2020-08-18 18:11:01 -070083public:
Austin Borger74fca042022-05-23 12:41:21 -070084 CameraServiceProxyWrapper(sp<hardware::ICameraServiceProxy> serviceProxy = nullptr) :
85 mCameraServiceProxy(serviceProxy)
86 { }
87
88 static sp<hardware::ICameraServiceProxy> getDefaultCameraServiceProxy();
89
Shuzhen Wang316781a2020-08-18 18:11:01 -070090 // Open
Austin Borger74fca042022-05-23 12:41:21 -070091 void logOpen(const String8& id, int facing,
Shuzhen Wang316781a2020-08-18 18:11:01 -070092 const String16& clientPackageName, int apiLevel, bool isNdk,
93 int32_t latencyMs);
94
95 // Close
Shuzhen Wang03fe6232023-02-05 12:41:15 -080096 void logClose(const String8& id, int32_t latencyMs, bool deviceError);
Shuzhen Wang316781a2020-08-18 18:11:01 -070097
98 // Stream configuration
Austin Borger74fca042022-05-23 12:41:21 -070099 void logStreamConfigured(const String8& id, int operatingMode, bool internalReconfig,
Shuzhen Wang316781a2020-08-18 18:11:01 -0700100 int32_t latencyMs);
101
102 // Session state becomes active
Austin Borger74fca042022-05-23 12:41:21 -0700103 void logActive(const String8& id, float maxPreviewFps);
Shuzhen Wang316781a2020-08-18 18:11:01 -0700104
105 // Session state becomes idle
Austin Borger74fca042022-05-23 12:41:21 -0700106 void logIdle(const String8& id,
Shuzhen Wang316781a2020-08-18 18:11:01 -0700107 int64_t requestCount, int64_t resultErrorCount, bool deviceError,
Shuzhen Wang9372b0b2022-05-11 18:55:19 -0700108 const std::string& userTag, int32_t videoStabilizationMode,
Shuzhen Wang316781a2020-08-18 18:11:01 -0700109 const std::vector<hardware::CameraStreamStats>& streamStats);
110
111 // Ping camera service proxy for user update
Austin Borger74fca042022-05-23 12:41:21 -0700112 void pingCameraServiceProxy();
Emilian Peevb91f1802021-03-23 14:50:28 -0700113
Emilian Peev5368ebf2021-10-08 17:52:18 -0700114 // Return the current top activity rotate and crop override.
Austin Borger74fca042022-05-23 12:41:21 -0700115 int getRotateAndCropOverride(String16 packageName, int lensFacing, int userId);
Austin Borger5f7abe22022-04-26 15:55:10 -0700116
Bharatt Kukreja7146ced2022-10-25 15:45:29 +0000117 // Return the current top activity autoframing.
118 int getAutoframingOverride(const String16& packageName);
119
Austin Borger5f7abe22022-04-26 15:55:10 -0700120 // Detect if the camera is disabled by device policy.
Austin Borger9bfa0a72022-08-03 17:50:40 -0700121 bool isCameraDisabled(int userId);
Shuzhen Wang316781a2020-08-18 18:11:01 -0700122};
123
124} // android
125
126#endif // ANDROID_SERVERS_CAMERA_SERVICE_PROXY_WRAPPER_H_