ARM asssembler질문좀 드립니다.
안녕하세요.
ARM Assembler공부를 해볼려고 아래의 C코드를 so 라이브러리 형태로 빌드한후에 해당 so파일을 IDA라는 disassembler툴로 열어보았습니다.
코드는 아래와 같습니다.
* C코드
void Java_org_androidtown_thread_SampleThreadActivity_hello(JNIEnv *env, jobject thiz)
{
__android_log_print(ANDROID_LOG_ERROR, "Hello", "Hello Jni World %s : %d", __FILE__, __LINE__);
}
* ASM코드
.text:00000C0C PUSH {R0-R2,LR}
.text:00000C0E MOVS R0, #8
.text:00000C10 LDR R1, =(aHello - 0xC1A)
.text:00000C12 LDR R2, =(aHelloJniWorldS - 0xC1E)
.text:00000C14 LDR R3, =(aJniHello_c - 0xC20)
.text:00000C16 ADD R1, PC ; "Hello"
.text:00000C18 STR R0, [SP,#0x10+var_10]
.text:00000C1A ADD R2, PC ; "Hello Jni World %s : %d"
.text:00000C1C ADD R3, PC ; "jni/hello.c"
.text:00000C1E MOVS R0, #6
.text:00000C20 BLX __android_log_print
.text:00000C24 POP {R1-R3,PC}
위의 어셈코드에서 R1 ~ R3레지스터에 Argument값을 넣어서 __android_log_print 함수를 호출하는 과정인데요
ADD R1, PC ---> 이 코드가 이해가 되질 않습니다. PC값을 더해서 R1에 또 왜 넣는건지?
R2, R3도 마찬가지로 밑에 연산이 들어갑니다.
혹시 아시는분 있으시면 답변 좀 부탁드립니다.
코멘트에 다 나와있네요... Hello 라는 문자열
코멘트에 다 나와있네요... Hello 라는 문자열 주소 구하는거라고...
사족인것 같습니다만 첨언을 하면.. ARM 은 32bit 주소공간 인데, 명령어도 32bit잖아요(RISC).
그래서 어떤 자료가 저장된 주소를 사용하려 할때, PC기반의 상대주소를 사용하는 경우가 있습니다.
문제가 되는 줄은 다음줄일텐데요
.text:00000C10 LDR R1, =(aHello - 0xC1A)
여기서 R1에 PC기반이 아닌 "Hello"의 절대 주소를 넣으려면 절대 주소가 32비트이니 32이트 opcode에 넣기가 애매할 겁니다.
이방법이 유일한 방법은 아닌데, 컴파일러가 이방법을 선택한거지요.. 어떤 이유에서건.
답변 감사합니다
아 저는 LDR R1, =(aHello - 0xC1A) 이부분만으로 "Hello"의 저장된 위치가 완전히 구해진줄 생각했네요
답변 감사합니다~ 많은 도움 되었습니다~^^
댓글 달기