papermario/asm/nonmatchings/os/code_41c60_len_c0/osProbeTLB.s
2020-08-12 22:37:16 -04:00

61 lines
2.3 KiB
ArmAsm

.set noat # allow manual use of $at
.set noreorder # don't insert nops after branches
glabel osProbeTLB
/* 041C60 80066860 40085000 */ mfc0 $t0, $10
/* 041C64 80066864 310900FF */ andi $t1, $t0, 0xff
/* 041C68 80066868 2401E000 */ addiu $at, $zero, -0x2000
/* 041C6C 8006686C 00815024 */ and $t2, $a0, $at
/* 041C70 80066870 012A4825 */ or $t1, $t1, $t2
/* 041C74 80066874 40895000 */ mtc0 $t1, $10
/* 041C78 80066878 00000000 */ nop
/* 041C7C 8006687C 00000000 */ nop
/* 041C80 80066880 00000000 */ nop
/* 041C84 80066884 42000008 */ tlbp
/* 041C88 80066888 00000000 */ nop
/* 041C8C 8006688C 00000000 */ nop
/* 041C90 80066890 400B0000 */ mfc0 $t3, $0
/* 041C94 80066894 3C018000 */ lui $at, 0x8000
/* 041C98 80066898 01615824 */ and $t3, $t3, $at
/* 041C9C 8006689C 1560001A */ bnez $t3, .L80066908
/* 041CA0 800668A0 00000000 */ nop
/* 041CA4 800668A4 42000001 */ tlbr
/* 041CA8 800668A8 00000000 */ nop
/* 041CAC 800668AC 00000000 */ nop
/* 041CB0 800668B0 00000000 */ nop
/* 041CB4 800668B4 400B2800 */ mfc0 $t3, $5
/* 041CB8 800668B8 216B2000 */ addi $t3, $t3, 0x2000
/* 041CBC 800668BC 000B5842 */ srl $t3, $t3, 1
/* 041CC0 800668C0 01646024 */ and $t4, $t3, $a0
/* 041CC4 800668C4 15800004 */ bnez $t4, .L800668D8
/* 041CC8 800668C8 216BFFFF */ addi $t3, $t3, -1
/* 041CCC 800668CC 40021000 */ mfc0 $v0, $2
/* 041CD0 800668D0 10000002 */ b .L800668DC
/* 041CD4 800668D4 00000000 */ nop
.L800668D8:
/* 041CD8 800668D8 40021800 */ mfc0 $v0, $3
.L800668DC:
/* 041CDC 800668DC 304D0002 */ andi $t5, $v0, 2
/* 041CE0 800668E0 11A00009 */ beqz $t5, .L80066908
/* 041CE4 800668E4 00000000 */ nop
/* 041CE8 800668E8 3C013FFF */ lui $at, 0x3fff
/* 041CEC 800668EC 3421FFC0 */ ori $at, $at, 0xffc0
/* 041CF0 800668F0 00411024 */ and $v0, $v0, $at
/* 041CF4 800668F4 00021180 */ sll $v0, $v0, 6
/* 041CF8 800668F8 008B6824 */ and $t5, $a0, $t3
/* 041CFC 800668FC 004D1020 */ add $v0, $v0, $t5
/* 041D00 80066900 10000002 */ b .L8006690C
/* 041D04 80066904 00000000 */ nop
.L80066908:
/* 041D08 80066908 2402FFFF */ addiu $v0, $zero, -1
.L8006690C:
/* 041D0C 8006690C 40885000 */ mtc0 $t0, $10
/* 041D10 80066910 03E00008 */ jr $ra
/* 041D14 80066914 00000000 */ nop
/* 041D18 80066918 00000000 */ nop
/* 041D1C 8006691C 00000000 */ nop