arm彙編學習(四)

 

1、android jni實現
1.靜態實現jni:先由Java獲得本地方法的聲明,而後再經過JNI實現該聲明方法。
2.動態實現jni:先經過JNI重載JNI_OnLoad()實現本地方法,而後直接在Java中調用本地方法。html

採用靜態實現的方式,若是沒有進行加密處理,很容易就在IDA導出函數搜到
採用動態實現的方式,還能起到必定的隱藏做用,導出的部分不是就能直接看到java層調的函數名,而是綁定的函數名java

native層:
在JNI_OnLoad註冊相關函數android

JNIEXPORT jstring JNICALL native_hello(JNIEnv *env, jclass clazz)
{
return (*env)->NewStringUTF(env, "hello load jni.");
}

// Java和JNI函數的綁定表函數

static JNINativeMethod method_table[] = {
{ "HelloLoad", "()Ljava/lang/String;", (void*)native_hello },//綁定
};


java層:
// jni中註冊的方法加密

public native String HelloLoad();


2、Android中調用Arm彙編代碼spa

Android.mk文件.net

# This file is jni/Android.mk

LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)

LOCAL_ARM_MODE := arm

# Name of the local module
LOCAL_MODULE := hello-jni
# The files that make up the source code
LOCAL_SRC_FILES := hello-jni.c multiple.s

include $(BUILD_SHARED_LIBRARY)

multiple.s符合gnu語法code

@ This file is jni/multiple.s
.text
.align    2
.global    armFunction
.type    armFunction, %function
armFunction:
@ Multiply by 10. Input value and return value in r0
stmfd    sp!, {fp,ip,lr}
mov    r3, r0, asl #3
add    r0, r3, r0, asl #1
ldmfd    sp!, {fp,ip,lr}
bx    lr
.size    armFunction, .-armFunction

直接調用在c中armFunction(input)調用htm

3、參考:
http://www.cnblogs.com/skywang12345/archive/2013/05/23/3095074.html
http://www.cnblogs.com/skywang12345/archive/2013/05/23/3092491.html
http://my.oschina.net/redhouse/blog/101375
http://blog.csdn.net/dndxhej/article/details/7515949blog

相關文章
相關標籤/搜索