andi和ori在这个程序中做了什么?

Nik*_*ntz 5 assembly mips

        .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)

我想我可以理解一切,除了这两个指令andiori在这种情况下如何工作。ori 似乎可以打印 ASCII 20 位向前的位置,但是为什么以及如何打印呢?

Bry*_*ord 1

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