.global main # makes label "main" globally known
.text # Instructions follow
.align 2 # Align instructions to 4-byte words
main: movi r16,0x47 # Load the hexadecimal value 41
# to register r16
loop: mov r4,r16 # Copy to r4 from r16
nop # (later changed to call hexasc)
nop # (later changed to mov r4,r2)
movia r8,putchar # copy subroutine address to a register
callr r8 # call subroutine via register
addi r16, r16,1 # Add 1 to register r16
andi r16, r16, 0x7f # mask with 7 bits
ori r16, r16, 0x20 # set a bit to avoid control chars
br loop # Branch to loop
.end # The assembler will stop reading here
foo bar bletch # comes after .end - ignored
Run Code Online (Sandbox Code Playgroud)
我想我可以理解一切,除了这两个指令andi和ori在这种情况下如何工作。ori 似乎可以打印 ASCII 20 位向前的位置,但是为什么以及如何打印呢?
andi 和 ori 都是按位运算符:
要看到差异,请考虑“
and $rd, $rs, $rt
or $rd, $rs, $rt
Run Code Online (Sandbox Code Playgroud)
相对
andi $rt, $rs, immed
ori $rt, $rs, immed
Run Code Online (Sandbox Code Playgroud)
http://www.cs.umd.edu/class/sum2003/cmsc311/Notes/Mips/bitwise.html