android C语言调试汇编

本文介绍了一个使用 Android JNI 实现的多线程示例,包括 C 语言编写的线程函数和 Java 调用接口。通过示例展示了如何在 Android 中创建和管理本地线程,并在后台循环打印全局变量。

有一点示范代码,不过代码内容有点敏感,所以我换成网上找的一段代码来进行调试。

源码来自:detect_bt_arm
在android jni中


void *thread2(void *) __attribute__ ((noreturn));

void thread1(void) __attribute__ ((noreturn));

uint32_t global_value = 0;
#define PRINT "value: 0x%x\n"

void *thread2(void *data) {
    for (;;) {
        sleep(1);
        __android_log_print(ANDROID_LOG_ERROR, "detect", PRINT, global_value);
    }
}

void thread1(void) {
    for (;;) {
        sleep(5);
        __asm__ __volatile__ ("mov r0, %[global];"
                "mov r1, #1;"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
                "add r1, r1, #1;" "str r1, [r0];"
        :
        :[global] "r"(&global_value)
        :
        );
    }
}

extern "C"
JNIEXPORT jstring JNICALL
Java_xd_magic_os_until_BaseActivity_detectedBTArm(
        JNIEnv *env,
        jobject /* this */) {
    std::string message = "";

    pthread_t thread_data2;
    int status;

    status = pthread_create(&thread_data2, NULL, thread2, NULL);
    if (status)
        perror("pthread_create()");
    thread1();

    return env->NewStringUTF(message.c_str());
}

下面是一点方法:

android中打印日志的方法是:

#include <android/log.h>

__android_log_write(ANDROID_LOG_ERROR, "yeshen", "start 1");
__android_log_print(ANDROID_LOG_ERROR, "yeshen", "out=%d\n", a);

编译出so库之后看so的信息

file libnative-lib.so

libnative-lib.so: ELF 32-bit LSB shared object, ARM, EABI5 version 1 (SYSV), dynamically linked, BuildID[sha1]=392a53add6c490e6dc848cead3391b0a96802c68, not stripped

从so库看汇编代码

objDump -d libnative-lib.so > 1.txt
vim 1.txt

当然首先要先懂汇编的代码是要干嘛。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值