papermario/ver/us/asm/os/__osProbeTLB.s
JoshDuMan e1766601f8
Match 50 functions in Libultra (#636)
* Fix script disasm

* Stuff

* Work on libultra

* More Libultra Work

* My Libultra work for now

* Fix all OS warnings

* fix gitignore
2022-01-31 20:40:55 +09:00

61 lines
2.4 KiB
ArmAsm

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