diff --git a/android/1.0/Android.mk b/android/1.0/Android.mk index 434b4321..122ff8d1 100644 --- a/android/1.0/Android.mk +++ b/android/1.0/Android.mk @@ -81,4 +81,9 @@ LOCAL_SHARED_LIBRARIES += \ android.hardware.gnss@1.0 \ LOCAL_CFLAGS += $(GNSS_CFLAGS) + +ifneq ($(LOC_HIDL_VERSION),) +LOCAL_CFLAGS += -DLOC_HIDL_VERSION='"$(LOC_HIDL_VERSION)"' +endif + include $(BUILD_EXECUTABLE) diff --git a/android/1.0/service.cpp b/android/1.0/service.cpp index ee61a102..04bb8abf 100644 --- a/android/1.0/service.cpp +++ b/android/1.0/service.cpp @@ -22,22 +22,63 @@ #include #include - #include "loc_cfg.h" +#include "loc_misc_utils.h" + extern "C" { #include "vndfwk-detect.h" } +#ifdef ARCH_ARM_32 +#define DEFAULT_HW_BINDER_MEM_SIZE 65536 +#endif + using android::hardware::gnss::V1_0::IGnss; -using android::hardware::defaultPassthroughServiceImplementation; + +using android::hardware::configureRpcThreadpool; +using android::hardware::registerPassthroughServiceImplementation; +using android::hardware::joinRpcThreadpool; + +using android::status_t; +using android::OK; + +typedef int vendorEnhancedServiceMain(int /* argc */, char* /* argv */ []); int main() { + + ALOGI("%s", __FUNCTION__); + bool vendorEnhanced = isRunningWithVendorEnhancedFramework(); setVendorEnhanced(vendorEnhanced); - if (!vendorEnhanced) { - return defaultPassthroughServiceImplementation(); +#ifdef ARCH_ARM_32 + android::hardware::ProcessState::initWithMmapSize((size_t)(DEFAULT_HW_BINDER_MEM_SIZE)); +#endif + configureRpcThreadpool(1, true); + status_t status; + + status = registerPassthroughServiceImplementation(); + if (status == OK) { + if (vendorEnhanced) { + #ifdef LOC_HIDL_VERSION + #define VENDOR_ENHANCED_LIB "vendor.qti.gnss@" LOC_HIDL_VERSION "-service.so" + + void* libHandle = NULL; + vendorEnhancedServiceMain* vendorEnhancedMainMethod = (vendorEnhancedServiceMain*) + dlGetSymFromLib(libHandle, VENDOR_ENHANCED_LIB, "main"); + if (NULL != vendorEnhancedMainMethod) { + (*vendorEnhancedMainMethod)(0, NULL); + } + #else + ALOGE("LOC_HIDL_VERSION not defined."); + #endif + } + + joinRpcThreadpool(); + } else { - return -1; + ALOGE("Error while registering IGnss 1.0 service: %d", status); } + + return 0; } diff --git a/android/1.1/Android.mk b/android/1.1/Android.mk index 33e5b0dc..5c97f400 100644 --- a/android/1.1/Android.mk +++ b/android/1.1/Android.mk @@ -83,4 +83,9 @@ LOCAL_SHARED_LIBRARIES += \ android.hardware.gnss@1.1 \ LOCAL_CFLAGS += $(GNSS_CFLAGS) + +ifneq ($(LOC_HIDL_VERSION),) +LOCAL_CFLAGS += -DLOC_HIDL_VERSION='"$(LOC_HIDL_VERSION)"' +endif + include $(BUILD_EXECUTABLE) diff --git a/android/1.1/service.cpp b/android/1.1/service.cpp index c1bc6b0e..bf7ad07c 100644 --- a/android/1.1/service.cpp +++ b/android/1.1/service.cpp @@ -22,22 +22,63 @@ #include #include - #include "loc_cfg.h" +#include "loc_misc_utils.h" + extern "C" { #include "vndfwk-detect.h" } +#ifdef ARCH_ARM_32 +#define DEFAULT_HW_BINDER_MEM_SIZE 65536 +#endif + using android::hardware::gnss::V1_1::IGnss; -using android::hardware::defaultPassthroughServiceImplementation; + +using android::hardware::configureRpcThreadpool; +using android::hardware::registerPassthroughServiceImplementation; +using android::hardware::joinRpcThreadpool; + +using android::status_t; +using android::OK; + +typedef int vendorEnhancedServiceMain(int /* argc */, char* /* argv */ []); int main() { + + ALOGI("%s", __FUNCTION__); + bool vendorEnhanced = isRunningWithVendorEnhancedFramework(); setVendorEnhanced(vendorEnhanced); - if (!vendorEnhanced) { - return defaultPassthroughServiceImplementation(); +#ifdef ARCH_ARM_32 + android::hardware::ProcessState::initWithMmapSize((size_t)(DEFAULT_HW_BINDER_MEM_SIZE)); +#endif + configureRpcThreadpool(1, true); + status_t status; + + status = registerPassthroughServiceImplementation(); + if (status == OK) { + if (vendorEnhanced) { + #ifdef LOC_HIDL_VERSION + #define VENDOR_ENHANCED_LIB "vendor.qti.gnss@" LOC_HIDL_VERSION "-service.so" + + void* libHandle = NULL; + vendorEnhancedServiceMain* vendorEnhancedMainMethod = (vendorEnhancedServiceMain*) + dlGetSymFromLib(libHandle, VENDOR_ENHANCED_LIB, "main"); + if (NULL != vendorEnhancedMainMethod) { + (*vendorEnhancedMainMethod)(0, NULL); + } + #else + ALOGE("LOC_HIDL_VERSION not defined."); + #endif + } + + joinRpcThreadpool(); + } else { - return -1; + ALOGE("Error while registering IGnss 1.1 service: %d", status); } + + return 0; } diff --git a/android/2.0/Android.mk b/android/2.0/Android.mk index 0fa50bdf..244bd9c1 100644 --- a/android/2.0/Android.mk +++ b/android/2.0/Android.mk @@ -89,4 +89,9 @@ LOCAL_SHARED_LIBRARIES += \ android.hardware.gnss@2.0 \ LOCAL_CFLAGS += $(GNSS_CFLAGS) + +ifneq ($(LOC_HIDL_VERSION),) +LOCAL_CFLAGS += -DLOC_HIDL_VERSION='"$(LOC_HIDL_VERSION)"' +endif + include $(BUILD_EXECUTABLE) diff --git a/android/2.0/service.cpp b/android/2.0/service.cpp index 1fdccabe..16f0b06b 100644 --- a/android/2.0/service.cpp +++ b/android/2.0/service.cpp @@ -23,20 +23,62 @@ #include #include #include "loc_cfg.h" +#include "loc_misc_utils.h" extern "C" { #include "vndfwk-detect.h" } + +#ifdef ARCH_ARM_32 +#define DEFAULT_HW_BINDER_MEM_SIZE 65536 +#endif + using android::hardware::gnss::V2_0::IGnss; -using android::hardware::defaultPassthroughServiceImplementation; + +using android::hardware::configureRpcThreadpool; +using android::hardware::registerPassthroughServiceImplementation; +using android::hardware::joinRpcThreadpool; + +using android::status_t; +using android::OK; + +typedef int vendorEnhancedServiceMain(int /* argc */, char* /* argv */ []); int main() { + + ALOGI("%s", __FUNCTION__); + bool vendorEnhanced = isRunningWithVendorEnhancedFramework(); setVendorEnhanced(vendorEnhanced); - if (!vendorEnhanced) { - return defaultPassthroughServiceImplementation(); +#ifdef ARCH_ARM_32 + android::hardware::ProcessState::initWithMmapSize((size_t)(DEFAULT_HW_BINDER_MEM_SIZE)); +#endif + configureRpcThreadpool(1, true); + status_t status; + + status = registerPassthroughServiceImplementation(); + if (status == OK) { + if (vendorEnhanced) { + #ifdef LOC_HIDL_VERSION + #define VENDOR_ENHANCED_LIB "vendor.qti.gnss@" LOC_HIDL_VERSION "-service.so" + + void* libHandle = NULL; + vendorEnhancedServiceMain* vendorEnhancedMainMethod = (vendorEnhancedServiceMain*) + dlGetSymFromLib(libHandle, VENDOR_ENHANCED_LIB, "main"); + if (NULL != vendorEnhancedMainMethod) { + (*vendorEnhancedMainMethod)(0, NULL); + } + #else + ALOGE("LOC_HIDL_VERSION not defined."); + #endif + } + + joinRpcThreadpool(); + } else { - return -1; + ALOGE("Error while registering IGnss 2.0 service: %d", status); } + + return 0; }