# Copyright (C) 2017 TeamWin Recovery 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. LOCAL_PATH := $(call my-dir) ifeq ($(TW_INCLUDE_CRYPTO), true) ifneq ($(TW_CRYPTO_USE_SYSTEM_VOLD),) # Parse TW_CRYPTO_USE_SYSTEM_VOLD ifeq ($(TW_CRYPTO_USE_SYSTEM_VOLD),true) # Just enabled, so only vold + vdc services := else # Additional services needed by vold services := $(TW_CRYPTO_USE_SYSTEM_VOLD) endif # List of .rc files for each additional service rc_files := $(foreach item,$(services),init.recovery.vold_decrypt.$(item).rc) include $(CLEAR_VARS) LOCAL_MODULE := init.recovery.vold_decrypt.rc LOCAL_MODULE_TAGS := eng LOCAL_MODULE_CLASS := RECOVERY_EXECUTABLES # Cannot send to TARGET_RECOVERY_ROOT_OUT since build system wipes init*.rc # during ramdisk creation and only allows init.recovery.*.rc files to be copied # from TARGET_ROOT_OUT thereafter LOCAL_MODULE_PATH := $(TARGET_ROOT_OUT) LOCAL_SRC_FILES := $(LOCAL_MODULE) # Add additional .rc files and imports into init.recovery.vold_decrypt.rc # Note: any init.recovery.vold_decrypt.{service}.rc that are not default # in crypto/vold_decrypt should be in the device tree LOCAL_POST_INSTALL_CMD := $(hide) \ $(foreach item, $(rc_files), \ sed -i '1iimport \/$(item)' "$(TARGET_ROOT_OUT)/$(LOCAL_MODULE)"; \ if [ -f "$(LOCAL_PATH)/$(item)" ]; then \ cp -f "$(LOCAL_PATH)/$(item)" "$(TARGET_ROOT_OUT)"/; \ fi; \ ) ifeq ($(shell test $(PLATFORM_SDK_VERSION) -lt 26; echo $$?),0) # Truncate service_name to max 16 characters LOCAL_POST_INSTALL_CMD += \ $(foreach item, $(rc_files), \ if [ -f "$(TARGET_ROOT_OUT)/$(item)" ]; then \ sed -i 's/\([ \t]*service[ \t]*\)\(.\{16\}\).*\([ \t].*\)/\1\2\3/' "$(TARGET_ROOT_OUT)/$(item)"; \ fi; \ ) endif include $(BUILD_PREBUILT) include $(CLEAR_VARS) LOCAL_MODULE := libvolddecrypt LOCAL_MODULE_TAGS := eng optional LOCAL_CFLAGS := -Wall ifeq ($(shell test $(PLATFORM_SDK_VERSION) -lt 23; echo $$?),0) LOCAL_C_INCLUDES += external/stlport/stlport bionic bionic/libstdc++/include endif ifneq ($(services),) ifeq ($(shell test $(PLATFORM_SDK_VERSION) -lt 26; echo $$?),0) # Truncate service_name to max 12 characters due to the 4 character prefix truncated_services := $(foreach item,$(services),$(shell echo -n "$(item)" | sed 's/\(.\{12\}\).*/\1/')) LOCAL_CFLAGS += -DTW_CRYPTO_SYSTEM_VOLD_SERVICES='"$(truncated_services)"' LOCAL_CFLAGS += -D_USING_SHORT_SERVICE_NAMES else LOCAL_CFLAGS += -DTW_CRYPTO_SYSTEM_VOLD_SERVICES='"$(services)"' endif endif ifeq ($(TW_CRYPTO_SYSTEM_VOLD_DEBUG),true) # Enabling strace will expose the password in the strace logs!! LOCAL_CFLAGS += -DTW_CRYPTO_SYSTEM_VOLD_DEBUG else ifneq ($(TW_CRYPTO_SYSTEM_VOLD_DEBUG),) # Specify strace path LOCAL_CFLAGS += -DTW_CRYPTO_SYSTEM_VOLD_DEBUG LOCAL_CFLAGS += -DVD_STRACE_BIN=\"$(TW_CRYPTO_SYSTEM_VOLD_DEBUG)\" endif endif LOCAL_SRC_FILES = vold_decrypt.cpp LOCAL_SHARED_LIBRARIES := libcutils include $(BUILD_STATIC_LIBRARY) endif endif