- This breaks boot if isSupported returns false for whatever reason (And I don't understand why it should register only if supported?)
64 lines
2.0 KiB
C++
64 lines
2.0 KiB
C++
/*
|
|
* Copyright (C) 2019 The LineageOS 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.
|
|
*/
|
|
|
|
// Here to avoid -Wmacro-redefined
|
|
#include "TouchscreenGesture.h"
|
|
|
|
#include <binder/ProcessState.h>
|
|
#include <hidl/HidlTransportSupport.h>
|
|
|
|
using android::hardware::configureRpcThreadpool;
|
|
using android::hardware::joinRpcThreadpool;
|
|
using android::sp;
|
|
using android::status_t;
|
|
using android::OK;
|
|
|
|
using ::vendor::lineage::touch::V1_0::samsung::TouchscreenGesture;
|
|
|
|
int main() {
|
|
sp<TouchscreenGesture> touchscreenGesture;
|
|
status_t status;
|
|
|
|
LOG(INFO) << "Touch HAL service is starting.";
|
|
|
|
touchscreenGesture = new TouchscreenGesture();
|
|
if (touchscreenGesture == nullptr) {
|
|
LOG(ERROR) << "Can not create an instance of Touch HAL TouchscreenGesture Iface, exiting.";
|
|
goto shutdown;
|
|
}
|
|
|
|
configureRpcThreadpool(1, true /*callerWillJoin*/);
|
|
|
|
if (!touchscreenGesture->isSupported())
|
|
LOG(WARNING) << "isSupported() returns false, registering stub implementation!";
|
|
|
|
status = touchscreenGesture->registerAsService();
|
|
if (status != OK) {
|
|
LOG(ERROR) << "Could not register service for Touch HAL TouchscreenGesture Iface ("
|
|
<< status << ")";
|
|
goto shutdown;
|
|
}
|
|
|
|
LOG(INFO) << "Touch HAL service is ready.";
|
|
joinRpcThreadpool();
|
|
|
|
// Should not pass this line
|
|
shutdown:
|
|
// In normal operation, we don't expect the thread pool to shutdown
|
|
LOG(ERROR) << "Touch HAL service is shutting down.";
|
|
return 1;
|
|
}
|