From 5fd1143c71ef98c130666f4e1044eb0da8f688c2 Mon Sep 17 00:00:00 2001 From: Tad Date: Thu, 26 Jan 2017 11:27:07 -0500 Subject: [PATCH] Edit the system.prop aswell --- Scripts/LAOS-14.1_Deblob.sh | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/Scripts/LAOS-14.1_Deblob.sh b/Scripts/LAOS-14.1_Deblob.sh index cffb563d..439ef0ec 100644 --- a/Scripts/LAOS-14.1_Deblob.sh +++ b/Scripts/LAOS-14.1_Deblob.sh @@ -1,12 +1,16 @@ #!/bin/bash + #Goal: Remove as many proprietary blobs without breaking core functionality #Outcome: Increased battery/performance/privacy/security, Decreased ROM size #This script and subsequent builds have been tested + base="/home/tad/Android/Build/LineageOS-14.1/" deblob() { dir=$1 blobList=$2; cd $base$dir; #Enter the target directory + cp Android.mk Android.mk.bak; + cp system.prop system.prop.bak; cp $blobList $blobList".bak"; #Make a backup blobs=""; @@ -15,8 +19,10 @@ deblob() { #ATFWD (Wireless Display) blobs=$blobs"ATFWD-daemon|atfwd.apk"; - #CNE (Automatic Cell/Wi-Fi Switching) XXX: Breaks radio XXX: Requires unsetting 'BOARD_USES_QCNE' in BoardConfig.mk and 'persist.cne.feature' in system.prop. + #CNE (Automatic Cell/Wi-Fi Switching) XXX: Breaks radio #blobs=$blobs"|andsfCne.xml|ATT_profile1.xml|ATT_profile2.xml|ATT_profile3.xml|ATT_profile4.xml|ATT_profiles.xml|cnd|cneapiclient.jar|cneapiclient.xml|CNEService.apk|com.quicinc.cne.jar|com.quicinc.cne.xml|ConnectivityExt.jar|ConnectivityExt.xml|libcneapiclient.so|libcneconn.so|libcneqmiutils.so|libcne.so|libNimsWrap.so|libvendorconn.so|libwqe.so|libxml.so|profile1.xml|profile2.xml|profile3.xml|profile4.xml|profile5.xml|ROW_profile1.xml|ROW_profile2.xml|ROW_profile3.xml|ROW_profile4.xml|ROW_profile5.xml|ROW_profiles.xml|SwimConfig.xml|VZW_profile1.xml|VZW_profile2.xml|VZW_profile3.xml|VZW_profile4.xml|VZW_profile5.xml|VZW_profile6.xml|VZW_profiles.xml"; + #sed -i 's/persist.cne.feature=1/persist.cne.feature=0/' system.prop; + #sed -i 's/BOARD_USES_QCNE := true/BOARD_USES_QCNE := false/' BoardConfig.mk; #Diag blobs=$blobs"|diag_klog|diag_mdlog|diag_mdlog-getlogs|diag_mdlog-wrap|diag_qshrink4_daemon|test_diag"; @@ -24,17 +30,23 @@ deblob() { #DivX (DRM) blobs=$blobs"|DxHDCP.cfg|dxhdcp2.b00|dxhdcp2.b01|dxhdcp2.b02|dxhdcp2.b03|dxhdcp2.mdt|libDxHdcp.so|libSHIMDivxDrm.so"; - #DPM (? Related to CNE) XXX: Requires unsetting 'persist.dpm.feature' in system.prop. + #DPM (? Related to CNE) blobs=$blobs"|com.qti.dpmframework.jar|com.qti.dpmframework.xml|dpmapi.jar|dpmapi.xml|dpm.conf|dpmd|dpmserviceapp.apk|libdpmctmgr.so|libdpmfdmgr.so|libdpmframework.so|libdpmnsrm.so|libdpmtcm.so|NsrmConfiguration.xml|tcmclient.jar"; + sed -i 's/persist.dpm.feature=3/persist.dpm.feature=0/' system.prop; + sed -i 's/persist.dpm.feature=2/persist.dpm.feature=0/' system.prop; + sed -i 's/persist.dpm.feature=1/persist.dpm.feature=0/' system.prop; #DRM XXX: Breaks full disk encryption #blobs=$blobs"|libdrmdecrypt.so|libdrmfs.so|libdrmtime.so|libtzdrmgenprov.so"; + echo "drm.service.enabled=false" >> system.prop; #Disable the DRM server #Google Widevine (DRM) blobs=$blobs"|com.google.widevine.software.drm.jar|com.google.widevine.software.drm.xml|libdrmwvmplugin.so|libwvdrmengine.so|libwvdrm_L1.so|libwvdrm_L3.so|libwvm.so|libWVphoneAPI.so|libWVStreamControlAPI_L1.so|libWVStreamControlAPI_L3.so|widevine.b00|widevine.b01|widevine.b02|widevine.b03|widevine.mdt"; + #grep -v "WV_SYMLINKS := $(addprefix $(TARGET_OUT_ETC)/firmware/,$(notdir $(WV_IMAGES)))" Android.mk >> Android.mk.new; + #mv Android.mk.new Android.mk; #GPS - #blobs=$blobs"|flp.conf|flp.default.so|flp.msm8084.so|gps.msm8084.so|gpsd|libflp.so|libloc_api_v02.so|libgps.utils.so|libloc_core.so|libloc_ds_api.so|libloc_eng.so|libloc_ext.so"; + #blobs=$blobs"|flp.conf|flp.default.so|flp.msm8084.so|gpsd|gps.msm8084.so|libflp.so|libgps.utils.so|libloc_api_v02.so|libloc_core.so|libloc_ds_api.so|libloc_eng.so|libloc_ext.so"; #HDCP (DRM) blobs=$blobs"|libmm-hdcpmgr.so"; @@ -45,9 +57,12 @@ deblob() { #Location XXX: TEST THIS blobs=$blobs"|com.qti.location.sdk.jar|com.qti.location.sdk.xml|com.qualcomm.location.apk|com.qualcomm.location.vzw_library.jar|com.qualcomm.location.vzw_library.xml|com.qualcomm.location.xml|izat.xt.srv.jar|izat.xt.srv.xml|libalarmservice_jni.so|libasn1cper.so|libasn1crt.so|libasn1crtx.so|libdataitems.so|libdrplugin_client.so|libDRPlugin.so|libevent_observer.so|libgdtap.so|libgeofence.so|libizat_core.so|liblbs_core.so|liblocationservice_glue.so|liblocationservice.so|liblowi_client.so|liblowi_wifihal_nl.so|liblowi_wifihal.so|libquipc_os_api.so|libquipc_ulp_adapter.so|libulp2.so|libxtadapter.so|libxt_native.so|libxtwifi_ulp_adaptor.so|libxtwifi_zpp_adaptor.so|location-mq|loc_launcher|lowi-server|slim_ap_daemon|slim_daemon|xtwifi-client|xtwifi-inet-agent"; + sed -i 's/persist.gps.qc_nlp_in_use=1/persist.gps.qc_nlp_in_use=0/' system.prop; #Microsoft Playready (DRM) blobs=$blobs"|playread.b00|playread.b01|playread.b02|playread.b03|playread.mdt"; + #grep -v "PLAYREADY_SYMLINKS := $(addprefix $(TARGET_OUT_ETC)/firmware/,$(notdir $(PLAYREADY_IMAGES)))" Android.mk >> Android.mk.new; + #mv Android.mk.new Android.mk; #Misc blobs=$blobs"|libuiblur.so"; @@ -75,6 +90,7 @@ deblob() { delta=$(($(wc -l < $blobList".bak") - $(wc -l < $blobList))); #Calculate the difference in size echo "Removed "$delta" blobs from "$dir$blobList; #Inform the user sh -c "cd $base$dir && ./setup-makefiles.sh"; #Update the makefiles + } #Find all using: cd device && find . -name "*proprietary*.txt" | grep -v ".bak"