Nie jestem pewien, dlaczego dodajemy rejestry% rdx i% rax, gdy kod zespołu używa% eax i% edx

Cześć Potrzebuję pomocy w zrozumieniu tego, co dzieje się w tym kodzie zespołu:

        .file   "mystery.c"

        .text

        .globl mystery

              .type mystery, @function

 mystery:
   pushq    %rbp
    movq    %rsp, %rbp

   movl %edi, -20(%rbp)
   movl $1, -16(%rbp)
   movl $0, -12(%rbp)
   movl $0, -8(%rbp)
   cmpl $2, -20(%rbp)
   jg   .L2
   movl $1, %eax
   jmp  .L3

  .L2:
movl    $2, -4(%rbp)
jmp .L4

  .L5:
movl    -12(%rbp), %eax
movl    -16(%rbp), %edx
leal    (%rdx,%rax), %eax
movl    %eax, -8(%rbp)
movl    -16(%rbp), %eax
movl    %eax, -12(%rbp)
movl    -8(%rbp), %eax
movl    %eax, -16(%rbp)
addl    $1, -4(%rbp)

.L4:
movl    -4(%rbp), %eax
cmpl    -20(%rbp), %eax
jle .L5
movl    -8(%rbp), %eax

.L3:
leave
ret

Rozumiem dokładnie, co się dzieje, aż dotrę do .L5, tutaj polecenieleal(%rdx, %rax), eax jest tym, co mnie myli. Do tej pory przenosiłem wartości do eax i edx, a teraz dodałem wartości w rdx i rax. Skąd pochodzi rdx i rax i jakie wartości mają? Czy to po prostu inny sposób pisania eax i edx? Dzięki za pomoc.

questionAnswers(3)

yourAnswerToTheQuestion