어셈블리어를 그렇게 잘 알진 못하는데요 ㅜ.ㅜ
크게 인텔 문법과 AT&T 문법으로 분류한다고 했을 때, AT&T 문법의 경우 destination이 뒤에 위치하는 문법으로 알고 있습니다.
GNU 컴파일러의 경우에도 AT&T 문법을 따른다고 여러곳에서 본 것 같은데요.
제가 arm-linux-gnueabi-gcc 크로스 컴파일러를 이용해서 어셈블리 코드를 생성해 보면, 다음처럼 destination이 앞에 위치하는 것 같은데.. 제가 개념을 좀 혼동하는 건지, 뭔가 변화가 있는건지 궁금하네요.
일부를 기술하였습니다.
sub sp, sp, #16
add r7, sp, #0
movw r3, #:lower16:__stack_chk_guard
movt r3, #:upper16:__stack_chk_guard
ldr r3, [r3, #0]
str r3, [r7, #12]
AT&T 문법대로라면 위에 destination들이 다 뒤에 위치해야 하지 않나요?