MIT6.S081笔记:lecture 5
data:image/s3,"s3://crabby-images/829bb/829bb8615cede921ab9aeaaeeb44793b3e5ccde9" alt=""
MIT6.S081笔记:lecture 5 calling conventions and stack
Calling convenstions
RISC-V Register File
data:image/s3,"s3://crabby-images/fa8d1/fa8d10b606d2c6dbb9b1c7d127d67222e19412d5" alt="regfile"
Integer Instructions
lb t0, 8(sp)
loads from memory address (sp+8) into register t0
lb = load byte, lh = load halfword, lw = load word, ld = load doubleword
add a0, t0, t1
adds value of t0 to the value of t1 and stores the sum into a0
addi a0, t0, -10
adds value of t0 to the value -10 and stores the sum into a0
mul a0, t0, t1
multiplies the value of t0 to the value of t1 and stores the product int a0
Pseudo Instructions
- translate to real instructions by assembler
data:image/s3,"s3://crabby-images/37f74/37f74e0c140fc26645c8b72c68e6ba2594a05ada" alt="pseudo"
Branching Instructions
- a way to jump to different parts of your code
- Branching refers to the “conditional jump” instructions, such as
beq, bne, bgt, bge, blt, ble
for branch-if equals, not equals, greater than, greater than or equals, less than, and less than or equals, respectively.
1 | # t0 = 0 |
Stack
Stack frame
data:image/s3,"s3://crabby-images/c7ad7/c7ad723fd16c7e70e8295759ca5e483ae1d02018" alt="image-20230614143513990"
stack frame is generated by function calls
start from high addresses and grow downwards to low addresses
the return address and to prev frame pointer are at a predictable position
sp - bottom of the stack
fp - top of the current frame
Use backtrace to debug
- Post title:MIT6.S081笔记:lecture 5
- Post author:sixwalter
- Create time:2023-08-05 11:14:26
- Post link:https://coelien.github.io/2023/08/05/course-learning/MIT6.S081/lec5/
- Copyright Notice:All articles in this blog are licensed under BY-NC-SA unless stating additionally.
Comments