arm匯編學(xué)習(xí)(四)
1.靜態(tài)實現(xiàn)jni:先由Java得到本地方法的聲明,然后再通過JNI實現(xiàn)該聲明方法。
2.動態(tài)實現(xiàn)jni:先通過JNI重載JNI_OnLoad()實現(xiàn)本地方法,然后直接在Java中調(diào)用本地方法。
采用靜態(tài)實現(xiàn)的方式,如果沒有進(jìn)行加密處理,很容易就在IDA導(dǎo)出函數(shù)搜到
采用動態(tài)實現(xiàn)的方式,還能起到一定的隱藏作用,導(dǎo)出的部分不是就能直接看到j(luò)ava層調(diào)的函數(shù)名,而是綁定的函數(shù)名
native層:
在JNI_OnLoad注冊相關(guān)函數(shù)
JNIEXPORT jstring JNICALL native_hello(JNIEnv *env, jclass clazz){return (*env)->NewStringUTF(env, "hello load jni.");}
// Java和JNI函數(shù)的綁定表
static JNINativeMethod method_table[] = {{ "HelloLoad", "()Ljava/lang/String;", (void*)native_hello },//綁定};
java層:
// jni中注冊的方法
public native String HelloLoad();
二、Android中調(diào)用Arm匯編代碼
Android.mk文件
# This file is jni/Android.mkLOCAL_PATH := $(call my-dir)include $(CLEAR_VARS)LOCAL_ARM_MODE := arm# Name of the local moduleLOCAL_MODULE := hello-jni# The files that make up the source codeLOCAL_SRC_FILES := hello-jni.c multiple.sinclude $(BUILD_SHARED_LIBRARY)
multiple.s符合gnu語法
@ This file is jni/multiple.s.text.align 2.global armFunction.type armFunction, %functionarmFunction:@ Multiply by 10. Input value and return value in r0stmfd sp!, {fp,ip,lr}mov r3, r0, asl #3add r0, r3, r0, asl #1ldmfd sp!, {fp,ip,lr}bx lr.size armFunction, .-armFunction
直接調(diào)用在c中armFunction(input)調(diào)用
評論