Loading services/core/java/com/android/server/vr/VrManagerService.java +8 −0 Original line number Diff line number Diff line Loading @@ -36,6 +36,9 @@ public class VrManagerService extends SystemService { public static final String TAG = "VrManagerService"; private static native void initializeNative(); private static native void setVrModeNative(boolean enabled); private final Object mLock = new Object(); private boolean mVrModeEnabled = false; private ArraySet<VrStateListener> mListeners = new ArraySet<>(); Loading Loading @@ -68,6 +71,10 @@ public class VrManagerService extends SystemService { @Override public void onStart() { synchronized(mLock) { initializeNative(); } publishLocalService(VrManagerInternal.class, new LocalService()); } Loading @@ -89,6 +96,7 @@ public class VrManagerService extends SystemService { mVrModeEnabled = enabled; // Log mode change event. Slog.i(TAG, "VR mode " + ((mVrModeEnabled) ? "enabled" : "disabled")); setVrModeNative(mVrModeEnabled); onVrModeChangedLocked(); } } Loading services/core/jni/Android.mk +1 −0 Original line number Diff line number Diff line Loading @@ -28,6 +28,7 @@ LOCAL_SRC_FILES += \ $(LOCAL_REL_DIR)/com_android_server_SerialService.cpp \ $(LOCAL_REL_DIR)/com_android_server_SystemServer.cpp \ $(LOCAL_REL_DIR)/com_android_server_tv_TvInputHal.cpp \ $(LOCAL_REL_DIR)/com_android_server_vr_VrManagerService.cpp \ $(LOCAL_REL_DIR)/com_android_server_UsbDeviceManager.cpp \ $(LOCAL_REL_DIR)/com_android_server_UsbMidiDevice.cpp \ $(LOCAL_REL_DIR)/com_android_server_UsbHostManager.cpp \ Loading services/core/jni/com_android_server_vr_VrManagerService.cpp 0 → 100644 +74 −0 Original line number Diff line number Diff line /* * Copyright (C) 2016 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 LOG_TAG "VrManagerService" #include <android_runtime/AndroidRuntime.h> #include <jni.h> #include <JNIHelp.h> #include <utils/Errors.h> #include <utils/Log.h> #include <hardware/hardware.h> #include <hardware/vr.h> namespace android { static vr_module_t *gVrHardwareModule = NULL; static void init_native(JNIEnv* /* env */, jclass /* clazz */) { if (gVrHardwareModule != NULL) { // This call path should never be hit. ALOGE("%s: May not initialize VR hardware module more than once!", __FUNCTION__); return; } int err = hw_get_module(VR_HARDWARE_MODULE_ID, (hw_module_t const**)&gVrHardwareModule); if (err) { ALOGW("%s: Could not open VR hardware module, error %s (%d).", __FUNCTION__, strerror(-err), err); return; } // Call init method if implemented. if (gVrHardwareModule->init) { gVrHardwareModule->init(gVrHardwareModule); } } static void setVrMode_native(JNIEnv* /* env */, jclass /* clazz */, jboolean enabled) { if (gVrHardwareModule == NULL) { // There is no VR hardware module implemented, do nothing. return; } // Call set_vr_mode method, this must be implemented if the HAL exists. gVrHardwareModule->set_vr_mode(gVrHardwareModule, static_cast<bool>(enabled)); } static const JNINativeMethod method_table[] = { { "initializeNative", "()V", (void*)init_native }, { "setVrModeNative", "(Z)V", (void*)setVrMode_native }, }; int register_android_server_vr_VrManagerService(JNIEnv *env) { return jniRegisterNativeMethods(env, "com/android/server/vr/VrManagerService", method_table, NELEM(method_table)); } }; // namespace android services/core/jni/onload.cpp +2 −0 Original line number Diff line number Diff line Loading @@ -35,6 +35,7 @@ int register_android_server_SystemServer(JNIEnv* env); int register_android_server_UsbDeviceManager(JNIEnv* env); int register_android_server_UsbMidiDevice(JNIEnv* env); int register_android_server_UsbHostManager(JNIEnv* env); int register_android_server_vr_VrManagerService(JNIEnv* env); int register_android_server_VibratorService(JNIEnv* env); int register_android_server_location_GnssLocationProvider(JNIEnv* env); int register_android_server_location_FlpHardwareProvider(JNIEnv* env); Loading Loading @@ -69,6 +70,7 @@ extern "C" jint JNI_OnLoad(JavaVM* vm, void* /* reserved */) register_android_server_UsbDeviceManager(env); register_android_server_UsbMidiDevice(env); register_android_server_UsbHostManager(env); register_android_server_vr_VrManagerService(env); register_android_server_VibratorService(env); register_android_server_SystemServer(env); register_android_server_location_GnssLocationProvider(env); Loading Loading
services/core/java/com/android/server/vr/VrManagerService.java +8 −0 Original line number Diff line number Diff line Loading @@ -36,6 +36,9 @@ public class VrManagerService extends SystemService { public static final String TAG = "VrManagerService"; private static native void initializeNative(); private static native void setVrModeNative(boolean enabled); private final Object mLock = new Object(); private boolean mVrModeEnabled = false; private ArraySet<VrStateListener> mListeners = new ArraySet<>(); Loading Loading @@ -68,6 +71,10 @@ public class VrManagerService extends SystemService { @Override public void onStart() { synchronized(mLock) { initializeNative(); } publishLocalService(VrManagerInternal.class, new LocalService()); } Loading @@ -89,6 +96,7 @@ public class VrManagerService extends SystemService { mVrModeEnabled = enabled; // Log mode change event. Slog.i(TAG, "VR mode " + ((mVrModeEnabled) ? "enabled" : "disabled")); setVrModeNative(mVrModeEnabled); onVrModeChangedLocked(); } } Loading
services/core/jni/Android.mk +1 −0 Original line number Diff line number Diff line Loading @@ -28,6 +28,7 @@ LOCAL_SRC_FILES += \ $(LOCAL_REL_DIR)/com_android_server_SerialService.cpp \ $(LOCAL_REL_DIR)/com_android_server_SystemServer.cpp \ $(LOCAL_REL_DIR)/com_android_server_tv_TvInputHal.cpp \ $(LOCAL_REL_DIR)/com_android_server_vr_VrManagerService.cpp \ $(LOCAL_REL_DIR)/com_android_server_UsbDeviceManager.cpp \ $(LOCAL_REL_DIR)/com_android_server_UsbMidiDevice.cpp \ $(LOCAL_REL_DIR)/com_android_server_UsbHostManager.cpp \ Loading
services/core/jni/com_android_server_vr_VrManagerService.cpp 0 → 100644 +74 −0 Original line number Diff line number Diff line /* * Copyright (C) 2016 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 LOG_TAG "VrManagerService" #include <android_runtime/AndroidRuntime.h> #include <jni.h> #include <JNIHelp.h> #include <utils/Errors.h> #include <utils/Log.h> #include <hardware/hardware.h> #include <hardware/vr.h> namespace android { static vr_module_t *gVrHardwareModule = NULL; static void init_native(JNIEnv* /* env */, jclass /* clazz */) { if (gVrHardwareModule != NULL) { // This call path should never be hit. ALOGE("%s: May not initialize VR hardware module more than once!", __FUNCTION__); return; } int err = hw_get_module(VR_HARDWARE_MODULE_ID, (hw_module_t const**)&gVrHardwareModule); if (err) { ALOGW("%s: Could not open VR hardware module, error %s (%d).", __FUNCTION__, strerror(-err), err); return; } // Call init method if implemented. if (gVrHardwareModule->init) { gVrHardwareModule->init(gVrHardwareModule); } } static void setVrMode_native(JNIEnv* /* env */, jclass /* clazz */, jboolean enabled) { if (gVrHardwareModule == NULL) { // There is no VR hardware module implemented, do nothing. return; } // Call set_vr_mode method, this must be implemented if the HAL exists. gVrHardwareModule->set_vr_mode(gVrHardwareModule, static_cast<bool>(enabled)); } static const JNINativeMethod method_table[] = { { "initializeNative", "()V", (void*)init_native }, { "setVrModeNative", "(Z)V", (void*)setVrMode_native }, }; int register_android_server_vr_VrManagerService(JNIEnv *env) { return jniRegisterNativeMethods(env, "com/android/server/vr/VrManagerService", method_table, NELEM(method_table)); } }; // namespace android
services/core/jni/onload.cpp +2 −0 Original line number Diff line number Diff line Loading @@ -35,6 +35,7 @@ int register_android_server_SystemServer(JNIEnv* env); int register_android_server_UsbDeviceManager(JNIEnv* env); int register_android_server_UsbMidiDevice(JNIEnv* env); int register_android_server_UsbHostManager(JNIEnv* env); int register_android_server_vr_VrManagerService(JNIEnv* env); int register_android_server_VibratorService(JNIEnv* env); int register_android_server_location_GnssLocationProvider(JNIEnv* env); int register_android_server_location_FlpHardwareProvider(JNIEnv* env); Loading Loading @@ -69,6 +70,7 @@ extern "C" jint JNI_OnLoad(JavaVM* vm, void* /* reserved */) register_android_server_UsbDeviceManager(env); register_android_server_UsbMidiDevice(env); register_android_server_UsbHostManager(env); register_android_server_vr_VrManagerService(env); register_android_server_VibratorService(env); register_android_server_SystemServer(env); register_android_server_location_GnssLocationProvider(env); Loading