ARM asssembler질문좀 드립니다.

junteken의 이미지

안녕하세요.

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도 마찬가지로 밑에 연산이 들어갑니다.

혹시 아시는분 있으시면 답변 좀 부탁드립니다.

klenui의 이미지

코멘트에 다 나와있네요... Hello 라는 문자열 주소 구하는거라고...

사족인것 같습니다만 첨언을 하면.. ARM 은 32bit 주소공간 인데, 명령어도 32bit잖아요(RISC).
그래서 어떤 자료가 저장된 주소를 사용하려 할때, PC기반의 상대주소를 사용하는 경우가 있습니다.

문제가 되는 줄은 다음줄일텐데요

.text:00000C10 LDR R1, =(aHello - 0xC1A)

여기서 R1에 PC기반이 아닌 "Hello"의 절대 주소를 넣으려면 절대 주소가 32비트이니 32이트 opcode에 넣기가 애매할 겁니다.
이방법이 유일한 방법은 아닌데, 컴파일러가 이방법을 선택한거지요.. 어떤 이유에서건.

junteken의 이미지

아 저는 LDR R1, =(aHello - 0xC1A) 이부분만으로 "Hello"의 저장된 위치가 완전히 구해진줄 생각했네요

답변 감사합니다~ 많은 도움 되었습니다~^^

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.