Hi I am a beginner in assembly language, is there a difference between movl (%rdi,%r12), %r10d and movl (%rdi,%r12,4), %r10d? I tried both of them and they both seem to do the same job-- saving the element of %rdi at %r12 position to %r10d. Is the 4 in the 2nd example really necessary?
x86-64 accessing element of array
715 views Asked by M. Chen At
1
There are 1 answers
Related Questions in ASSEMBLY
- (x64 Nasm) Writeline function on Linux
- Is the compiler Xcode uses to produce Assembly code a bad compiler?
- Why do we need AX instead of MOV DS, data directly with a segment?
- Bootloader in Assembly with Linux kernel
- How should the byte sequence 0x40 0x55 be interpreted by an x86-64 emulator?
- C++ code into assembly
- Drawing circles of increasing radius
- Assembly print on screen using pop ecx
- Equivalent to asm volatile in Gfortran?
- Show 640x480 BMP image with inline ASM c++
Related Questions in X86-64
- How should the byte sequence 0x40 0x55 be interpreted by an x86-64 emulator?
- os kern error : "ld: symbol(s) not found for architecture x86_64"
- Can feenableexcept hurt a program performance?
- MASM console window creation troubles (maybe my stack frame??)
- Bomb lab phase 5
- Displaying symbolic constants in Assembly Language
- puts implementation in assembly with nasm x86-64
- Can I use the mid bits on pointers (on 64-bit machines) to implement things (like tagged pointers)?
- Segmentation fault when exploit string overwrites the return pointer with the starting address on stack
- Reserve bytes in stack: x86 Assembly (64 bit)
Related Questions in ATT
- How to add values from vector to each other
- jmp instruction *%eax
- Porting from Windows to Linux. Assembler command translation
- Mixed integer and string in strace output in write syscall
- Several questions dealing with functions in IA32 assembly language
- How to far jump to $0x9000:%ax using AT&T syntax?
- What's the difference between local and global variables in 32-bit X86?
- What does JL mean in at&t syntax?
- Binary Bomb phase 2, assembly ia32, at&t syntax need help understanding code flow
- Inline asm: operand type mismatch for `in'
Related Questions in ADDRESSING-MODE
- Determining when NASM can infer the size of the mov operation
- Sum of a word array not storing in another word array
- Addressing Modes in Assembly Language (IA-32 NASM)
- Why code and data have different addressing mode?
- Direct addressing without segment in x86?
- Do terms like direct/indirect addressing mode actual exists in the Intel x86 manuals
- What does a comma in a parenthesis mean in the AT&T syntax for x86 assembly?
- What is the "-4" for in assembler: movl $1, -4(%rbp)
- MASM: How to resolve Immediate mode Illegal in 8086 programming?
- x86-64 accessing element of array
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
Popular Tags
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Yes, they are different.
Suppose for example that
%rdi = 0x12340000and%r12 = 8. Thenmovl (%rdi,%r12), %r10dadds%r12to%rdito form an effective address, so you load a 32-bit dword from address0x12340008. The4is the scale parameter of the SIB addressing mode; it causes%r12to be multiplied by 4 before adding to%rdi, so withmovl (%rdi,%r12,4), %r10dyou load a 32-bit dword from address0x12340020instead.See the GNU as manual: "If no
scaleis specified,scaleis taken to be 1."If you try it with an array defined like
and
%rdicontains the address offoo, with%r12 = 8as above, thenmovl (%rdi,%r12), %r10dwill load%r10dwith the value5, butmovl (%rdi,%r12,4), %r10dwill load it with the value17. In other words, it is a question of whether you are treating%rdias a count of bytes, or a count of 32-bit ints.If they appear to work the same in your test, then either your test is buggy, or the two different addresses happen by coincidence to contain the same value, or your
%r12is zero, or your assembler is broken (unlikely).