diff --git a/runtime/Makefile b/runtime/Makefile index 4a4f0b80..319883ec 100644 --- a/runtime/Makefile +++ b/runtime/Makefile @@ -9,6 +9,7 @@ CPY = /opt/riscv/bin/riscv32-unknown-elf-objcopy VX_STR = ./startup/vx_start.s VX_INT = ./intrinsics/vx_intrinsics.s VX_IO = ./io/vx_io.s ./io/vx_io.c +VX_API = ./vx_api/vx_api.c VX_TEST = ./tests/tests.c VX_MAIN = ./vx_main.c @@ -22,4 +23,4 @@ HEX: ELF $(CPY) -O ihex vortex_runtime.elf vortex_runtime.hex ELF: - $(COMP) $(CC_FLAGS) $(VX_STR) $(VX_INT) $(VX_IO) $(VX_TEST) $(VX_MAIN) -o vortex_runtime.elf + $(COMP) $(CC_FLAGS) $(VX_STR) $(VX_INT) $(VX_IO) $(VX_API) $(VX_TEST) $(VX_MAIN) -o vortex_runtime.elf diff --git a/runtime/startup/vx_start.s b/runtime/startup/vx_start.s index 641a6c0d..03f12c31 100644 --- a/runtime/startup/vx_start.s +++ b/runtime/startup/vx_start.s @@ -3,22 +3,13 @@ .type _start, @function .global _start _start: + la a1, vx_set_sp li a0, 4 - la a1, 0x40004326 - sw a0, 0(a1) - nop - nop - nop - lw a2, 0(a1) + .word 0x00b5106b # wspawn a0(numWarps), a1(PC SPAWN) + jal vx_set_sp + jal main li a0, 0 .word 0x0005006b # tmc a0 - # la a1, vx_set_sp - # li a0, 4 - # .word 0x00b5106b # wspawn a0(numWarps), a1(PC SPAWN) - # jal vx_set_sp - # jal main - # li a0, 0 - # .word 0x0005006b # tmc a0 .type vx_set_sp, @function diff --git a/runtime/vortex_runtime.dump b/runtime/vortex_runtime.dump index 32b41d0b..07c09049 100644 --- a/runtime/vortex_runtime.dump +++ b/runtime/vortex_runtime.dump @@ -5,567 +5,553 @@ vortex_runtime.elf: file format elf32-littleriscv Disassembly of section .text: 80000000 <_start>: -80000000: 00400513 li a0,4 -80000004: 400045b7 lui a1,0x40004 -80000008: 32058593 addi a1,a1,800 # 40004320 <_start-0x3fffbce0> -8000000c: 00a5a023 sw a0,0(a1) -80000010: 00000013 nop -80000014: 00000013 nop -80000018: 00000013 nop -8000001c: 0005a603 lw a2,0(a1) -80000020: 00000513 li a0,0 +80000000: 00000597 auipc a1,0x0 +80000004: 02058593 addi a1,a1,32 # 80000020 +80000008: 00400513 li a0,4 +8000000c: 00b5106b 0xb5106b +80000010: 010000ef jal ra,80000020 +80000014: 744000ef jal ra,80000758
+80000018: 00000513 li a0,0 +8000001c: 0005006b 0x5006b + +80000020 : +80000020: 00400513 li a0,4 80000024: 0005006b 0x5006b +80000028: 021026f3 csrr a3,0x21 +8000002c: 00f69693 slli a3,a3,0xf +80000030: 02002673 csrr a2,0x20 +80000034: 00a61593 slli a1,a2,0xa +80000038: 00261613 slli a2,a2,0x2 +8000003c: 6ffff137 lui sp,0x6ffff +80000040: 40b10133 sub sp,sp,a1 +80000044: 40d10133 sub sp,sp,a3 +80000048: 00c10133 add sp,sp,a2 +8000004c: 021026f3 csrr a3,0x21 +80000050: 00068663 beqz a3,8000005c +80000054: 00000513 li a0,0 +80000058: 0005006b 0x5006b -80000028 : -80000028: 00400513 li a0,4 -8000002c: 0005006b 0x5006b -80000030: 021026f3 csrr a3,0x21 -80000034: 00f69693 slli a3,a3,0xf -80000038: 02002673 csrr a2,0x20 -8000003c: 00a61593 slli a1,a2,0xa -80000040: 00261613 slli a2,a2,0x2 -80000044: 6ffff137 lui sp,0x6ffff -80000048: 40b10133 sub sp,sp,a1 -8000004c: 40d10133 sub sp,sp,a3 -80000050: 00c10133 add sp,sp,a2 -80000054: 021026f3 csrr a3,0x21 -80000058: 00068663 beqz a3,80000064 -8000005c: 00000513 li a0,0 -80000060: 0005006b 0x5006b +8000005c : +8000005c: 00008067 ret -80000064 : +80000060 : +80000060: 00b5106b 0xb5106b 80000064: 00008067 ret -80000068 : -80000068: 00b5106b 0xb5106b +80000068 : +80000068: 0005006b 0x5006b 8000006c: 00008067 ret -80000070 : -80000070: 0005006b 0x5006b +80000070 : +80000070: 00b5406b 0xb5406b 80000074: 00008067 ret -80000078 : -80000078: 00b5406b 0xb5406b +80000078 : +80000078: 0005206b 0x5206b 8000007c: 00008067 ret -80000080 : -80000080: 0005206b 0x5206b +80000080 : +80000080: 0000306b 0x306b 80000084: 00008067 ret -80000088 : -80000088: 0000306b 0x306b +80000088 : +80000088: 02102573 csrr a0,0x21 8000008c: 00008067 ret -80000090 : -80000090: 02102573 csrr a0,0x21 +80000090 : +80000090: 02002573 csrr a0,0x20 80000094: 00008067 ret -80000098 : -80000098: 02002573 csrr a0,0x20 -8000009c: 00008067 ret +80000098 : +80000098: 00400513 li a0,4 +8000009c: 0005006b 0x5006b +800000a0: 021026f3 csrr a3,0x21 +800000a4: 00f69693 slli a3,a3,0xf +800000a8: 02002673 csrr a2,0x20 +800000ac: 00a61593 slli a1,a2,0xa +800000b0: 00261613 slli a2,a2,0x2 +800000b4: 6ffff137 lui sp,0x6ffff +800000b8: 40b10133 sub sp,sp,a1 +800000bc: 40d10133 sub sp,sp,a3 +800000c0: 00c10133 add sp,sp,a2 +800000c4: 021026f3 csrr a3,0x21 +800000c8: 00068663 beqz a3,800000d4 +800000cc: 00000513 li a0,0 +800000d0: 0005006b 0x5006b -800000a0 : -800000a0: 00400513 li a0,4 -800000a4: 0005006b 0x5006b -800000a8: 021026f3 csrr a3,0x21 -800000ac: 00f69693 slli a3,a3,0xf -800000b0: 02002673 csrr a2,0x20 -800000b4: 00a61593 slli a1,a2,0xa -800000b8: 00261613 slli a2,a2,0x2 -800000bc: 6ffff137 lui sp,0x6ffff -800000c0: 40b10133 sub sp,sp,a1 -800000c4: 40d10133 sub sp,sp,a3 -800000c8: 00c10133 add sp,sp,a2 -800000cc: 021026f3 csrr a3,0x21 -800000d0: 00068663 beqz a3,800000dc -800000d4: 00000513 li a0,0 -800000d8: 0005006b 0x5006b +800000d4 : +800000d4: 00008067 ret -800000dc : -800000dc: 00008067 ret +800000d8 : +800000d8: ff410113 addi sp,sp,-12 # 6fffeff4 <_start-0x1000100c> +800000dc: 00112023 sw ra,0(sp) +800000e0: 00b12223 sw a1,4(sp) -800000e0 : -800000e0: ff410113 addi sp,sp,-12 # 6fffeff4 <_start-0x1000100c> -800000e4: 00112023 sw ra,0(sp) -800000e8: 00b12223 sw a1,4(sp) +800000e4 : +800000e4: 00054583 lbu a1,0(a0) +800000e8: 00058863 beqz a1,800000f8 +800000ec: 01c000ef jal ra,80000108 +800000f0: 00150513 addi a0,a0,1 +800000f4: ff1ff06f j 800000e4 -800000ec : -800000ec: 00054583 lbu a1,0(a0) -800000f0: 00058863 beqz a1,80000100 -800000f4: 01c000ef jal ra,80000110 -800000f8: 00150513 addi a0,a0,1 -800000fc: ff1ff06f j 800000ec +800000f8 : +800000f8: 00012083 lw ra,0(sp) +800000fc: 00412583 lw a1,4(sp) +80000100: 00c10113 addi sp,sp,12 +80000104: 00008067 ret -80000100 : -80000100: 00012083 lw ra,0(sp) -80000104: 00412583 lw a1,4(sp) -80000108: 00c10113 addi sp,sp,12 -8000010c: 00008067 ret +80000108 : +80000108: 000102b7 lui t0,0x10 +8000010c: 00b2a023 sw a1,0(t0) # 10000 <_start-0x7fff0000> +80000110: 00008067 ret -80000110 : -80000110: 000102b7 lui t0,0x10 -80000114: 00b2a023 sw a1,0(t0) # 10000 <_start-0x7fff0000> -80000118: 00008067 ret +80000114 : +80000114: fe010113 addi sp,sp,-32 +80000118: 00112e23 sw ra,28(sp) +8000011c: 00812c23 sw s0,24(sp) +80000120: 02010413 addi s0,sp,32 +80000124: fea42623 sw a0,-20(s0) +80000128: 810007b7 lui a5,0x81000 +8000012c: fec42703 lw a4,-20(s0) +80000130: 00271713 slli a4,a4,0x2 +80000134: 11878793 addi a5,a5,280 # 81000118 +80000138: 00f707b3 add a5,a4,a5 +8000013c: 0007a783 lw a5,0(a5) +80000140: 00078513 mv a0,a5 +80000144: f95ff0ef jal ra,800000d8 +80000148: 00000013 nop +8000014c: 01c12083 lw ra,28(sp) +80000150: 01812403 lw s0,24(sp) +80000154: 02010113 addi sp,sp,32 +80000158: 00008067 ret -8000011c : -8000011c: fe010113 addi sp,sp,-32 -80000120: 00112e23 sw ra,28(sp) -80000124: 00812c23 sw s0,24(sp) -80000128: 02010413 addi s0,sp,32 -8000012c: fea42623 sw a0,-20(s0) -80000130: 810007b7 lui a5,0x81000 -80000134: fec42703 lw a4,-20(s0) -80000138: 00271713 slli a4,a4,0x2 -8000013c: 0f478793 addi a5,a5,244 # 810000f4 -80000140: 00f707b3 add a5,a4,a5 -80000144: 0007a783 lw a5,0(a5) -80000148: 00078513 mv a0,a5 -8000014c: f95ff0ef jal ra,800000e0 -80000150: 00000013 nop -80000154: 01c12083 lw ra,28(sp) -80000158: 01812403 lw s0,24(sp) -8000015c: 02010113 addi sp,sp,32 -80000160: 00008067 ret +8000015c : +8000015c: fe010113 addi sp,sp,-32 +80000160: 00112e23 sw ra,28(sp) +80000164: 00812c23 sw s0,24(sp) +80000168: 02010413 addi s0,sp,32 +8000016c: fea42623 sw a0,-20(s0) +80000170: feb42423 sw a1,-24(s0) +80000174: fec42503 lw a0,-20(s0) +80000178: f61ff0ef jal ra,800000d8 +8000017c: fe842503 lw a0,-24(s0) +80000180: f95ff0ef jal ra,80000114 +80000184: 810007b7 lui a5,0x81000 +80000188: 04078513 addi a0,a5,64 # 81000040 +8000018c: f4dff0ef jal ra,800000d8 +80000190: 00000013 nop +80000194: 01c12083 lw ra,28(sp) +80000198: 01812403 lw s0,24(sp) +8000019c: 02010113 addi sp,sp,32 +800001a0: 00008067 ret -80000164 : -80000164: fe010113 addi sp,sp,-32 -80000168: 00112e23 sw ra,28(sp) -8000016c: 00812c23 sw s0,24(sp) -80000170: 02010413 addi s0,sp,32 -80000174: fea42623 sw a0,-20(s0) -80000178: feb42423 sw a1,-24(s0) -8000017c: fec42503 lw a0,-20(s0) -80000180: f61ff0ef jal ra,800000e0 -80000184: fe842503 lw a0,-24(s0) -80000188: f95ff0ef jal ra,8000011c -8000018c: 810007b7 lui a5,0x81000 -80000190: 04078513 addi a0,a5,64 # 81000040 -80000194: f4dff0ef jal ra,800000e0 -80000198: 00000013 nop -8000019c: 01c12083 lw ra,28(sp) -800001a0: 01812403 lw s0,24(sp) -800001a4: 02010113 addi sp,sp,32 -800001a8: 00008067 ret - -800001ac : -800001ac: fe010113 addi sp,sp,-32 -800001b0: 00112e23 sw ra,28(sp) -800001b4: 00812c23 sw s0,24(sp) -800001b8: 02010413 addi s0,sp,32 -800001bc: 810007b7 lui a5,0x81000 -800001c0: 23c7a783 lw a5,572(a5) # 8100023c -800001c4: 00078513 mv a0,a5 -800001c8: ea9ff0ef jal ra,80000070 +800001a4 : +800001a4: fe010113 addi sp,sp,-32 +800001a8: 00112e23 sw ra,28(sp) +800001ac: 00812c23 sw s0,24(sp) +800001b0: 02010413 addi s0,sp,32 +800001b4: 810007b7 lui a5,0x81000 +800001b8: 2607a783 lw a5,608(a5) # 81000260 +800001bc: 00078513 mv a0,a5 +800001c0: ea9ff0ef jal ra,80000068 +800001c4: 810007b7 lui a5,0x81000 +800001c8: 25c7a703 lw a4,604(a5) # 8100025c 800001cc: 810007b7 lui a5,0x81000 -800001d0: 2387a703 lw a4,568(a5) # 81000238 -800001d4: 810007b7 lui a5,0x81000 -800001d8: 2347a783 lw a5,564(a5) # 81000234 -800001dc: 00078513 mv a0,a5 -800001e0: 000700e7 jalr a4 -800001e4: eadff0ef jal ra,80000090 -800001e8: fea42623 sw a0,-20(s0) -800001ec: fec42783 lw a5,-20(s0) -800001f0: 00078863 beqz a5,80000200 -800001f4: 00000513 li a0,0 -800001f8: e79ff0ef jal ra,80000070 -800001fc: 00c0006f j 80000208 -80000200: 00100513 li a0,1 -80000204: e6dff0ef jal ra,80000070 -80000208: 00000013 nop -8000020c: 01c12083 lw ra,28(sp) -80000210: 01812403 lw s0,24(sp) -80000214: 02010113 addi sp,sp,32 -80000218: 00008067 ret +800001d0: 2587a783 lw a5,600(a5) # 81000258 +800001d4: 00078513 mv a0,a5 +800001d8: 000700e7 jalr a4 +800001dc: eadff0ef jal ra,80000088 +800001e0: fea42623 sw a0,-20(s0) +800001e4: fec42783 lw a5,-20(s0) +800001e8: 00078863 beqz a5,800001f8 +800001ec: 00000513 li a0,0 +800001f0: e79ff0ef jal ra,80000068 +800001f4: 00c0006f j 80000200 +800001f8: 00100513 li a0,1 +800001fc: e6dff0ef jal ra,80000068 +80000200: 00000013 nop +80000204: 01c12083 lw ra,28(sp) +80000208: 01812403 lw s0,24(sp) +8000020c: 02010113 addi sp,sp,32 +80000210: 00008067 ret -8000021c : -8000021c: fe010113 addi sp,sp,-32 -80000220: 00112e23 sw ra,28(sp) -80000224: 00812c23 sw s0,24(sp) -80000228: 02010413 addi s0,sp,32 -8000022c: fea42623 sw a0,-20(s0) -80000230: feb42423 sw a1,-24(s0) -80000234: fec42223 sw a2,-28(s0) -80000238: fed42023 sw a3,-32(s0) -8000023c: 810007b7 lui a5,0x81000 -80000240: fe442703 lw a4,-28(s0) -80000244: 22e7ac23 sw a4,568(a5) # 81000238 -80000248: 810007b7 lui a5,0x81000 -8000024c: fe042703 lw a4,-32(s0) -80000250: 22e7aa23 sw a4,564(a5) # 81000234 -80000254: 810007b7 lui a5,0x81000 -80000258: fe842703 lw a4,-24(s0) -8000025c: 22e7ae23 sw a4,572(a5) # 8100023c -80000260: fe442783 lw a5,-28(s0) -80000264: 00078593 mv a1,a5 -80000268: fec42503 lw a0,-20(s0) -8000026c: dfdff0ef jal ra,80000068 -80000270: f3dff0ef jal ra,800001ac -80000274: 00000013 nop -80000278: 01c12083 lw ra,28(sp) -8000027c: 01812403 lw s0,24(sp) -80000280: 02010113 addi sp,sp,32 -80000284: 00008067 ret +80000214 : +80000214: fe010113 addi sp,sp,-32 +80000218: 00112e23 sw ra,28(sp) +8000021c: 00812c23 sw s0,24(sp) +80000220: 02010413 addi s0,sp,32 +80000224: fea42623 sw a0,-20(s0) +80000228: feb42423 sw a1,-24(s0) +8000022c: fec42223 sw a2,-28(s0) +80000230: fed42023 sw a3,-32(s0) +80000234: 810007b7 lui a5,0x81000 +80000238: fe442703 lw a4,-28(s0) +8000023c: 24e7ae23 sw a4,604(a5) # 8100025c +80000240: 810007b7 lui a5,0x81000 +80000244: fe042703 lw a4,-32(s0) +80000248: 24e7ac23 sw a4,600(a5) # 81000258 +8000024c: 810007b7 lui a5,0x81000 +80000250: fe842703 lw a4,-24(s0) +80000254: 26e7a023 sw a4,608(a5) # 81000260 +80000258: fe442783 lw a5,-28(s0) +8000025c: 00078593 mv a1,a5 +80000260: fec42503 lw a0,-20(s0) +80000264: dfdff0ef jal ra,80000060 +80000268: f3dff0ef jal ra,800001a4 +8000026c: 00000013 nop +80000270: 01c12083 lw ra,28(sp) +80000274: 01812403 lw s0,24(sp) +80000278: 02010113 addi sp,sp,32 +8000027c: 00008067 ret -80000288 : -80000288: fe010113 addi sp,sp,-32 -8000028c: 00112e23 sw ra,28(sp) -80000290: 00812c23 sw s0,24(sp) -80000294: 02010413 addi s0,sp,32 -80000298: 810007b7 lui a5,0x81000 -8000029c: 08478513 addi a0,a5,132 # 81000084 -800002a0: e41ff0ef jal ra,800000e0 -800002a4: 00400513 li a0,4 -800002a8: dc9ff0ef jal ra,80000070 -800002ac: dedff0ef jal ra,80000098 -800002b0: fea42623 sw a0,-20(s0) -800002b4: fec42703 lw a4,-20(s0) -800002b8: 810007b7 lui a5,0x81000 -800002bc: fec42683 lw a3,-20(s0) -800002c0: 00269693 slli a3,a3,0x2 -800002c4: 24078793 addi a5,a5,576 # 81000240 -800002c8: 00f687b3 add a5,a3,a5 -800002cc: 00e7a023 sw a4,0(a5) -800002d0: 00100513 li a0,1 -800002d4: d9dff0ef jal ra,80000070 -800002d8: 810007b7 lui a5,0x81000 -800002dc: 2407a783 lw a5,576(a5) # 81000240 -800002e0: 00078513 mv a0,a5 -800002e4: e39ff0ef jal ra,8000011c -800002e8: 810007b7 lui a5,0x81000 -800002ec: 09078513 addi a0,a5,144 # 81000090 -800002f0: df1ff0ef jal ra,800000e0 -800002f4: 810007b7 lui a5,0x81000 -800002f8: 24078793 addi a5,a5,576 # 81000240 -800002fc: 0047a783 lw a5,4(a5) -80000300: 00078513 mv a0,a5 -80000304: e19ff0ef jal ra,8000011c -80000308: 810007b7 lui a5,0x81000 -8000030c: 09078513 addi a0,a5,144 # 81000090 -80000310: dd1ff0ef jal ra,800000e0 -80000314: 810007b7 lui a5,0x81000 -80000318: 24078793 addi a5,a5,576 # 81000240 -8000031c: 0087a783 lw a5,8(a5) -80000320: 00078513 mv a0,a5 -80000324: df9ff0ef jal ra,8000011c -80000328: 810007b7 lui a5,0x81000 -8000032c: 09078513 addi a0,a5,144 # 81000090 -80000330: db1ff0ef jal ra,800000e0 -80000334: 810007b7 lui a5,0x81000 -80000338: 24078793 addi a5,a5,576 # 81000240 -8000033c: 00c7a783 lw a5,12(a5) -80000340: 00078513 mv a0,a5 -80000344: dd9ff0ef jal ra,8000011c -80000348: 810007b7 lui a5,0x81000 -8000034c: 09078513 addi a0,a5,144 # 81000090 -80000350: d91ff0ef jal ra,800000e0 -80000354: 00000013 nop -80000358: 01c12083 lw ra,28(sp) -8000035c: 01812403 lw s0,24(sp) -80000360: 02010113 addi sp,sp,32 -80000364: 00008067 ret +80000280 : +80000280: fe010113 addi sp,sp,-32 +80000284: 00112e23 sw ra,28(sp) +80000288: 00812c23 sw s0,24(sp) +8000028c: 02010413 addi s0,sp,32 +80000290: 810007b7 lui a5,0x81000 +80000294: 08478513 addi a0,a5,132 # 81000084 +80000298: e41ff0ef jal ra,800000d8 +8000029c: 00400513 li a0,4 +800002a0: dc9ff0ef jal ra,80000068 +800002a4: dedff0ef jal ra,80000090 +800002a8: fea42623 sw a0,-20(s0) +800002ac: fec42703 lw a4,-20(s0) +800002b0: 810007b7 lui a5,0x81000 +800002b4: fec42683 lw a3,-20(s0) +800002b8: 00269693 slli a3,a3,0x2 +800002bc: 26478793 addi a5,a5,612 # 81000264 +800002c0: 00f687b3 add a5,a3,a5 +800002c4: 00e7a023 sw a4,0(a5) +800002c8: 00100513 li a0,1 +800002cc: d9dff0ef jal ra,80000068 +800002d0: 810007b7 lui a5,0x81000 +800002d4: 2647a783 lw a5,612(a5) # 81000264 +800002d8: 00078513 mv a0,a5 +800002dc: e39ff0ef jal ra,80000114 +800002e0: 810007b7 lui a5,0x81000 +800002e4: 09078513 addi a0,a5,144 # 81000090 +800002e8: df1ff0ef jal ra,800000d8 +800002ec: 810007b7 lui a5,0x81000 +800002f0: 26478793 addi a5,a5,612 # 81000264 +800002f4: 0047a783 lw a5,4(a5) +800002f8: 00078513 mv a0,a5 +800002fc: e19ff0ef jal ra,80000114 +80000300: 810007b7 lui a5,0x81000 +80000304: 09078513 addi a0,a5,144 # 81000090 +80000308: dd1ff0ef jal ra,800000d8 +8000030c: 810007b7 lui a5,0x81000 +80000310: 26478793 addi a5,a5,612 # 81000264 +80000314: 0087a783 lw a5,8(a5) +80000318: 00078513 mv a0,a5 +8000031c: df9ff0ef jal ra,80000114 +80000320: 810007b7 lui a5,0x81000 +80000324: 09078513 addi a0,a5,144 # 81000090 +80000328: db1ff0ef jal ra,800000d8 +8000032c: 810007b7 lui a5,0x81000 +80000330: 26478793 addi a5,a5,612 # 81000264 +80000334: 00c7a783 lw a5,12(a5) +80000338: 00078513 mv a0,a5 +8000033c: dd9ff0ef jal ra,80000114 +80000340: 810007b7 lui a5,0x81000 +80000344: 09078513 addi a0,a5,144 # 81000090 +80000348: d91ff0ef jal ra,800000d8 +8000034c: 00000013 nop +80000350: 01c12083 lw ra,28(sp) +80000354: 01812403 lw s0,24(sp) +80000358: 02010113 addi sp,sp,32 +8000035c: 00008067 ret -80000368 : -80000368: fe010113 addi sp,sp,-32 -8000036c: 00112e23 sw ra,28(sp) -80000370: 00812c23 sw s0,24(sp) -80000374: 02010413 addi s0,sp,32 -80000378: d21ff0ef jal ra,80000098 -8000037c: fea42623 sw a0,-20(s0) -80000380: fec42783 lw a5,-20(s0) -80000384: 0027b793 sltiu a5,a5,2 -80000388: fef405a3 sb a5,-21(s0) -8000038c: feb44783 lbu a5,-21(s0) -80000390: 00078513 mv a0,a5 -80000394: cedff0ef jal ra,80000080 -80000398: feb44783 lbu a5,-21(s0) -8000039c: 06078463 beqz a5,80000404 -800003a0: fec42783 lw a5,-20(s0) -800003a4: 0017b793 seqz a5,a5 -800003a8: fef40523 sb a5,-22(s0) -800003ac: fea44783 lbu a5,-22(s0) -800003b0: 00078513 mv a0,a5 -800003b4: ccdff0ef jal ra,80000080 -800003b8: fea44783 lbu a5,-22(s0) -800003bc: 02078263 beqz a5,800003e0 -800003c0: 810007b7 lui a5,0x81000 -800003c4: fec42703 lw a4,-20(s0) -800003c8: 00271713 slli a4,a4,0x2 -800003cc: 24078793 addi a5,a5,576 # 81000240 -800003d0: 00f707b3 add a5,a4,a5 -800003d4: 00a00713 li a4,10 -800003d8: 00e7a023 sw a4,0(a5) -800003dc: 0200006f j 800003fc -800003e0: 810007b7 lui a5,0x81000 -800003e4: fec42703 lw a4,-20(s0) -800003e8: 00271713 slli a4,a4,0x2 -800003ec: 24078793 addi a5,a5,576 # 81000240 -800003f0: 00f707b3 add a5,a4,a5 -800003f4: 00b00713 li a4,11 -800003f8: 00e7a023 sw a4,0(a5) -800003fc: c8dff0ef jal ra,80000088 -80000400: 0640006f j 80000464 -80000404: fec42783 lw a5,-20(s0) -80000408: 0037b793 sltiu a5,a5,3 -8000040c: fef404a3 sb a5,-23(s0) -80000410: fe944783 lbu a5,-23(s0) -80000414: 00078513 mv a0,a5 -80000418: c69ff0ef jal ra,80000080 -8000041c: fe944783 lbu a5,-23(s0) -80000420: 02078263 beqz a5,80000444 -80000424: 810007b7 lui a5,0x81000 -80000428: fec42703 lw a4,-20(s0) -8000042c: 00271713 slli a4,a4,0x2 -80000430: 24078793 addi a5,a5,576 # 81000240 -80000434: 00f707b3 add a5,a4,a5 -80000438: 00c00713 li a4,12 -8000043c: 00e7a023 sw a4,0(a5) -80000440: 0200006f j 80000460 -80000444: 810007b7 lui a5,0x81000 -80000448: fec42703 lw a4,-20(s0) -8000044c: 00271713 slli a4,a4,0x2 -80000450: 24078793 addi a5,a5,576 # 81000240 -80000454: 00f707b3 add a5,a4,a5 -80000458: 00d00713 li a4,13 -8000045c: 00e7a023 sw a4,0(a5) -80000460: c29ff0ef jal ra,80000088 -80000464: c25ff0ef jal ra,80000088 -80000468: 810007b7 lui a5,0x81000 -8000046c: 2407a783 lw a5,576(a5) # 81000240 -80000470: 00078513 mv a0,a5 -80000474: ca9ff0ef jal ra,8000011c -80000478: 810007b7 lui a5,0x81000 -8000047c: 09078513 addi a0,a5,144 # 81000090 -80000480: c61ff0ef jal ra,800000e0 -80000484: 810007b7 lui a5,0x81000 -80000488: 24078793 addi a5,a5,576 # 81000240 -8000048c: 0047a783 lw a5,4(a5) -80000490: 00078513 mv a0,a5 -80000494: c89ff0ef jal ra,8000011c -80000498: 810007b7 lui a5,0x81000 -8000049c: 09078513 addi a0,a5,144 # 81000090 -800004a0: c41ff0ef jal ra,800000e0 -800004a4: 810007b7 lui a5,0x81000 -800004a8: 24078793 addi a5,a5,576 # 81000240 -800004ac: 0087a783 lw a5,8(a5) -800004b0: 00078513 mv a0,a5 -800004b4: c69ff0ef jal ra,8000011c -800004b8: 810007b7 lui a5,0x81000 -800004bc: 09078513 addi a0,a5,144 # 81000090 -800004c0: c21ff0ef jal ra,800000e0 -800004c4: 810007b7 lui a5,0x81000 -800004c8: 24078793 addi a5,a5,576 # 81000240 -800004cc: 00c7a783 lw a5,12(a5) -800004d0: 00078513 mv a0,a5 -800004d4: c49ff0ef jal ra,8000011c -800004d8: 810007b7 lui a5,0x81000 -800004dc: 09078513 addi a0,a5,144 # 81000090 -800004e0: c01ff0ef jal ra,800000e0 -800004e4: 00000013 nop -800004e8: 01c12083 lw ra,28(sp) -800004ec: 01812403 lw s0,24(sp) -800004f0: 02010113 addi sp,sp,32 -800004f4: 00008067 ret +80000360 : +80000360: fe010113 addi sp,sp,-32 +80000364: 00112e23 sw ra,28(sp) +80000368: 00812c23 sw s0,24(sp) +8000036c: 02010413 addi s0,sp,32 +80000370: d21ff0ef jal ra,80000090 +80000374: fea42623 sw a0,-20(s0) +80000378: fec42783 lw a5,-20(s0) +8000037c: 0027b793 sltiu a5,a5,2 +80000380: fef405a3 sb a5,-21(s0) +80000384: feb44783 lbu a5,-21(s0) +80000388: 00078513 mv a0,a5 +8000038c: cedff0ef jal ra,80000078 +80000390: feb44783 lbu a5,-21(s0) +80000394: 06078463 beqz a5,800003fc +80000398: fec42783 lw a5,-20(s0) +8000039c: 0017b793 seqz a5,a5 +800003a0: fef40523 sb a5,-22(s0) +800003a4: fea44783 lbu a5,-22(s0) +800003a8: 00078513 mv a0,a5 +800003ac: ccdff0ef jal ra,80000078 +800003b0: fea44783 lbu a5,-22(s0) +800003b4: 02078263 beqz a5,800003d8 +800003b8: 810007b7 lui a5,0x81000 +800003bc: fec42703 lw a4,-20(s0) +800003c0: 00271713 slli a4,a4,0x2 +800003c4: 26478793 addi a5,a5,612 # 81000264 +800003c8: 00f707b3 add a5,a4,a5 +800003cc: 00a00713 li a4,10 +800003d0: 00e7a023 sw a4,0(a5) +800003d4: 0200006f j 800003f4 +800003d8: 810007b7 lui a5,0x81000 +800003dc: fec42703 lw a4,-20(s0) +800003e0: 00271713 slli a4,a4,0x2 +800003e4: 26478793 addi a5,a5,612 # 81000264 +800003e8: 00f707b3 add a5,a4,a5 +800003ec: 00b00713 li a4,11 +800003f0: 00e7a023 sw a4,0(a5) +800003f4: c8dff0ef jal ra,80000080 +800003f8: 0640006f j 8000045c +800003fc: fec42783 lw a5,-20(s0) +80000400: 0037b793 sltiu a5,a5,3 +80000404: fef404a3 sb a5,-23(s0) +80000408: fe944783 lbu a5,-23(s0) +8000040c: 00078513 mv a0,a5 +80000410: c69ff0ef jal ra,80000078 +80000414: fe944783 lbu a5,-23(s0) +80000418: 02078263 beqz a5,8000043c +8000041c: 810007b7 lui a5,0x81000 +80000420: fec42703 lw a4,-20(s0) +80000424: 00271713 slli a4,a4,0x2 +80000428: 26478793 addi a5,a5,612 # 81000264 +8000042c: 00f707b3 add a5,a4,a5 +80000430: 00c00713 li a4,12 +80000434: 00e7a023 sw a4,0(a5) +80000438: 0200006f j 80000458 +8000043c: 810007b7 lui a5,0x81000 +80000440: fec42703 lw a4,-20(s0) +80000444: 00271713 slli a4,a4,0x2 +80000448: 26478793 addi a5,a5,612 # 81000264 +8000044c: 00f707b3 add a5,a4,a5 +80000450: 00d00713 li a4,13 +80000454: 00e7a023 sw a4,0(a5) +80000458: c29ff0ef jal ra,80000080 +8000045c: c25ff0ef jal ra,80000080 +80000460: 810007b7 lui a5,0x81000 +80000464: 2647a783 lw a5,612(a5) # 81000264 +80000468: 00078513 mv a0,a5 +8000046c: ca9ff0ef jal ra,80000114 +80000470: 810007b7 lui a5,0x81000 +80000474: 09078513 addi a0,a5,144 # 81000090 +80000478: c61ff0ef jal ra,800000d8 +8000047c: 810007b7 lui a5,0x81000 +80000480: 26478793 addi a5,a5,612 # 81000264 +80000484: 0047a783 lw a5,4(a5) +80000488: 00078513 mv a0,a5 +8000048c: c89ff0ef jal ra,80000114 +80000490: 810007b7 lui a5,0x81000 +80000494: 09078513 addi a0,a5,144 # 81000090 +80000498: c41ff0ef jal ra,800000d8 +8000049c: 810007b7 lui a5,0x81000 +800004a0: 26478793 addi a5,a5,612 # 81000264 +800004a4: 0087a783 lw a5,8(a5) +800004a8: 00078513 mv a0,a5 +800004ac: c69ff0ef jal ra,80000114 +800004b0: 810007b7 lui a5,0x81000 +800004b4: 09078513 addi a0,a5,144 # 81000090 +800004b8: c21ff0ef jal ra,800000d8 +800004bc: 810007b7 lui a5,0x81000 +800004c0: 26478793 addi a5,a5,612 # 81000264 +800004c4: 00c7a783 lw a5,12(a5) +800004c8: 00078513 mv a0,a5 +800004cc: c49ff0ef jal ra,80000114 +800004d0: 810007b7 lui a5,0x81000 +800004d4: 09078513 addi a0,a5,144 # 81000090 +800004d8: c01ff0ef jal ra,800000d8 +800004dc: 00000013 nop +800004e0: 01c12083 lw ra,28(sp) +800004e4: 01812403 lw s0,24(sp) +800004e8: 02010113 addi sp,sp,32 +800004ec: 00008067 ret -800004f8 : -800004f8: fe010113 addi sp,sp,-32 -800004fc: 00112e23 sw ra,28(sp) -80000500: 00812c23 sw s0,24(sp) -80000504: 02010413 addi s0,sp,32 -80000508: b89ff0ef jal ra,80000090 -8000050c: fea42623 sw a0,-20(s0) -80000510: 810007b7 lui a5,0x81000 -80000514: fec42703 lw a4,-20(s0) -80000518: 00271713 slli a4,a4,0x2 -8000051c: 25078793 addi a5,a5,592 # 81000250 -80000520: 00f707b3 add a5,a4,a5 -80000524: fec42703 lw a4,-20(s0) -80000528: 00e7a023 sw a4,0(a5) -8000052c: fec42783 lw a5,-20(s0) -80000530: 00078663 beqz a5,8000053c -80000534: 00000513 li a0,0 -80000538: b39ff0ef jal ra,80000070 -8000053c: 00000013 nop -80000540: 01c12083 lw ra,28(sp) -80000544: 01812403 lw s0,24(sp) -80000548: 02010113 addi sp,sp,32 -8000054c: 00008067 ret +800004f0 : +800004f0: fe010113 addi sp,sp,-32 +800004f4: 00112e23 sw ra,28(sp) +800004f8: 00812c23 sw s0,24(sp) +800004fc: 02010413 addi s0,sp,32 +80000500: b89ff0ef jal ra,80000088 +80000504: fea42623 sw a0,-20(s0) +80000508: 810007b7 lui a5,0x81000 +8000050c: fec42703 lw a4,-20(s0) +80000510: 00271713 slli a4,a4,0x2 +80000514: 27478793 addi a5,a5,628 # 81000274 +80000518: 00f707b3 add a5,a4,a5 +8000051c: fec42703 lw a4,-20(s0) +80000520: 00e7a023 sw a4,0(a5) +80000524: fec42783 lw a5,-20(s0) +80000528: 00078663 beqz a5,80000534 +8000052c: 00000513 li a0,0 +80000530: b39ff0ef jal ra,80000068 +80000534: 00000013 nop +80000538: 01c12083 lw ra,28(sp) +8000053c: 01812403 lw s0,24(sp) +80000540: 02010113 addi sp,sp,32 +80000544: 00008067 ret -80000550 : -80000550: fe010113 addi sp,sp,-32 -80000554: 00112e23 sw ra,28(sp) -80000558: 00812c23 sw s0,24(sp) -8000055c: 02010413 addi s0,sp,32 -80000560: 800007b7 lui a5,0x80000 -80000564: 4f878793 addi a5,a5,1272 # 800004f8 -80000568: fef42623 sw a5,-20(s0) -8000056c: fec42583 lw a1,-20(s0) -80000570: 00400513 li a0,4 -80000574: af5ff0ef jal ra,80000068 -80000578: f81ff0ef jal ra,800004f8 -8000057c: 810007b7 lui a5,0x81000 -80000580: 2507a783 lw a5,592(a5) # 81000250 -80000584: 00078513 mv a0,a5 -80000588: b95ff0ef jal ra,8000011c -8000058c: 810007b7 lui a5,0x81000 -80000590: 09078513 addi a0,a5,144 # 81000090 -80000594: b4dff0ef jal ra,800000e0 -80000598: 810007b7 lui a5,0x81000 -8000059c: 25078793 addi a5,a5,592 # 81000250 -800005a0: 0047a783 lw a5,4(a5) -800005a4: 00078513 mv a0,a5 -800005a8: b75ff0ef jal ra,8000011c -800005ac: 810007b7 lui a5,0x81000 -800005b0: 09078513 addi a0,a5,144 # 81000090 -800005b4: b2dff0ef jal ra,800000e0 -800005b8: 810007b7 lui a5,0x81000 -800005bc: 25078793 addi a5,a5,592 # 81000250 -800005c0: 0087a783 lw a5,8(a5) -800005c4: 00078513 mv a0,a5 -800005c8: b55ff0ef jal ra,8000011c -800005cc: 810007b7 lui a5,0x81000 -800005d0: 09078513 addi a0,a5,144 # 81000090 -800005d4: b0dff0ef jal ra,800000e0 -800005d8: 810007b7 lui a5,0x81000 -800005dc: 25078793 addi a5,a5,592 # 81000250 -800005e0: 00c7a783 lw a5,12(a5) -800005e4: 00078513 mv a0,a5 -800005e8: b35ff0ef jal ra,8000011c -800005ec: 810007b7 lui a5,0x81000 -800005f0: 09078513 addi a0,a5,144 # 81000090 -800005f4: aedff0ef jal ra,800000e0 -800005f8: 00000013 nop -800005fc: 01c12083 lw ra,28(sp) -80000600: 01812403 lw s0,24(sp) -80000604: 02010113 addi sp,sp,32 -80000608: 00008067 ret +80000548 : +80000548: fe010113 addi sp,sp,-32 +8000054c: 00112e23 sw ra,28(sp) +80000550: 00812c23 sw s0,24(sp) +80000554: 02010413 addi s0,sp,32 +80000558: 800007b7 lui a5,0x80000 +8000055c: 4f078793 addi a5,a5,1264 # 800004f0 +80000560: fef42623 sw a5,-20(s0) +80000564: fec42583 lw a1,-20(s0) +80000568: 00400513 li a0,4 +8000056c: af5ff0ef jal ra,80000060 +80000570: f81ff0ef jal ra,800004f0 +80000574: 810007b7 lui a5,0x81000 +80000578: 2747a783 lw a5,628(a5) # 81000274 +8000057c: 00078513 mv a0,a5 +80000580: b95ff0ef jal ra,80000114 +80000584: 810007b7 lui a5,0x81000 +80000588: 09078513 addi a0,a5,144 # 81000090 +8000058c: b4dff0ef jal ra,800000d8 +80000590: 810007b7 lui a5,0x81000 +80000594: 27478793 addi a5,a5,628 # 81000274 +80000598: 0047a783 lw a5,4(a5) +8000059c: 00078513 mv a0,a5 +800005a0: b75ff0ef jal ra,80000114 +800005a4: 810007b7 lui a5,0x81000 +800005a8: 09078513 addi a0,a5,144 # 81000090 +800005ac: b2dff0ef jal ra,800000d8 +800005b0: 810007b7 lui a5,0x81000 +800005b4: 27478793 addi a5,a5,628 # 81000274 +800005b8: 0087a783 lw a5,8(a5) +800005bc: 00078513 mv a0,a5 +800005c0: b55ff0ef jal ra,80000114 +800005c4: 810007b7 lui a5,0x81000 +800005c8: 09078513 addi a0,a5,144 # 81000090 +800005cc: b0dff0ef jal ra,800000d8 +800005d0: 810007b7 lui a5,0x81000 +800005d4: 27478793 addi a5,a5,628 # 81000274 +800005d8: 00c7a783 lw a5,12(a5) +800005dc: 00078513 mv a0,a5 +800005e0: b35ff0ef jal ra,80000114 +800005e4: 810007b7 lui a5,0x81000 +800005e8: 09078513 addi a0,a5,144 # 81000090 +800005ec: aedff0ef jal ra,800000d8 +800005f0: 00000013 nop +800005f4: 01c12083 lw ra,28(sp) +800005f8: 01812403 lw s0,24(sp) +800005fc: 02010113 addi sp,sp,32 +80000600: 00008067 ret -8000060c : -8000060c: ff010113 addi sp,sp,-16 -80000610: 00112623 sw ra,12(sp) -80000614: 00812423 sw s0,8(sp) -80000618: 01010413 addi s0,sp,16 -8000061c: c6dff0ef jal ra,80000288 -80000620: 810007b7 lui a5,0x81000 -80000624: 09478513 addi a0,a5,148 # 81000094 -80000628: ab9ff0ef jal ra,800000e0 -8000062c: 00400513 li a0,4 -80000630: a41ff0ef jal ra,80000070 -80000634: d35ff0ef jal ra,80000368 -80000638: 00100513 li a0,1 -8000063c: a35ff0ef jal ra,80000070 -80000640: 810007b7 lui a5,0x81000 -80000644: 0a878513 addi a0,a5,168 # 810000a8 -80000648: a99ff0ef jal ra,800000e0 -8000064c: f05ff0ef jal ra,80000550 -80000650: 00000013 nop -80000654: 00c12083 lw ra,12(sp) -80000658: 00812403 lw s0,8(sp) -8000065c: 01010113 addi sp,sp,16 -80000660: 00008067 ret +80000604 : +80000604: ff010113 addi sp,sp,-16 +80000608: 00112623 sw ra,12(sp) +8000060c: 00812423 sw s0,8(sp) +80000610: 01010413 addi s0,sp,16 +80000614: c6dff0ef jal ra,80000280 +80000618: 810007b7 lui a5,0x81000 +8000061c: 09478513 addi a0,a5,148 # 81000094 +80000620: ab9ff0ef jal ra,800000d8 +80000624: 00400513 li a0,4 +80000628: a41ff0ef jal ra,80000068 +8000062c: d35ff0ef jal ra,80000360 +80000630: 00100513 li a0,1 +80000634: a35ff0ef jal ra,80000068 +80000638: 810007b7 lui a5,0x81000 +8000063c: 0a878513 addi a0,a5,168 # 810000a8 +80000640: a99ff0ef jal ra,800000d8 +80000644: f05ff0ef jal ra,80000548 +80000648: 00000013 nop +8000064c: 00c12083 lw ra,12(sp) +80000650: 00812403 lw s0,8(sp) +80000654: 01010113 addi sp,sp,16 +80000658: 00008067 ret -80000664 : -80000664: fc010113 addi sp,sp,-64 -80000668: 02112e23 sw ra,60(sp) -8000066c: 02812c23 sw s0,56(sp) -80000670: 04010413 addi s0,sp,64 -80000674: fca42623 sw a0,-52(s0) -80000678: fcc42783 lw a5,-52(s0) -8000067c: fef42623 sw a5,-20(s0) -80000680: a11ff0ef jal ra,80000090 -80000684: fea42423 sw a0,-24(s0) -80000688: a11ff0ef jal ra,80000098 -8000068c: fea42223 sw a0,-28(s0) -80000690: fec42783 lw a5,-20(s0) -80000694: 0107a783 lw a5,16(a5) -80000698: fe842703 lw a4,-24(s0) -8000069c: 00f77e63 bgeu a4,a5,800006b8 -800006a0: fec42783 lw a5,-20(s0) -800006a4: 00c7a783 lw a5,12(a5) -800006a8: fe442703 lw a4,-28(s0) -800006ac: 00f77663 bgeu a4,a5,800006b8 -800006b0: 00100793 li a5,1 -800006b4: 0080006f j 800006bc -800006b8: 00000793 li a5,0 -800006bc: fef401a3 sb a5,-29(s0) -800006c0: fe344783 lbu a5,-29(s0) -800006c4: 0017f793 andi a5,a5,1 -800006c8: fef401a3 sb a5,-29(s0) -800006cc: fe344783 lbu a5,-29(s0) -800006d0: 00078513 mv a0,a5 -800006d4: 9adff0ef jal ra,80000080 -800006d8: fe344783 lbu a5,-29(s0) -800006dc: 06078663 beqz a5,80000748 -800006e0: fec42783 lw a5,-20(s0) -800006e4: 00c7a703 lw a4,12(a5) -800006e8: fe842783 lw a5,-24(s0) -800006ec: 02f707b3 mul a5,a4,a5 -800006f0: fe442703 lw a4,-28(s0) -800006f4: 00f707b3 add a5,a4,a5 -800006f8: fcf42e23 sw a5,-36(s0) -800006fc: fec42783 lw a5,-20(s0) -80000700: 0007a703 lw a4,0(a5) -80000704: fdc42783 lw a5,-36(s0) -80000708: 00279793 slli a5,a5,0x2 -8000070c: 00f707b3 add a5,a4,a5 -80000710: 0007a683 lw a3,0(a5) -80000714: fec42783 lw a5,-20(s0) -80000718: 0047a703 lw a4,4(a5) -8000071c: fdc42783 lw a5,-36(s0) -80000720: 00279793 slli a5,a5,0x2 -80000724: 00f707b3 add a5,a4,a5 -80000728: 0007a703 lw a4,0(a5) -8000072c: fec42783 lw a5,-20(s0) -80000730: 0087a603 lw a2,8(a5) -80000734: fdc42783 lw a5,-36(s0) -80000738: 00279793 slli a5,a5,0x2 -8000073c: 00f607b3 add a5,a2,a5 -80000740: 00e68733 add a4,a3,a4 -80000744: 00e7a023 sw a4,0(a5) -80000748: 941ff0ef jal ra,80000088 -8000074c: 00000013 nop -80000750: 03c12083 lw ra,60(sp) -80000754: 03812403 lw s0,56(sp) -80000758: 04010113 addi sp,sp,64 -8000075c: 00008067 ret +8000065c : +8000065c: fc010113 addi sp,sp,-64 +80000660: 02112e23 sw ra,60(sp) +80000664: 02812c23 sw s0,56(sp) +80000668: 04010413 addi s0,sp,64 +8000066c: fca42623 sw a0,-52(s0) +80000670: fcc42783 lw a5,-52(s0) +80000674: fef42623 sw a5,-20(s0) +80000678: a11ff0ef jal ra,80000088 +8000067c: fea42423 sw a0,-24(s0) +80000680: a11ff0ef jal ra,80000090 +80000684: fea42223 sw a0,-28(s0) +80000688: fec42783 lw a5,-20(s0) +8000068c: 0107a783 lw a5,16(a5) +80000690: fe842703 lw a4,-24(s0) +80000694: 00f77e63 bgeu a4,a5,800006b0 +80000698: fec42783 lw a5,-20(s0) +8000069c: 00c7a783 lw a5,12(a5) +800006a0: fe442703 lw a4,-28(s0) +800006a4: 00f77663 bgeu a4,a5,800006b0 +800006a8: 00100793 li a5,1 +800006ac: 0080006f j 800006b4 +800006b0: 00000793 li a5,0 +800006b4: fef401a3 sb a5,-29(s0) +800006b8: fe344783 lbu a5,-29(s0) +800006bc: 0017f793 andi a5,a5,1 +800006c0: fef401a3 sb a5,-29(s0) +800006c4: fe344783 lbu a5,-29(s0) +800006c8: 00078513 mv a0,a5 +800006cc: 9adff0ef jal ra,80000078 +800006d0: fe344783 lbu a5,-29(s0) +800006d4: 06078663 beqz a5,80000740 +800006d8: fec42783 lw a5,-20(s0) +800006dc: 00c7a703 lw a4,12(a5) +800006e0: fe842783 lw a5,-24(s0) +800006e4: 02f707b3 mul a5,a4,a5 +800006e8: fe442703 lw a4,-28(s0) +800006ec: 00f707b3 add a5,a4,a5 +800006f0: fcf42e23 sw a5,-36(s0) +800006f4: fec42783 lw a5,-20(s0) +800006f8: 0007a703 lw a4,0(a5) +800006fc: fdc42783 lw a5,-36(s0) +80000700: 00279793 slli a5,a5,0x2 +80000704: 00f707b3 add a5,a4,a5 +80000708: 0007a683 lw a3,0(a5) +8000070c: fec42783 lw a5,-20(s0) +80000710: 0047a703 lw a4,4(a5) +80000714: fdc42783 lw a5,-36(s0) +80000718: 00279793 slli a5,a5,0x2 +8000071c: 00f707b3 add a5,a4,a5 +80000720: 0007a703 lw a4,0(a5) +80000724: fec42783 lw a5,-20(s0) +80000728: 0087a603 lw a2,8(a5) +8000072c: fdc42783 lw a5,-36(s0) +80000730: 00279793 slli a5,a5,0x2 +80000734: 00f607b3 add a5,a2,a5 +80000738: 00e68733 add a4,a3,a4 +8000073c: 00e7a023 sw a4,0(a5) +80000740: 941ff0ef jal ra,80000080 +80000744: 00000013 nop +80000748: 03c12083 lw ra,60(sp) +8000074c: 03812403 lw s0,56(sp) +80000750: 04010113 addi sp,sp,64 +80000754: 00008067 ret -80000760
: -80000760: fd010113 addi sp,sp,-48 -80000764: 02112623 sw ra,44(sp) -80000768: 02812423 sw s0,40(sp) -8000076c: 03010413 addi s0,sp,48 -80000770: 00100513 li a0,1 -80000774: 8fdff0ef jal ra,80000070 -80000778: 810007b7 lui a5,0x81000 -8000077c: 1b478793 addi a5,a5,436 # 810001b4 -80000780: fcf42a23 sw a5,-44(s0) -80000784: 810007b7 lui a5,0x81000 -80000788: 1f478793 addi a5,a5,500 # 810001f4 -8000078c: fcf42c23 sw a5,-40(s0) -80000790: 810007b7 lui a5,0x81000 -80000794: 26078793 addi a5,a5,608 # 81000260 -80000798: fcf42e23 sw a5,-36(s0) -8000079c: 00400793 li a5,4 -800007a0: fef42023 sw a5,-32(s0) -800007a4: 00400793 li a5,4 -800007a8: fef42223 sw a5,-28(s0) -800007ac: 00400793 li a5,4 -800007b0: fef42623 sw a5,-20(s0) -800007b4: 00400793 li a5,4 -800007b8: fef42423 sw a5,-24(s0) -800007bc: fec42703 lw a4,-20(s0) -800007c0: fe842583 lw a1,-24(s0) -800007c4: fd440793 addi a5,s0,-44 -800007c8: 00078693 mv a3,a5 -800007cc: 800007b7 lui a5,0x80000 -800007d0: 66478613 addi a2,a5,1636 # 80000664 -800007d4: 00070513 mv a0,a4 -800007d8: a45ff0ef jal ra,8000021c -800007dc: 00000793 li a5,0 -800007e0: 00078513 mv a0,a5 -800007e4: 02c12083 lw ra,44(sp) -800007e8: 02812403 lw s0,40(sp) -800007ec: 03010113 addi sp,sp,48 -800007f0: 00008067 ret +80000758
: +80000758: ff010113 addi sp,sp,-16 +8000075c: 00112623 sw ra,12(sp) +80000760: 00812423 sw s0,8(sp) +80000764: 01010413 addi s0,sp,16 +80000768: 00100513 li a0,1 +8000076c: 8fdff0ef jal ra,80000068 +80000770: b11ff0ef jal ra,80000280 +80000774: 810007b7 lui a5,0x81000 +80000778: 0f478513 addi a0,a5,244 # 810000f4 +8000077c: 95dff0ef jal ra,800000d8 +80000780: 00400513 li a0,4 +80000784: 8e5ff0ef jal ra,80000068 +80000788: bd9ff0ef jal ra,80000360 +8000078c: 00100513 li a0,1 +80000790: 8d9ff0ef jal ra,80000068 +80000794: 810007b7 lui a5,0x81000 +80000798: 10878513 addi a0,a5,264 # 81000108 +8000079c: 93dff0ef jal ra,800000d8 +800007a0: da9ff0ef jal ra,80000548 +800007a4: 00000793 li a5,0 +800007a8: 00078513 mv a0,a5 +800007ac: 00c12083 lw ra,12(sp) +800007b0: 00812403 lw s0,8(sp) +800007b4: 01010113 addi sp,sp,16 +800007b8: 00008067 ret Disassembly of section .rodata: @@ -592,7 +578,7 @@ Disassembly of section .rodata: 8100002a: 0000 unimp 8100002c: 0062 c.slli zero,0x18 8100002e: 0000 unimp -81000030: 00000063 beqz zero,81000030 +81000030: 00000063 beqz zero,81000030 81000034: 0064 addi s1,sp,12 81000036: 0000 unimp 81000038: 0065 c.nop 25 @@ -623,7 +609,7 @@ Disassembly of section .rodata: 8100006e: 0000 unimp 81000070: 0062 c.slli zero,0x18 81000072: 0000 unimp -81000074: 00000063 beqz zero,81000074 +81000074: 00000063 beqz zero,81000074 81000078: 0064 addi s1,sp,12 8100007a: 0000 unimp 8100007c: 0065 c.nop 25 @@ -671,136 +657,132 @@ Disassembly of section .rodata: 810000de: 0000 unimp 810000e0: 0062 c.slli zero,0x18 810000e2: 0000 unimp -810000e4: 00000063 beqz zero,810000e4 +810000e4: 00000063 beqz zero,810000e4 810000e8: 0064 addi s1,sp,12 810000ea: 0000 unimp 810000ec: 0065 c.nop 25 810000ee: 0000 unimp 810000f0: 0066 c.slli zero,0x19 +810000f2: 0000 unimp +810000f4: 6574 flw fa3,76(a0) +810000f6: 645f7473 csrrci s0,0x645,30 +810000fa: 7669 lui a2,0xffffa +810000fc: 7265 lui tp,0xffff9 +810000fe: 636e6567 0x636e6567 +81000102: 0a65 addi s4,s4,25 +81000104: 0000 unimp +81000106: 0000 unimp +81000108: 6574 flw fa3,76(a0) +8100010a: 775f7473 csrrci s0,0x775,30 +8100010e: 77617073 csrci 0x776,2 +81000112: 0a6e slli s4,s4,0x1b + ... Disassembly of section .data: -810000f4 : -810000f4: 0000 unimp -810000f6: 8100 0x8100 -810000f8: 0004 0x4 -810000fa: 8100 0x8100 -810000fc: 0008 0x8 -810000fe: 8100 0x8100 -81000100: 000c 0xc -81000102: 8100 0x8100 -81000104: 0010 0x10 -81000106: 8100 0x8100 -81000108: 0014 0x14 -8100010a: 8100 0x8100 -8100010c: 0018 0x18 -8100010e: 8100 0x8100 -81000110: 001c 0x1c -81000112: 8100 0x8100 -81000114: 0020 addi s0,sp,8 -81000116: 8100 0x8100 -81000118: 0024 addi s1,sp,8 +81000118 : +81000118: 0000 unimp 8100011a: 8100 0x8100 -8100011c: 0028 addi a0,sp,8 +8100011c: 0004 0x4 8100011e: 8100 0x8100 -81000120: 002c addi a1,sp,8 +81000120: 0008 0x8 81000122: 8100 0x8100 -81000124: 0030 addi a2,sp,8 +81000124: 000c 0xc 81000126: 8100 0x8100 -81000128: 0034 addi a3,sp,8 +81000128: 0010 0x10 8100012a: 8100 0x8100 -8100012c: 0038 addi a4,sp,8 +8100012c: 0014 0x14 8100012e: 8100 0x8100 -81000130: 003c addi a5,sp,8 +81000130: 0018 0x18 81000132: 8100 0x8100 - -81000134 : -81000134: 0044 addi s1,sp,4 +81000134: 001c 0x1c 81000136: 8100 0x8100 -81000138: 0048 addi a0,sp,4 +81000138: 0020 addi s0,sp,8 8100013a: 8100 0x8100 -8100013c: 004c addi a1,sp,4 +8100013c: 0024 addi s1,sp,8 8100013e: 8100 0x8100 -81000140: 0050 addi a2,sp,4 +81000140: 0028 addi a0,sp,8 81000142: 8100 0x8100 -81000144: 0054 addi a3,sp,4 +81000144: 002c addi a1,sp,8 81000146: 8100 0x8100 -81000148: 0058 addi a4,sp,4 +81000148: 0030 addi a2,sp,8 8100014a: 8100 0x8100 -8100014c: 005c addi a5,sp,4 +8100014c: 0034 addi a3,sp,8 8100014e: 8100 0x8100 -81000150: 0060 addi s0,sp,12 +81000150: 0038 addi a4,sp,8 81000152: 8100 0x8100 -81000154: 0064 addi s1,sp,12 +81000154: 003c addi a5,sp,8 81000156: 8100 0x8100 -81000158: 0068 addi a0,sp,12 + +81000158 : +81000158: 0044 addi s1,sp,4 8100015a: 8100 0x8100 -8100015c: 006c addi a1,sp,12 +8100015c: 0048 addi a0,sp,4 8100015e: 8100 0x8100 -81000160: 0070 addi a2,sp,12 +81000160: 004c addi a1,sp,4 81000162: 8100 0x8100 -81000164: 0074 addi a3,sp,12 +81000164: 0050 addi a2,sp,4 81000166: 8100 0x8100 -81000168: 0078 addi a4,sp,12 +81000168: 0054 addi a3,sp,4 8100016a: 8100 0x8100 -8100016c: 007c addi a5,sp,12 +8100016c: 0058 addi a4,sp,4 8100016e: 8100 0x8100 -81000170: 0080 addi s0,sp,64 +81000170: 005c addi a5,sp,4 81000172: 8100 0x8100 - -81000174 : -81000174: 00b4 addi a3,sp,72 +81000174: 0060 addi s0,sp,12 81000176: 8100 0x8100 -81000178: 00b8 addi a4,sp,72 +81000178: 0064 addi s1,sp,12 8100017a: 8100 0x8100 -8100017c: 00bc addi a5,sp,72 +8100017c: 0068 addi a0,sp,12 8100017e: 8100 0x8100 -81000180: 00c0 addi s0,sp,68 +81000180: 006c addi a1,sp,12 81000182: 8100 0x8100 -81000184: 00c4 addi s1,sp,68 +81000184: 0070 addi a2,sp,12 81000186: 8100 0x8100 -81000188: 00c8 addi a0,sp,68 +81000188: 0074 addi a3,sp,12 8100018a: 8100 0x8100 -8100018c: 00cc addi a1,sp,68 +8100018c: 0078 addi a4,sp,12 8100018e: 8100 0x8100 -81000190: 00d0 addi a2,sp,68 +81000190: 007c addi a5,sp,12 81000192: 8100 0x8100 -81000194: 00d4 addi a3,sp,68 +81000194: 0080 addi s0,sp,64 81000196: 8100 0x8100 -81000198: 00d8 addi a4,sp,68 -8100019a: 8100 0x8100 -8100019c: 00dc addi a5,sp,68 -8100019e: 8100 0x8100 -810001a0: 00e0 addi s0,sp,76 -810001a2: 8100 0x8100 -810001a4: 00e4 addi s1,sp,76 -810001a6: 8100 0x8100 -810001a8: 00e8 addi a0,sp,76 -810001aa: 8100 0x8100 -810001ac: 00ec addi a1,sp,76 -810001ae: 8100 0x8100 -810001b0: 00f0 addi a2,sp,76 -810001b2: 8100 0x8100 -810001b4 : -810001b4: 0001 nop -810001b6: 0000 unimp -810001b8: 0001 nop -810001ba: 0000 unimp -810001bc: 0001 nop -810001be: 0000 unimp -810001c0: 0001 nop -810001c2: 0000 unimp -810001c4: 0001 nop -810001c6: 0000 unimp -810001c8: 0001 nop -810001ca: 0000 unimp -810001cc: 0001 nop -810001ce: 0000 unimp -810001d0: 0001 nop -810001d2: 0000 unimp -810001d4: 0001 nop -810001d6: 0000 unimp +81000198 : +81000198: 00b4 addi a3,sp,72 +8100019a: 8100 0x8100 +8100019c: 00b8 addi a4,sp,72 +8100019e: 8100 0x8100 +810001a0: 00bc addi a5,sp,72 +810001a2: 8100 0x8100 +810001a4: 00c0 addi s0,sp,68 +810001a6: 8100 0x8100 +810001a8: 00c4 addi s1,sp,68 +810001aa: 8100 0x8100 +810001ac: 00c8 addi a0,sp,68 +810001ae: 8100 0x8100 +810001b0: 00cc addi a1,sp,68 +810001b2: 8100 0x8100 +810001b4: 00d0 addi a2,sp,68 +810001b6: 8100 0x8100 +810001b8: 00d4 addi a3,sp,68 +810001ba: 8100 0x8100 +810001bc: 00d8 addi a4,sp,68 +810001be: 8100 0x8100 +810001c0: 00dc addi a5,sp,68 +810001c2: 8100 0x8100 +810001c4: 00e0 addi s0,sp,76 +810001c6: 8100 0x8100 +810001c8: 00e4 addi s1,sp,76 +810001ca: 8100 0x8100 +810001cc: 00e8 addi a0,sp,76 +810001ce: 8100 0x8100 +810001d0: 00ec addi a1,sp,76 +810001d2: 8100 0x8100 +810001d4: 00f0 addi a2,sp,76 +810001d6: 8100 0x8100 + +810001d8 : 810001d8: 0001 nop 810001da: 0000 unimp 810001dc: 0001 nop @@ -814,27 +796,27 @@ Disassembly of section .data: 810001ec: 0001 nop 810001ee: 0000 unimp 810001f0: 0001 nop +810001f2: 0000 unimp +810001f4: 0001 nop +810001f6: 0000 unimp +810001f8: 0001 nop +810001fa: 0000 unimp +810001fc: 0001 nop +810001fe: 0000 unimp +81000200: 0001 nop +81000202: 0000 unimp +81000204: 0001 nop +81000206: 0000 unimp +81000208: 0001 nop +8100020a: 0000 unimp +8100020c: 0001 nop +8100020e: 0000 unimp +81000210: 0001 nop +81000212: 0000 unimp +81000214: 0001 nop ... -810001f4 : -810001f4: 0006 c.slli zero,0x1 -810001f6: 0000 unimp -810001f8: 0006 c.slli zero,0x1 -810001fa: 0000 unimp -810001fc: 0006 c.slli zero,0x1 -810001fe: 0000 unimp -81000200: 0006 c.slli zero,0x1 -81000202: 0000 unimp -81000204: 0006 c.slli zero,0x1 -81000206: 0000 unimp -81000208: 0006 c.slli zero,0x1 -8100020a: 0000 unimp -8100020c: 0006 c.slli zero,0x1 -8100020e: 0000 unimp -81000210: 0006 c.slli zero,0x1 -81000212: 0000 unimp -81000214: 0006 c.slli zero,0x1 -81000216: 0000 unimp +81000218 : 81000218: 0006 c.slli zero,0x1 8100021a: 0000 unimp 8100021c: 0006 c.slli zero,0x1 @@ -848,29 +830,47 @@ Disassembly of section .data: 8100022c: 0006 c.slli zero,0x1 8100022e: 0000 unimp 81000230: 0006 c.slli zero,0x1 +81000232: 0000 unimp +81000234: 0006 c.slli zero,0x1 +81000236: 0000 unimp +81000238: 0006 c.slli zero,0x1 +8100023a: 0000 unimp +8100023c: 0006 c.slli zero,0x1 +8100023e: 0000 unimp +81000240: 0006 c.slli zero,0x1 +81000242: 0000 unimp +81000244: 0006 c.slli zero,0x1 +81000246: 0000 unimp +81000248: 0006 c.slli zero,0x1 +8100024a: 0000 unimp +8100024c: 0006 c.slli zero,0x1 +8100024e: 0000 unimp +81000250: 0006 c.slli zero,0x1 +81000252: 0000 unimp +81000254: 0006 c.slli zero,0x1 ... Disassembly of section .bss: -81000234 : -81000234: 0000 unimp +81000258 : +81000258: 0000 unimp ... -81000238 : -81000238: 0000 unimp +8100025c : +8100025c: 0000 unimp ... -8100023c : -8100023c: 0000 unimp +81000260 : +81000260: 0000 unimp ... -81000240 : +81000264 : ... -81000250 : +81000274 : ... -81000260 : +81000284 : ... Disassembly of section .comment: diff --git a/runtime/vortex_runtime.elf b/runtime/vortex_runtime.elf index 6e2ca38b..11470acc 100644 Binary files a/runtime/vortex_runtime.elf and b/runtime/vortex_runtime.elf differ diff --git a/runtime/vortex_runtime.hex b/runtime/vortex_runtime.hex index 851a0a88..654870a4 100644 --- a/runtime/vortex_runtime.hex +++ b/runtime/vortex_runtime.hex @@ -1,132 +1,128 @@ :0200000480007A -:1000000013054000B74500409385053223A0A500A5 -:1000100013000000130000001300000003A60500F9 -:10002000130500006B000500130540006B00050080 -:10003000F32610029396F600732600029315A6008D -:100040001316260037F1FF6F3301B1403301D14061 -:100050003301C100F3261002638606001305000079 -:100060006B000500678000006B10B5006780000022 -:100070006B000500678000006B40B50067800000E2 -:100080006B200500678000006B3000006780000077 -:10009000732510026780000073250002678000004E -:1000A000130540006B000500F32610029396F6003E -:1000B000732600029315A6001316260037F1FF6F72 -:1000C0003301B1403301D1403301C100F3261002A6 -:1000D00063860600130500006B00050067800000C2 -:1000E000130141FF232011002322B10083450500A5 -:1000F00063880500EF00C001130515006FF01FFFB6 -:1001000083200100832541001301C10067800000A6 -:10011000B702010023A0B20067800000130101FEB6 -:10012000232E1100232C8100130401022326A4FE98 -:10013000B70700810327C4FE131727009387470FD3 -:10014000B307F70083A7070013850700EFF05FF9F7 -:10015000130000008320C101032481011301010267 -:1001600067800000130101FE232E1100232C810063 -:10017000130401022326A4FE2324B4FE0325C4FE97 -:10018000EFF01FF6032584FEEFF05FF9B70700815B -:1001900013850704EFF0DFF4130000008320C10192 -:1001A000032481011301010267800000130101FE95 -:1001B000232E1100232C810013040102B7070081B4 -:1001C00083A7C72313850700EFF09FEAB7070081D5 -:1001D00003A78723B707008183A747231385070059 -:1001E000E7000700EFF0DFEA2326A4FE8327C4FE22 -:1001F0006388070013050000EFF09FE76F00C00061 -:1002000013051000EFF0DFE6130000008320C101AA -:10021000032481011301010267800000130101FE24 -:10022000232E1100232C8100130401022326A4FE97 -:100230002324B4FE2322C4FE2320D4FEB70700816A -:10024000032744FE23ACE722B7070081032704FEFF -:1002500023AAE722B7070081032784FE23AEE72203 -:10026000832744FE938507000325C4FEEFF0DFDFFC -:10027000EFF0DFF3130000008320C10103248101AC -:100280001301010267800000130101FE232E1100FB -:10029000232C810013040102B7070081138547084E -:1002A000EFF01FE413054000EFF09FDCEFF0DFDE1E -:1002B0002326A4FE0327C4FEB70700818326C4FEBD -:1002C0009396260093870724B387F60023A0E700C0 -:1002D00013051000EFF0DFD9B707008183A70724CB -:1002E00013850700EFF09FE3B70700811385070927 -:1002F000EFF01FDFB70700819387072483A747002C -:1003000013850700EFF09FE1B70700811385070908 -:10031000EFF01FDDB70700819387072483A78700CD -:1003200013850700EFF09FDFB707008113850709EA -:10033000EFF01FDBB70700819387072483A7C7006F -:1003400013850700EFF09FDDB707008113850709CC -:10035000EFF01FD9130000008320C10103248101A5 -:100360001301010267800000130101FE232E11001A -:10037000232C810013040102EFF01FD22326A4FED8 -:100380008327C4FE93B72700A305F4FE8347B4FE7A -:1003900013850700EFF0DFCE8347B4FE63840706C2 -:1003A0008327C4FE93B717002305F4FE8347A4FEFA -:1003B00013850700EFF0DFCC8347A4FE63820702BA -:1003C000B70700810327C4FE13172700938707246C -:1003D000B307F7001307A00023A0E7006F00000297 -:1003E000B70700810327C4FE13172700938707244C -:1003F000B307F7001307B00023A0E700EFF0DFC852 -:100400006F0040068327C4FE93B73700A304F4FEB1 -:10041000834794FE13850700EFF09FC6834794FE41 -:1004200063820702B70700810327C4FE1317270062 -:1004300093870724B307F7001307C00023A0E70042 -:100440006F000002B70700810327C4FE13172700BF -:1004500093870724B307F7001307D00023A0E70012 -:10046000EFF09FC2EFF05FC2B707008183A70724B8 -:1004700013850700EFF09FCAB707008113850709AE -:10048000EFF01FC6B70700819387072483A74700B3 -:1004900013850700EFF09FC8B70700811385070990 -:1004A000EFF01FC4B70700819387072483A7870055 -:1004B00013850700EFF09FC6B70700811385070972 -:1004C000EFF01FC2B70700819387072483A7C700F7 -:1004D00013850700EFF09FC4B70700811385070954 -:1004E000EFF01FC0130000008320C101032481012D -:1004F0001301010267800000130101FE232E110089 -:10050000232C810013040102EFF09FB82326A4FEE0 -:10051000B70700810327C4FE131727009387072519 -:10052000B307F7000327C4FE23A0E7008327C4FE18 -:100530006386070013050000EFF09FB3130000006F -:100540008320C1010324810113010102678000009F -:10055000130101FE232E1100232C8100130401023C -:10056000B70700809387874F2326F4FE8325C4FEB8 -:1005700013054000EFF05FAFEFF01FF8B707008101 -:1005800083A7072513850700EFF05FB9B707008140 -:1005900013850709EFF0DFB4B707008193870725BC -:1005A00083A7470013850700EFF05FB7B707008107 -:1005B00013850709EFF0DFB2B7070081938707259E -:1005C00083A7870013850700EFF05FB5B7070081A9 -:1005D00013850709EFF0DFB0B70700819387072580 -:1005E00083A7C70013850700EFF05FB3B70700814B -:1005F00013850709EFF0DFAE130000008320C1016F -:10060000032481011301010267800000130101FF2F -:10061000232611002324810013040101EFF0DFC61B -:10062000B707008113854709EFF09FAB1305400022 -:10063000EFF01FA4EFF05FD313051000EFF05FA3FE -:10064000B70700811385870AEFF09FA9EFF05FF0ED -:10065000130000008320C100032481001301010165 -:1006600067800000130101FC232E1102232C81025C -:10067000130401042326A4FC8327C4FC2326F4FED0 -:10068000EFF01FA12324A4FEEFF01FA12322A4FE5C -:100690008327C4FE83A70701032784FE637EF70038 -:1006A0008327C4FE83A7C700032744FE6376F700B1 -:1006B000930710006F00800093070000A301F4FE71 -:1006C000834734FE93F71700A301F4FE834734FEFB -:1006D00013850700EFF0DF9A834734FE6386070631 -:1006E0008327C4FE03A7C700832784FEB307F7024E -:1006F000032744FEB307F700232EF4FC8327C4FE30 -:1007000003A707008327C4FD93972700B307F700CB -:1007100083A607008327C4FE03A747008327C4FDE1 -:1007200093972700B307F70003A707008327C4FEAA -:1007300003A687008327C4FD93972700B307F6001D -:100740003387E60023A0E700EFF01F9413000000BA -:100750008320C10303248103130101046780000087 -:10076000130101FD23261102232481021304010336 -:1007700013051000EFF0DF8FB70700819387471B49 -:10078000232AF4FCB70700819387471F232CF4FC2E -:10079000B707008193870726232EF4FC93074000B8 -:1007A0002320F4FE930740002322F4FE9307400029 -:1007B0002326F4FE930740002324F4FE0327C4FEFF -:1007C000832584FE930744FD93860700B7070080C6 -:1007D0001386476613050700EFF05FA49307000038 -:1007E000138507008320C102032481021301010342 -:0407F000678000001E +:100000009705000093850502130540006B10B500AD +:10001000EF000001EF004074130500006B000500C5 +:10002000130540006B000500F32610029396F600BE +:10003000732600029315A6001316260037F1FF6FF2 +:100040003301B1403301D1403301C100F326100226 +:1000500063860600130500006B0005006780000042 +:100060006B10B500678000006B0005006780000022 +:100070006B40B500678000006B20050067800000C2 +:100080006B3000006780000073251002678000005D +:100090007325000267800000130540006B00050017 +:1000A000F32610029396F600732600029315A6001D +:1000B0001316260037F1FF6F3301B1403301D140F1 +:1000C0003301C100F3261002638606001305000009 +:1000D0006B00050067800000130141FF2320110021 +:1000E0002322B1008345050063880500EF00C001AD +:1000F000130515006FF01FFF8320010083254100C9 +:100100001301C10067800000B702010023A0B20004 +:1001100067800000130101FE232E1100232C8100B3 +:10012000130401022326A4FEB70700810327C4FE9F +:100130001317270093878711B307F70083A70700DA +:1001400013850700EFF05FF9130000008320C10161 +:10015000032481011301010267800000130101FEE5 +:10016000232E1100232C8100130401022326A4FE58 +:100170002324B4FE0325C4FEEFF01FF6032584FEFE +:10018000EFF05FF9B707008113850704EFF0DFF4A4 +:10019000130000008320C101032481011301010227 +:1001A00067800000130101FE232E1100232C810023 +:1001B00013040102B707008183A7072613850700F0 +:1001C000EFF09FEAB707008103A7C725B7070081B3 +:1001D00083A7872513850700E7000700EFF0DFEA14 +:1001E0002326A4FE8327C4FE6388070013050000AE +:1001F000EFF09FE76F00C00013051000EFF0DFE69F +:10020000130000008320C1010324810113010102B6 +:1002100067800000130101FE232E1100232C8100B2 +:10022000130401022326A4FE2324B4FE2322C4FEC9 +:100230002320D4FEB7070081032744FE23AEE72422 +:10024000B7070081032704FE23ACE724B70700812A +:10025000032784FE23A0E726832744FE9385070017 +:100260000325C4FEEFF0DFDFEFF0DFF31300000043 +:100270008320C10103248101130101026780000072 +:10028000130101FE232E1100232C8100130401020F +:10029000B707008113854708EFF01FE413054000FE +:1002A000EFF09FDCEFF0DFDE2326A4FE0327C4FE81 +:1002B000B70700818326C4FE9396260093874726BE +:1002C000B387F60023A0E70013051000EFF0DFD995 +:1002D000B707008183A7472613850700EFF09FE348 +:1002E000B707008113850709EFF01FDFB70700810B +:1002F0009387472683A7470013850700EFF09FE108 +:10030000B707008113850709EFF01FDDB7070081EC +:100310009387472683A7870013850700EFF09FDFA9 +:10032000B707008113850709EFF01FDBB7070081CE +:100330009387472683A7C70013850700EFF09FDD4B +:10034000B707008113850709EFF01FD913000000DC +:100350008320C10103248101130101026780000091 +:10036000130101FE232E1100232C8100130401022E +:10037000EFF01FD22326A4FE8327C4FE93B72700E5 +:10038000A305F4FE8347B4FE13850700EFF0DFCE2C +:100390008347B4FE638407068327C4FE93B7170020 +:1003A0002305F4FE8347A4FE13850700EFF0DFCC9E +:1003B0008347A4FE63820702B70700810327C4FEB8 +:1003C0001317270093874726B307F7001307A000EA +:1003D00023A0E7006F000002B70700810327C4FED7 +:1003E0001317270093874726B307F7001307B000BA +:1003F00023A0E700EFF0DFC86F0040068327C4FEAC +:1004000093B73700A304F4FE834794FE13850700D7 +:10041000EFF09FC6834794FE63820702B70700810F +:100420000327C4FE1317270093874726B307F70057 +:100430001307C00023A0E7006F000002B707008188 +:100440000327C4FE1317270093874726B307F70037 +:100450001307D00023A0E700EFF09FC2EFF05FC2C8 +:10046000B707008183A7472613850700EFF09FCACF +:10047000B707008113850709EFF01FC6B707008192 +:100480009387472683A7470013850700EFF09FC88F +:10049000B707008113850709EFF01FC4B707008174 +:1004A0009387472683A7870013850700EFF09FC631 +:1004B000B707008113850709EFF01FC2B707008156 +:1004C0009387472683A7C70013850700EFF09FC4D3 +:1004D000B707008113850709EFF01FC01300000064 +:1004E0008320C10103248101130101026780000000 +:1004F000130101FE232E1100232C8100130401029D +:10050000EFF09FB82326A4FEB70700810327C4FE9F +:100510001317270093874727B307F7000327C4FE65 +:1005200023A0E7008327C4FE6386070013050000AD +:10053000EFF09FB3130000008320C1010324810169 +:100540001301010267800000130101FE232E110038 +:10055000232C810013040102B70700809387074F03 +:100560002326F4FE8325C4FE13054000EFF05FAFA1 +:10057000EFF01FF8B707008183A74727138507000F +:10058000EFF05FB9B707008113850709EFF0DFB41B +:10059000B70700819387472783A747001385070084 +:1005A000EFF05FB7B707008113850709EFF0DFB2FF +:1005B000B70700819387472783A787001385070024 +:1005C000EFF05FB5B707008113850709EFF0DFB0E3 +:1005D000B70700819387472783A7C70013850700C4 +:1005E000EFF05FB3B707008113850709EFF0DFAEC7 +:1005F000130000008320C1010324810113010102C3 +:1006000067800000130101FF2326110023248100CD +:1006100013040101EFF0DFC6B70700811385470916 +:10062000EFF09FAB13054000EFF01FA4EFF05FD396 +:1006300013051000EFF05FA3B70700811385870A49 +:10064000EFF09FA9EFF05FF0130000008320C100DE +:10065000032481001301010167800000130101FCE4 +:10066000232E1102232C8102130401042326A4FC4F +:100670008327C4FC2326F4FEEFF01FA12324A4FE4D +:10068000EFF01FA12322A4FE8327C4FE83A7070146 +:10069000032784FE637EF7008327C4FE83A7C70079 +:1006A000032744FE6376F700930710006F00800075 +:1006B00093070000A301F4FE834734FE93F717006D +:1006C000A301F4FE834734FE13850700EFF0DF9AA1 +:1006D000834734FE638607068327C4FE03A7C7004B +:1006E000832784FEB307F702032744FEB307F7000E +:1006F000232EF4FC8327C4FE03A707008327C4FD31 +:1007000093972700B307F70083A607008327C4FE4B +:1007100003A747008327C4FD93972700B307F7007B +:1007200003A707008327C4FE03A687008327C4FD11 +:1007300093972700B307F6003387E60023A0E7006E +:10074000EFF01F94130000008320C10303248103F2 +:100750001301010467800000130101FF232611002B +:10076000232481001304010113051000EFF0DF8F33 +:10077000EFF01FB1B70700811385470FEFF0DF954A +:1007800013054000EFF05F8EEFF09FBD13051000E2 +:10079000EFF09F8DB707008113858710EFF0DF938F +:1007A000EFF09FDA93070000138507008320C10054 +:0C07B00003248100130101016780000098 :02000004810079 :10000000300000003100000032000000330000002A :10001000340000003500000036000000370000000A @@ -143,26 +139,28 @@ :1000C000330000003400000035000000360000005E :1000D0003700000038000000390000006100000017 :1000E0006200000063000000640000006500000082 -:0200F0006600A8 -:1000F4000000008104000081080000810C000081E0 -:100104001000008114000081180000811C0000818F -:100114002000008124000081280000812C0000813F -:100124003000008134000081380000813C000081EF -:1001340044000081480000814C000081500000818F -:1001440054000081580000815C000081600000813F -:1001540064000081680000816C00008170000081EF -:1001640074000081780000817C000081800000819F -:10017400B4000081B8000081BC000081C00000818F -:10018400C4000081C8000081CC000081D00000813F -:10019400D4000081D8000081DC000081E0000081EF -:1001A400E4000081E8000081EC000081F00000819F -:1001B4000100000001000000010000000100000037 -:1001C4000100000001000000010000000100000027 -:1001D4000100000001000000010000000100000017 -:1001E4000100000001000000010000000100000007 -:1001F40006000000060000000600000006000000E3 -:1002040006000000060000000600000006000000D2 -:1002140006000000060000000600000006000000C2 -:1002240006000000060000000600000006000000B2 +:1000F00066000000746573745F6469766572676595 +:100100006E63650A00000000746573745F77737036 +:0501100061776E0A009A +:100118000000008104000081080000810C000081BB +:100128001000008114000081180000811C0000816B +:100138002000008124000081280000812C0000811B +:100148003000008134000081380000813C000081CB +:1001580044000081480000814C000081500000816B +:1001680054000081580000815C000081600000811B +:1001780064000081680000816C00008170000081CB +:1001880074000081780000817C000081800000817B +:10019800B4000081B8000081BC000081C00000816B +:1001A800C4000081C8000081CC000081D00000811B +:1001B800D4000081D8000081DC000081E0000081CB +:1001C800E4000081E8000081EC000081F00000817B +:1001D8000100000001000000010000000100000013 +:1001E8000100000001000000010000000100000003 +:1001F80001000000010000000100000001000000F3 +:1002080001000000010000000100000001000000E2 +:1002180006000000060000000600000006000000BE +:1002280006000000060000000600000006000000AE +:10023800060000000600000006000000060000009E +:10024800060000000600000006000000060000008E :040000058000000077 :00000001FF diff --git a/runtime/vx_api/vx_api.c b/runtime/vx_api/vx_api.c new file mode 100644 index 00000000..f636b4e6 --- /dev/null +++ b/runtime/vx_api/vx_api.c @@ -0,0 +1,37 @@ + +#include "../intrinsics/vx_intrinsics.h" +#include "vx_api.h" + + + +func_t global_function_pointer; +// void (func_t)(void *) + +void * global_argument_struct; + +unsigned global_num_threads; +void setup_call() +{ + vx_tmc(global_num_threads); + global_function_pointer(global_argument_struct); + + unsigned wid = vx_warpID(); + if (wid != 0) + { + vx_tmc(0); // Halt Warp Execution + } + else + { + vx_tmc(1); // Only activate one thread + } +} + +void vx_spawnWarps(unsigned numWarps, unsigned numThreads, func_t func_ptr, void * args) +{ + global_function_pointer = func_ptr; + global_argument_struct = args; + global_num_threads = numThreads; + vx_wspawn(numWarps, (unsigned) func_ptr); + setup_call(); + +} diff --git a/runtime/vx_api/vx_api.h b/runtime/vx_api/vx_api.h new file mode 100644 index 00000000..f6a43e7f --- /dev/null +++ b/runtime/vx_api/vx_api.h @@ -0,0 +1,18 @@ + +#ifndef VX_API_ + +#define VX_API_ + + +typedef void (*func_t)(void *); + +void vx_spawnWarps(unsigned numWarps, unsigned numThreads, func_t func_ptr , void * args); + + + + + + + + +#endif \ No newline at end of file diff --git a/runtime/vx_main.c b/runtime/vx_main.c index 317679c2..8526c688 100644 --- a/runtime/vx_main.c +++ b/runtime/vx_main.c @@ -2,11 +2,71 @@ #include "intrinsics/vx_intrinsics.h" #include "io/vx_io.h" #include "tests/tests.h" +#include "vx_api/vx_api.h" + +typedef struct +{ + unsigned * x; + unsigned * y; + unsigned * z; + unsigned numColums; + unsigned numRows; +} mat_add_args_t; + + +unsigned x[] = {1, 1, 1, 1, + 1, 1, 1, 1, + 1, 1, 1, 1, + 1, 1, 1, 1}; + +unsigned y[] = {6, 6, 6, 6, + 6, 6, 6, 6, + 6, 6, 6, 6, + 6, 6, 6, 6}; + +unsigned z[] = {0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0}; + +void mat_add_kernel(void * void_arguments) +{ + mat_add_args_t * arguments = (mat_add_args_t *) void_arguments; + + unsigned wid = vx_warpID(); + unsigned tid = vx_threadID(); + + bool valid = (wid < arguments->numRows) && (tid < arguments->numColums); + + __if (valid) + { + unsigned index = (wid * arguments->numColums) + tid; + arguments->z[index] = arguments->x[index] + arguments->y[index]; + } + __endif +} + int main() { // Main is called with all threads active of warp 0 vx_tmc(1); + /////////////////////////////////////////////////////////////////////// + + // mat_add_args_t arguments; + // arguments.x = x; + // arguments.y = y; + // arguments.z = z; + // arguments.numColums = 4; + // arguments.numRows = 4; + + + // int numWarps = 4; + // int numThreads = 4; + + // vx_spawnWarps(numWarps, numThreads, mat_add_kernel, &arguments); + + /////////////////////////////////////////////////////////////////////// /* NOTE: * when test_wspawn is called from instrinsic_tests, RA 80000458 is stored at address 6fffefbc, @@ -19,6 +79,7 @@ int main() */ // intrinsics_tests(); + /////////////////////////////////////////////////////////////////////// test_tmc();