| plan 9 kernel history: overview | file list | diff list |
1994/0311/carrera/l.s (diff list | history)
| carrera/l.s on 1993/0903 | ||
| 1993/0903 | #include "mem.h" | |
| 1994/0209 | #define SP R29 | |
| 1993/0903 | ||
| 1994/0209 | #define PROM (KSEG1+0x1C000000) | |
| 1993/0903 | #define NOOP WORD $0x27 | |
| 1994/0209 | #define FCRNOOP NOOP; NOOP; NOOP | |
| 1993/0903 | #define WAIT NOOP; NOOP #define NOOP4 NOOP; NOOP; NOOP; NOOP #define ERET NOOP4;NOOP4;WORD $0x42000018;NOOP4;NOOP4 #define CONST(x,r) MOVW $((x)&0xffff0000), r; OR $((x)&0xffff), r | |
| 1993/1217 | #define RDBGSV CONST(0x80020000, R26); \ MOVW R29, 0(R26); \ MOVW M(EPC), R27; \ MOVW R27, 4(R26); \ MOVW R31, 8(R26); \ MOVW M(CAUSE), R27; \ MOVW R27, 12(R26); \ MOVW M(STATUS), R27; \ MOVW R27, 16(R26); \ MOVW M(BADVADDR), R27; \ | |
| 1993/1220 | MOVW R27, 20(R26); | |
| 1993/1211 | ||
| 1993/0903 | /* * R4000 instructions */ | |
| 1994/0228 | #define LD(offset, base, rt) WORD $((067<<26)|((base)<<21)|((rt)<<16)|((offset)&0xFFFF)) #define STD(rt, offset, base) WORD $((077<<26)|((base)<<21)|((rt)<<16)|((offset)&0xFFFF)) | |
| 1993/0903 | #define DSLL(sa, rt, rd) WORD $(((rt)<<16)|((rd)<<11)|((sa)<<6)|070) #define DSRA(sa, rt, rd) WORD $(((rt)<<16)|((rd)<<11)|((sa)<<6)|073) #define LL(base, rt) WORD $((060<<26)|((base)<<21)|((rt)<<16)) #define SC(base, rt) WORD $((070<<26)|((base)<<21)|((rt)<<16)) /* * Boot first processor */ TEXT start(SB), $-4 MOVW $setR30(SB), R30 MOVW $(CU1|INTR7|INTR6|INTR5|INTR4|INTR3|INTR2|INTR1|INTR0), R1 MOVW R1, M(STATUS) WAIT MOVW $TLBROFF, R1 MOVW R1, M(WIRED) MOVW $((0x1C<<7)|(1<<24)), R1 MOVW R1, FCR31 /* permit only inexact and underflow */ NOOP MOVD $0.5, F26 SUBD F26, F26, F24 ADDD F26, F26, F28 ADDD F28, F28, F30 MOVD F24, F0 MOVD F24, F2 MOVD F24, F4 MOVD F24, F6 MOVD F24, F8 MOVD F24, F10 MOVD F24, F12 MOVD F24, F14 MOVD F24, F16 MOVD F24, F18 MOVD F24, F20 MOVD F24, F22 MOVW $MACHADDR, R(MACH) ADDU $(BY2PG-4), R(MACH), SP MOVW $0, R(USER) MOVW R0, 0(R(MACH)) MOVW $edata(SB), R1 MOVW $end(SB), R2 clrbss: MOVB $0, (R1) ADDU $1, R1 BNE R1, R2, clrbss MOVW R4, _argc(SB) MOVW R5, _argv(SB) MOVW R6, _env(SB) JAL main(SB) JMP (R0) /* * Take first processor into user mode * - argument is stack pointer to user */ TEXT touser(SB), $-4 MOVW $(UTZERO+32), R2 /* header appears in text */ MOVW (R2), R3 /* fault now */ MOVW M(STATUS), R4 WAIT AND $(~KMODEMASK), R4 OR $(KUSER|EXL|IE), R4 MOVW R4, M(STATUS) WAIT MOVW R1, SP MOVW R2, M(EPC) NOOP4 ERET TEXT firmware(SB), $0 SLL $3, R1 MOVW $(PROM+0x774), R1 JMP (R1) TEXT splhi(SB), $0 MOVW R31, 12(R(MACH)) /* save PC in m->splpc */ MOVW M(STATUS), R1 WAIT AND $~IE, R1, R2 MOVW R2, M(STATUS) WAIT RET TEXT splx(SB), $0 MOVW R31, 12(R(MACH)) /* save PC in m->splpc */ MOVW M(STATUS), R2 WAIT AND $IE, R1 AND $~IE, R2 OR R2, R1 MOVW R1, M(STATUS) WAIT RET TEXT spllo(SB), $0 MOVW M(STATUS), R1 WAIT OR $IE, R1, R2 MOVW R2, M(STATUS) WAIT RET TEXT spldone(SB), $0 RET TEXT wbflush(SB), $-4 RET TEXT setlabel(SB), $-4 MOVW R29, 0(R1) MOVW R31, 4(R1) MOVW $0, R1 RET TEXT gotolabel(SB), $-4 MOVW 0(R1), R29 MOVW 4(R1), R31 MOVW $1, R1 RET TEXT gotopc(SB), $8 MOVW R1, 0(FP) /* save arguments for later */ MOVW $(64*1024), R7 MOVW R7, 8(SP) JAL icflush(SB) MOVW 0(FP), R7 MOVW _argc(SB), R4 MOVW _argv(SB), R5 MOVW _env(SB), R6 MOVW R0, 4(SP) JMP (R7) TEXT puttlb(SB), $0 MOVW R1, M(TLBVIRT) MOVW 4(FP), R2 /* phys0 */ MOVW 8(FP), R3 /* phys1 */ MOVW R2, M(TLBPHYS0) WAIT MOVW $PGSZ4K, R1 MOVW R3, M(TLBPHYS1) WAIT MOVW R1, M(PAGEMASK) OR R2, R3, R4 /* MTC0 delay slot */ AND $PTEVALID, R4 /* MTC0 delay slot */ NOOP TLBP NOOP4 MOVW M(INDEX), R1 NOOP4 BGEZ R1, index BEQ R4, dont /* cf. kunmap */ TLBWR NOOP dont: RET index: TLBWI NOOP RET TEXT getwired(SB),$0 MOVW M(WIRED), R1 WAIT RET TEXT getrandom(SB),$0 MOVW M(RANDOM), R1 WAIT RET | |
| 1993/1210 | TEXT puttlbx(SB), $0 | |
| 1993/0903 | MOVW 4(FP), R2 MOVW 8(FP), R3 MOVW 12(FP), R4 MOVW 16(FP), R5 MOVW R2, M(TLBVIRT) NOOP4 MOVW R3, M(TLBPHYS0) NOOP4 MOVW R4, M(TLBPHYS1) NOOP4 MOVW R5, M(PAGEMASK) NOOP4 MOVW R1, M(INDEX) NOOP4 TLBWI WAIT RET TEXT tlbvirt(SB), $0 NOOP MOVW M(TLBVIRT), R1 NOOP RET TEXT gettlbx(SB), $0 MOVW 4(FP), R5 MOVW M(TLBVIRT), R10 NOOP4 MOVW R1, M(INDEX) NOOP4 TLBR NOOP4 MOVW M(TLBVIRT), R2 MOVW M(TLBPHYS0), R3 MOVW M(TLBPHYS1), R4 NOOP4 MOVW R2, 0(R5) MOVW R3, 4(R5) MOVW R4, 8(R5) MOVW R10, M(TLBVIRT) NOOP4 RET TEXT gettlbp(SB), $0 MOVW 4(FP), R5 MOVW R1, M(TLBVIRT) NOOP NOOP NOOP TLBP NOOP NOOP MOVW M(INDEX), R1 NOOP BLTZ R1, gettlbp1 TLBR NOOP NOOP NOOP MOVW M(TLBVIRT), R2 MOVW M(TLBPHYS0), R3 MOVW M(TLBPHYS1), R4 MOVW M(PAGEMASK), R6 NOOP MOVW R2, 0(R5) MOVW R3, 4(R5) MOVW R4, 8(R5) MOVW R6, 12(R5) gettlbp1: RET TEXT gettlbvirt(SB), $0 MOVW R1, M(INDEX) NOOP NOOP TLBR NOOP NOOP NOOP MOVW M(TLBVIRT), R1 NOOP RET TEXT vector0(SB), $-4 NOOP4 NOOP4 | |
| 1993/1211 | RDBGSV | |
| 1993/0903 | MOVW $utlbmiss(SB), R26 JMP (R26) TEXT utlbmiss(SB), $-4 | |
| 1993/1211 | CONST (MACHADDR, R26) /* R26 = m-> */ MOVW 16(R26), R27 ADDU $1, R27 MOVW R27, 16(R26) /* m->tlbfault++ */ | |
| 1993/0903 | MOVW M(TLBVIRT), R27 WAIT MOVW R27, R26 SRL $13, R27 XOR R26, R27 AND $(STLBSIZE-1), R27 SLL $2, R27 MOVW R27, R26 SLL $1, R27 ADDU R26, R27 /* R27 = ((tlbvirt^(tlbvirt>>13)) & (STLBSIZE-1)) x 12 */ CONST (MACHADDR, R26) /* R26 = m-> */ MOVW 4(R26), R26 /* R26 = m->stb */ ADDU R26, R27 /* R27 = &m->stb[hash] */ MOVW M(BADVADDR), R26 WAIT AND $BY2PG, R26 BNE R26, utlbodd MOVW 4(R27), R26 BEQ R26, stlbm MOVW R26, M(TLBPHYS0) WAIT MOVW 8(R27), R26 MOVW R26, M(TLBPHYS1) JMP utlbcom utlbodd: MOVW 8(R27), R26 BEQ R26, stlbm MOVW R26, M(TLBPHYS1) WAIT MOVW 4(R27), R26 MOVW R26, M(TLBPHYS0) utlbcom: WAIT /* MTC0/MFC0 hazard */ MOVW M(TLBVIRT), R26 WAIT MOVW (R27), R27 BEQ R27, stlbm BNE R26, R27, stlbm MOVW $PGSZ4K, R27 MOVW R27, M(PAGEMASK) NOOP4 TLBP NOOP4 MOVW M(INDEX), R26 NOOP4 BGEZ R26, utlindex TLBWR NOOP4 ERET utlindex: MOVW R0,(R0) TLBWI NOOP4 ERET stlbm: MOVW $exception(SB), R26 JMP (R26) TEXT vector100(SB), $-4 NOOP4 NOOP4 | |
| 1993/1211 | RDBGSV | |
| 1993/0903 | MOVW $exception(SB), R26 JMP (R26) TEXT vector180(SB), $-4 NOOP4 NOOP4 | |
| 1993/1211 | RDBGSV | |
| 1993/0903 | MOVW $exception(SB), R26 JMP (R26) NOP TEXT exception(SB), $-4 MOVW M(STATUS), R26 WAIT AND $KUSER, R26 BEQ R26, waskernel wasuser: CONST (MACHADDR, R27) /* R27 = m-> */ MOVW 8(R27), R26 /* R26 = m->proc */ MOVW 8(R26), R27 /* R27 = m->proc->kstack */ MOVW SP, R26 /* save user sp */ ADDU $(KSTACK-UREGSIZE-2*BY2WD), R27, SP MOVW R26, 0x10(SP) /* user SP */ MOVW R31, 0x28(SP) MOVW R30, 0x2C(SP) MOVW M(CAUSE), R26 MOVW R(MACH), 0x3C(SP) MOVW R(USER), 0x40(SP) AND $(EXCMASK<<2), R26 SUBU $(CSYS<<2), R26 JAL saveregs(SB) MOVW $setR30(SB), R30 CONST (MACHADDR, R1) | |
| 1993/0904 | MOVW R1, R(MACH) /* R(MACH) = m-> */ | |
| 1993/0903 | MOVW 8(R(MACH)), R(USER) /* up = m->proc */ MOVW 4(SP), R1 /* first arg for syscall/trap */ BNE R26, notsys JAL syscall(SB) sysrestore: MOVW 0x28(SP), R31 MOVW 0x08(SP), R26 MOVW 0x2C(SP), R30 MOVW R26, M(STATUS) WAIT MOVW 0x0C(SP), R26 /* old pc */ MOVW 0x10(SP), SP MOVW R26, M(EPC) NOOP4 ERET notsys: JAL trap(SB) restore: JAL restregs(SB) MOVW 0x28(SP), R31 MOVW 0x2C(SP), R30 MOVW 0x3C(SP), R(MACH) MOVW 0x40(SP), R(USER) MOVW 0x10(SP), SP MOVW R26, M(EPC) NOOP4 ERET waskernel: MOVW $1, R26 /* not syscall */ MOVW SP, -(UREGSIZE-16)(SP) SUBU $UREGSIZE, SP MOVW R31, 0x28(SP) JAL saveregs(SB) MOVW 4(SP), R1 /* first arg for trap */ JAL trap(SB) JAL restregs(SB) MOVW 0x28(SP), R31 ADDU $UREGSIZE, SP MOVW R26, M(EPC) NOOP4 ERET TEXT forkret(SB), $0 MOVW R0, R1 /* Fake out system call return */ JMP sysrestore TEXT saveregs(SB), $-4 MOVW R1, 0x9C(SP) MOVW R2, 0x98(SP) | |
| 1994/0209 | /* save R5, R6 as 64 bits */ ADDU $(UREGSIZE-16), SP, R1 MOVW $~7, R2 /* don't let him use R28 */ AND R2, R1 STD (5, 0,(1)) STD (6, 8,(1)) | |
| 1993/0903 | ADDU $8, SP, R1 MOVW R1, 0x04(SP) /* arg to base of regs */ MOVW M(STATUS), R1 MOVW M(EPC), R2 WAIT MOVW R1, 0x08(SP) MOVW R2, 0x0C(SP) MOVW $(~KMODEMASK),R2 /* don't let him use R28 */ AND R2, R1 MOVW R1, M(STATUS) WAIT BEQ R26, return /* sys call, don't save */ MOVW M(CAUSE), R1 MOVW M(BADVADDR), R2 NOOP MOVW R1, 0x14(SP) MOVW M(TLBVIRT), R1 NOOP MOVW R2, 0x18(SP) MOVW R1, 0x1C(SP) MOVW HI, R1 MOVW LO, R2 MOVW R1, 0x20(SP) MOVW R2, 0x24(SP) /* LINK,SB,SP missing */ MOVW R28, 0x30(SP) /* R27, R26 not saved */ /* R25, R24 missing */ MOVW R23, 0x44(SP) MOVW R22, 0x48(SP) MOVW R21, 0x4C(SP) MOVW R20, 0x50(SP) MOVW R19, 0x54(SP) MOVW R18, 0x58(SP) MOVW R17, 0x5C(SP) MOVW R16, 0x60(SP) MOVW R15, 0x64(SP) MOVW R14, 0x68(SP) MOVW R13, 0x6C(SP) MOVW R12, 0x70(SP) MOVW R11, 0x74(SP) MOVW R10, 0x78(SP) MOVW R9, 0x7C(SP) MOVW R8, 0x80(SP) MOVW R7, 0x84(SP) MOVW R6, 0x88(SP) MOVW R5, 0x8C(SP) MOVW R4, 0x90(SP) MOVW R3, 0x94(SP) return: RET TEXT restregs(SB), $-4 /* LINK,SB,SP missing */ MOVW 0x30(SP), R28 /* R27, R26 not saved */ /* R25, R24 missing */ MOVW 0x44(SP), R23 MOVW 0x48(SP), R22 MOVW 0x4C(SP), R21 MOVW 0x50(SP), R20 MOVW 0x54(SP), R19 MOVW 0x58(SP), R18 MOVW 0x5C(SP), R17 MOVW 0x60(SP), R16 MOVW 0x64(SP), R15 MOVW 0x68(SP), R14 MOVW 0x6C(SP), R13 MOVW 0x70(SP), R12 MOVW 0x74(SP), R11 MOVW 0x78(SP), R10 MOVW 0x7C(SP), R9 MOVW 0x80(SP), R8 MOVW 0x84(SP), R7 | |
| 1994/0209 | /* * restored below * MOVW 0x88(SP), R6 * MOVW 0x8C(SP), R5 */ | |
| 1993/0903 | MOVW 0x90(SP), R4 MOVW 0x94(SP), R3 MOVW 0x24(SP), R2 MOVW 0x20(SP), R1 MOVW R2, LO MOVW R1, HI | |
| 1994/0209 | /* restore 64-bit R5, R6 */ ADDU $(UREGSIZE-16), SP, R1 MOVW $~7, R2 /* don't let him use R28 */ AND R2, R1 LD (0,(1), 5) LD (8,(1), 6) | |
| 1993/0903 | MOVW 0x08(SP), R1 MOVW 0x98(SP), R2 MOVW R1, M(STATUS) WAIT MOVW 0x9C(SP), R1 MOVW 0x0C(SP), R26 /* old pc */ RET TEXT rfnote(SB), $0 MOVW R1, R26 /* 1st arg is &uregpointer */ SUBU $(BY2WD), R26, SP /* pc hole */ JMP restore TEXT clrfpintr(SB), $0 MOVW M(STATUS), R3 WAIT OR $CU1, R3 MOVW R3, M(STATUS) NOOP NOOP NOOP MOVW FCR31, R1 FCRNOOP MOVW R1, R2 AND $~(0x3F<<12), R2 MOVW R2, FCR31 AND $~CU1, R3 MOVW R3, M(STATUS) WAIT RET TEXT getstatus(SB), $0 MOVW M(STATUS), R1 WAIT RET TEXT savefpregs(SB), $0 MOVW FCR31, R2 /* 3 delays before R2 ok */ MOVW M(STATUS), R3 WAIT AND $~(0x3F<<12), R2, R4 MOVW R4, FCR31 MOVD F0, 0x00(R1) MOVD F2, 0x08(R1) MOVD F4, 0x10(R1) MOVD F6, 0x18(R1) MOVD F8, 0x20(R1) MOVD F10, 0x28(R1) MOVD F12, 0x30(R1) MOVD F14, 0x38(R1) MOVD F16, 0x40(R1) MOVD F18, 0x48(R1) MOVD F20, 0x50(R1) MOVD F22, 0x58(R1) MOVD F24, 0x60(R1) MOVD F26, 0x68(R1) MOVD F28, 0x70(R1) MOVD F30, 0x78(R1) MOVW R2, 0x80(R1) AND $~CU1, R3 MOVW R3, M(STATUS) WAIT RET TEXT restfpregs(SB), $0 MOVW M(STATUS), R3 WAIT OR $CU1, R3 MOVW R3, M(STATUS) WAIT MOVW fpstat+4(FP), R2 NOOP MOVD 0x00(R1), F0 MOVD 0x08(R1), F2 MOVD 0x10(R1), F4 MOVD 0x18(R1), F6 MOVD 0x20(R1), F8 MOVD 0x28(R1), F10 MOVD 0x30(R1), F12 MOVD 0x38(R1), F14 MOVD 0x40(R1), F16 MOVD 0x48(R1), F18 MOVD 0x50(R1), F20 MOVD 0x58(R1), F22 MOVD 0x60(R1), F24 MOVD 0x68(R1), F26 MOVD 0x70(R1), F28 MOVD 0x78(R1), F30 MOVW R2, FCR31 AND $~CU1, R3 MOVW R3, M(STATUS) WAIT RET TEXT fcr31(SB), $0 MOVW FCR31, R1 /* 3 delays before using R1 */ MOVW M(STATUS), R3 WAIT AND $~CU1, R3 MOVW R3, M(STATUS) WAIT RET /* * Emulate 68020 test and set: load linked / store conditional */ TEXT tas(SB), $0 MOVW R1, R2 /* address of key */ tas1: MOVW $1, R3 LL(2, 1) NOOP SC(2, 3) NOOP BEQ R3, tas1 RET /* * cache manipulation */ #define CACHE BREAK /* overloaded op-code */ #define PI R((0 /* primary I cache */ #define PD R((1 /* primary D cache */ #define SD R((3 /* secondary combined I/D cache */ #define IWBI (0<<2))) /* index write-back invalidate */ #define ILT (1<<2))) /* index load tag */ #define IST (2<<2))) /* index store tag */ #define CDE (3<<2))) /* create dirty exclusive */ #define HI (4<<2))) /* hit invalidate */ #define HWBI (5<<2))) /* hit write back invalidate */ #define HWB (6<<2))) /* hit write back */ #define HSV (7<<2))) /* hit set virtual */ /* * we avoid using R4, R5, R6, and R7 so gotopc can call us without saving them */ TEXT icflush(SB), $-4 /* icflush(virtaddr, count) */ MOVW M(STATUS), R10 WAIT MOVW 4(FP), R9 MOVW $0, M(STATUS) WAIT | |
| 1993/0907 | WAIT WAIT | |
| 1993/0904 | ADDU R1, R9 /* R9 = last address */ MOVW $(~0x3f), R8 AND R1, R8 /* R8 = first address, rounded down */ | |
| 1993/1231 | ADDU $0x3f, R9 | |
| 1993/0904 | AND $(~0x3f), R9 /* round last address up */ | |
| 1993/1231 | SUBU R8, R9 /* R9 = revised count */ | |
| 1993/0903 | icflush1: /* primary cache line size is 16 bytes */ | |
| 1993/0904 | CACHE PD+HWB, 0x00(R8) CACHE PI+HI, 0x00(R8) CACHE PD+HWB, 0x10(R8) CACHE PI+HI, 0x10(R8) CACHE PD+HWB, 0x20(R8) CACHE PI+HI, 0x20(R8) CACHE PD+HWB, 0x30(R8) CACHE PI+HI, 0x30(R8) | |
| 1993/1231 | SUBU $0x40, R9 ADDU $0x40, R8 | |
| 1993/0903 | BGTZ R9, icflush1 MOVW R10, M(STATUS) WAIT | |
| 1993/0907 | WAIT WAIT | |
| 1993/0903 | RET | |
| 1993/0918 | TEXT dcflush(SB), $-4 /* dcflush(virtaddr, count) */ | |
| 1993/0903 | MOVW M(STATUS), R10 WAIT MOVW 4(FP), R9 | |
| 1993/0907 | MOVW $0, M(STATUS) WAIT ADDU R1, R9 /* R9 = last address */ MOVW $(~0x3f), R8 AND R1, R8 /* R8 = first address, rounded down */ | |
| 1993/1231 | ADDU $0x3f, R9 | |
| 1993/0907 | AND $(~0x3f), R9 /* round last address up */ | |
| 1993/1231 | SUBU R8, R9 /* R9 = revised count */ | |
| 1994/0228 | dcflush1: /* primary cache line is 16 bytes */ | |
| 1993/0907 | CACHE PI+HI, 0x00(R8) CACHE PI+HI, 0x10(R8) CACHE PI+HI, 0x20(R8) CACHE PI+HI, 0x30(R8) | |
| 1993/1211 | CACHE PD+HWBI, 0x00(R8) CACHE PD+HWBI, 0x10(R8) CACHE PD+HWBI, 0x20(R8) CACHE PD+HWBI, 0x30(R8) | |
| 1993/1231 | SUBU $0x40, R9 ADDU $0x40, R8 | |
| 1993/0918 | BGTZ R9, dcflush1 | |
| 1993/0903 | MOVW R10, M(STATUS) WAIT RET TEXT cleancache(SB), $-4 MOVW $KZERO, R1 MOVW M(STATUS), R10 WAIT MOVW $0, M(STATUS) WAIT | |
| 1993/0904 | MOVW $(32*1024), R9 | |
| 1993/0903 | ccache: | |
| 1993/0904 | CACHE PD+IWBI, 0x00(R1) WAIT CACHE PI+IWBI, 0x00(R1) WAIT SUBU $16, R9 ADDU $16, R1 | |
| 1993/0903 | BGTZ R9, ccache MOVW R10, M(STATUS) WAIT RET TEXT getcallerpc(SB), $0 MOVW 0(SP), R1 RET TEXT rdcount(SB), $0 MOVW M(COUNT), R1 NOOP RET TEXT wrcompare(SB), $0 MOVW R1, M(COMPARE) RET | |
| 1994/0307 | TEXT uvld(SB), $-4 /* uvld(address, dst) */ MOVW 4(FP), R2 | |
| 1994/0308 | MOVV 0(R1), R5 MOVV R5, 0(R2) | |
| 1994/0307 | RET TEXT uvst(SB), $-4 /* uvst(address, src) */ MOVW 4(FP), R2 | |
| 1994/0308 | MOVV 0(R2), R5 | |
| 1994/0307 | MOVV R5, 0(R1) | |
| 1994/0309 | RET | |
| 1994/0311 | TEXT fwblock(SB), $-4 /* fwblock(void*port, void *block, csum) */ | |
| 1994/0309 | MOVW 4(FP), R2 MOVW 8(FP), R3 MOVW $64, R4 fwloop: MOVV 0(R2), R5 MOVV R5, 0(R1) ADDU R5, R3 SRLV $32, R5 ADDU R5, R3 ADD $8, R2 SUB $1, R4 BNE R4, fwloop | |
| 1994/0311 | MOVW R3, R1 RET TEXT frblock(SB), $-4 /* frblock(void*port, void *block, csum) */ MOVW 4(FP), R2 MOVW 8(FP), R3 MOVW $64, R4 frloop: MOVV 0(R1), R5 MOVV R5, 0(R2) ADDU R5, R3 SRLV $32, R5 ADDU R5, R3 ADD $8, R2 SUB $1, R4 BNE R4, frloop | |
| 1994/0309 | MOVW R3, R1 | |
| 1994/0307 | RET | |