Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6066499
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 23, 20262026-05-23T09:30:27+00:00 2026-05-23T09:30:27+00:00

Can anyone tell me what the following code in x86 ASM does? It’s only

  • 0

Can anyone tell me what the following code in x86 ASM does? It’s only part of a larger file, but it’s just this bit that’s getting me down.

find_max:
  6 .LFB0:
  7         .cfi_startproc
  8         pushq   %rbp
  9         .cfi_def_cfa_offset 16
 10         movq    %rsp, %rbp
 11         .cfi_offset 6, -16
 12         .cfi_def_cfa_register 6
 13         movl    %edi, -20(%rbp)
 14         movl    -20(%rbp), %eax
 15         cltq
 16         movl    a(,%rax,4), %eax
 17         movl    %eax, -4(%rbp)
 18         movl    -20(%rbp), %eax
 19         movl    %eax, -8(%rbp)

Specifically,

  • What’s initially in %edi on line 13?
  • Why is the code referencing -20(%rbp)?
  • And what exactly does line 16 do?
  • What’s the wisdom behind switching behind the 32-bit registers and the 64-bit registers (for instance in the case of line 15)?

The C code I disassembled to get this goes something like the following:

extern int a[];

int find_max(int n)
{
    int max = a[n];
    int pos = n;
    int x;

    while (n > 0)
    {
        n--;
        x = a[n];

        if (x > max)
        {
            max = x;
            pos = n;
        }
    } 
    return pos;
}
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-23T09:30:27+00:00Added an answer on May 23, 2026 at 9:30 am

    What’s initially in %edi on line 13?

    rdi is the first parameter-passing register for the AMD/Linux 64-bit ABI. edi is being used in this code since your function takes a 32-bit int parameter.


    Why is the code referencing -20(%rbp)?

    It’s saving the passed-in-parameter to the stack; presumably you are compiling with low or no optimization, so every variable is getting a real memory address. If you turn up the optimizations, you’ll probably see these operations disappear.


    And what exactly does line 16 do?

    Line 16 is an array indexing operation:

    movl    a(,%rax,4), %eax
    

    The AT&T syntax for memory addressing is a little strange looking. It breaks down as:

    segment-override:signed-offset(base,index,scale)

    In your case, the array’s address is being used as the offset field, you have no base register or segment override, the scale is 4 and the index register being used is rax. That breaks down to something like along the lines of this C-like pseudocode:

    eax = *(int *)((char *)a + (rax * 4))
    

    What’s the wisdom behind switching behind the 32-bit registers and the 64-bit registers (for instance in the case of line 15)?

    I don’t see anything like that on line 15, but the reason it’s done is because your function uses a lot of int – since int is a 32-bit type, the compiler is using 32-bit registers. Where it doesn’t matter or the compiler is using temporary registers, it’s choosing the native 64-bit size.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Can anyone tell how correct the following code below. Iam tryin to create a
Can anyone tell me what exactly does this Java code do? SecureRandom random =
Can anyone tell me how to best possible way to convert the following code
Can anyone tell me what -a means in unix. Please see the following code:
I am using the following code to disable the anchor tag.Can anyone tell me
Can anyone tell me why in the following code I get redirected to yahoo.com
Can anyone tell me the purpose of the following code and when/where you would
Can anyone tell me why the following code might not cycle through the array
can anyone tell me the function of following code. is the code line NSString*
Can anyone tell me why the following code function s3() function ret = fun(x)

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.