Added rvvector folder

This commit is contained in:
fares 2019-11-21 10:31:45 -05:00
parent 13ebe51f03
commit b9d9dfabe5
7 changed files with 10354 additions and 0 deletions

37
rvvector/basic/Makefile Normal file
View file

@ -0,0 +1,37 @@
LIB_PATH = ../../runtime
COMP = /home/fares/dev/riscv-gnu-toolchain-vector/drops/bin/riscv32-unknown-elf-gcc
CC_FLAGS = -ffreestanding -O0 -Wl,--gc-sections -nostartfiles -nostdlib -nostartfiles -nodefaultlibs -Wl,-Bstatic,-T,$(LIB_PATH)/mains/vortex_link.ld -march=rv32imv -mabi=ilp32
DMP = /home/fares/dev/riscv-gnu-toolchain-vector/drops/bin/riscv32-unknown-elf-objdump
CPY = /home/fares/dev/riscv-gnu-toolchain-vector/drops/bin/riscv32-unknown-elf-objcopy
# VX_STR = ../../startup/vx_start.s
NEWLIB = $(LIB_PATH)/newlib/newlib.c
VX_STR = $(LIB_PATH)/startup/vx_start.s
VX_INT = $(LIB_PATH)/intrinsics/vx_intrinsics.s
VX_IO = $(LIB_PATH)/io/vx_io.s $(LIB_PATH)/io/vx_io.c
VX_API = $(LIB_PATH)/vx_api/vx_api.c
VX_TEST = $(LIB_PATH)/tests/tests.c
VX_FIO = $(LIB_PATH)/fileio/fileio.s
VX_VEC = vx_vec.s
LIBS = /home/fares/dev/riscv-gnu-toolchain-vector/drops/riscv32-unknown-elf/lib/libc.a /home/fares/dev/riscv-gnu-toolchain-vector/drops/riscv32-unknown-elf/lib/libstdc++.a -static-libgcc -lgcc
VX_MAIN = vx_vector_main
all: HEX DUMP ELF
DUMP: ELF
$(DMP) -D $(VX_MAIN).elf > $(VX_MAIN).dump
HEX: ELF
$(CPY) -O ihex $(VX_MAIN).elf $(VX_MAIN).hex
ELF:
$(COMP) $(CC_FLAGS) $(VX_STR) $(VX_VEC) $(VX_FIO) $(NEWLIB) $(VX_INT) $(VX_IO) $(VX_API) $(VX_TEST) $(VX_MAIN).c $(LIBS) -Iinclude -o $(VX_MAIN).elf

15
rvvector/basic/vx_vec.h Normal file
View file

@ -0,0 +1,15 @@
#pragma once
#ifdef __cplusplus
extern "C" {
#endif
void vx_vec_test();
#ifdef __cplusplus
}
#endif

24
rvvector/basic/vx_vec.s Normal file
View file

@ -0,0 +1,24 @@
.type vx_vec_test, @function
.global vx_vec_test
vx_vec_test:
slli a0, a0, 2
add a0, a0, a3
vmv.v.x vv0, a2
# vsplat4 vv0, a2
stripmine_loop:
vlb4 vv1, (a1)
vcmpez4 vp0, vv1
!vp0 vlw4 vv1, (a3)
!vp0 vlw4 vv2, (a4)
!vp0 vfma4 vv1, vv0, vv1, vv2
!vp0 vsw4 vv1, (a4)
addi a1, a1, 4
addi a3, a3, 16
addi a4, a4, 16
bleu a3, a0, stripmine_loop
# handle edge cases
# when (n % 4) != 0 ...
ret

View file

@ -0,0 +1,10 @@
#include "../../runtime/intrinsics/vx_intrinsics.h"
#include "vx_vec.h"
int main()
{
vx_tmc(1);
vx_vec_test();
vx_tmc(0);
}

File diff suppressed because it is too large Load diff

Binary file not shown.

View file

@ -0,0 +1,286 @@
:0200000480007A
:10000000970500009385C506130540006B10B500E9
:10001000EF00C005130510006B000500138581C3B8
:100020001386C1C33306A64093050000EF00901B62
:10003000171500001305858BEF00D006EF00D010D8
:10004000130540006B000500EF0010026F00D006A2
:10005000B707000093870700638807003715008003
:100060001305858E6F0010046780000013054000A3
:100070006B0005009711000093814179F32610026F
:100080009396A601732600029315A6001316260068
:1000900037F1FF6F3301B1403301D1403301C1006B
:1000A000F326100263860600130500006B000500AE
:1000B0006780000067800000130101FD2326810294
:1000C00013040103232EA4FC232CB4FC232AC4FC18
:1000D0008327C4FD83A707002326F4FE930744FD6E
:1000E0002322F4FE832744FE03C707008327C4FEB0
:1000F0002380E7008327C4FE93871700032744FE6D
:10010000034717002380E7008327C4FE9387270057
:10011000032744FE034727002380E7008327C4FE0C
:1001200093873700032744FE034737002380E70007
:100130008327C4FE938747002326F4FE232404FE6E
:100140006F004003832784FE032784FDB307F70075
:1001500003C707008327C4FE2380E7008327C4FE6C
:10016000938717002326F4FE832784FE93871700C6
:100170002324F4FE832744FD032784FEE344F7FC95
:100180008327C4FE2320F4FE832704FE93F7370061
:10019000032704FEB307F7002320F4FE832704FEA1
:1001A0002326F4FE8327C4FD0327C4FE23A0E70013
:1001B000130000000324C102130101036780000043
:1001C000130101FC232E8102130401042326A4FC45
:1001D0002324B4FC8327C4FC83A707002326F4FE52
:1001E0009307C4FD2322F4FE8327C4FE03C7070040
:1001F000832744FE2380E700832744FE938717006C
:100200000327C4FE034717002380E700832744FE2B
:10021000938727000327C4FE034727002380E700B6
:10022000832744FE938737000327C4FE0347370024
:100230002380E7008327C4FE938747002326F4FE2C
:10024000232404FE6F004003832784FE032784FCDD
:10025000B307F7000327C4FE034707002380E70026
:100260008327C4FE938717002326F4FE832784FE8A
:10027000938717002324F4FE8327C4FD032784FEFD
:10028000E344F7FC8327C4FE2320F4FE832704FE07
:1002900093F73700032704FEB307F7002320F4FE8B
:1002A000832704FE2326F4FE8327C4FC0327C4FE11
:1002B00023A0E700130000000324C103130101047D
:1002C00067800000130101FF232681001304010150
:1002D000130000000324C100130101016780000026
:1002E000130101FE232E8100130401022326A4FE24
:1002F0002324B4FE832784FE3727000023A2E700CF
:1003000093070000138507000324C10113010102B4
:1003100067800000130101FE232E1100232C8100B1
:10032000130401022326A4FEB7170080138507CB10
:10033000EF00C04F93071000138507008320C10111
:10034000032481011301010267800000130101FDF4
:10035000232611022324810213040103232EA4FC6B
:10036000232CB4FC232AC4FCB70700712326F4FE17
:10037000B70700722324F4FE930730002322F4FE13
:10038000130744FE9307C4FE1306400093050700BD
:1003900013850700EFF05FD21307C4FD9307C4FE77
:1003A000130640009305070013850700EFF0DFD028
:1003B000130784FD9307C4FE13064000930507004E
:1003C00013850700EFF05FCF130744FD9307C4FECA
:1003D000130640009305070013850700EFF0DFCDFB
:1003E00083A7C1C2E7800700130704FE930784FEBA
:1003F0009305070013850700EFF09FDC832704FEB9
:10040000138507008320C102032481021301010325
:1004100067800000130101FD2326110223248102BD
:1004200013040103232EA4FC232CB4FC232AC4FCB4
:10043000B70700712324F4FEB70700722326F4FEE9
:10044000930740002322F4FE130744FE930784FE23
:10045000130640009305070013850700EFF0DFC582
:100460001307C4FD930784FE13064000930507009D
:1004700013850700EFF05FC4130784FD930784FE24
:10048000130640009305070013850700EFF0DFC255
:10049000130744FD930784FE1306400093050700ED
:1004A00013850700EFF05FC183A7C1C2E780070093
:1004B000832744FD138507008320C10203248102A2
:1004C0001301010367800000130101FD23261102BF
:1004D0002324810213040103232EA4FC232CB4FC47
:1004E000232AC4FCB70700712326F4FE93075000AB
:1004F0002324F4FE130784FE9307C4FE1306400072
:100500009305070013850700EFF01FBB1307C4FD19
:100510009307C4FE130640009305070013850700E8
:10052000EFF09FB99307C4FE032644FD832584FDA5
:1005300013850700EFF05FB883A7C1C2E78007000B
:10054000832744FD138507008320C1020324810211
:100550001301010367800000130101FD23268102BE
:1005600013040103232EA4FC8327C4FD63D80700D2
:100570008327C4FDB307F040232EF4FC0327C4FDFA
:10058000B73700009387078063D8E700B7370000CC
:1005900093870780232EF4FC83A701C32326F4FE50
:1005A00003A701C38327C4FD3307F70023A8E1C2D3
:1005B0008327C4FE138507000324C102130101032E
:1005C00067800000130101FE232E1100232C8100FF
:1005D000130401022326A4FE13050000EF00001EF1
:1005E000130000008320C1010324810113010102D3
:1005F00067800000130101FD2326110223248102DC
:1006000013040103232EA4FC232CB4FC232AC4FCD2
:10061000B70700712326F4FEB70700722324F4FE07
:10062000930770002322F4FE130744FE9307C4FED1
:10063000130640009305070013850700EFF0DFA7BE
:100640001307C4FD9307C4FE13064000930507007B
:1006500013850700EFF05FA6130784FD9307C4FE20
:10066000130640009305070013850700EFF0DFA491
:10067000130744FD9307C4FE1306400093050700CB
:1006800013850700EFF05FA383A7C1C2E7800700CF
:10069000130704FE930784FE9305070013850700E4
:1006A000EFF01FB2832704FE138507008320C102E9
:1006B000032481021301010367800000130101FF7D
:1006C000232611002324810013040101B7170080A1
:1006D000138547CCEF008015130000008320C10074
:1006E000032481001301010167800000130101FF51
:1006F000232611002324810013040101EF00800E42
:1007000093070500138507008320C100032481009F
:100710001301010167800000130101FF232611006E
:100720002324810013040101B7170080138587CEAD
:10073000EF00C00F130000008320C10003248100DC
:100740001301010167800000130101FF232611003E
:100750002324810013040101B71700801385C7D03B
:10076000EF00C00C83A781C39386170023ACD1C2CE
:10077000138507008320C1000324810013010101B8
:1007800067800000130101FF23261100232481004C
:1007900013040101B7170080138587D3EF00000908
:1007A000130000008320C100032481001301010114
:1007B000678000006B10B500678000006B000500CB
:1007C000678000006B40B500678000006B2005006B
:1007D000678000006B300000678000007325100206
:1007E0006780000073250002678000001305400049
:1007F0006B000500F32610029396F60073260002A4
:100800009315A6001316260037F1FF6F3301B14090
:100810003301D1403301C100F32610026386060084
:10082000130500006B00050067800000130141FF05
:10083000232011002322B1008345050063880500B1
:10084000EF00C001130515006FF01FFF83200100AA
:10085000832541001301C10067800000B702010039
:1008600023A0B20067800000130101FF23261100BE
:10087000232481001304010113051000EFF01FF47D
:10088000EFF05F8313050000EFF05FF3130000004B
:10089000138507008320C100032481001301010197
:1008A0006780000093050500930600001306000012
:1008B000130500006F00C020130101FF9305000025
:1008C000232481002326110013040500EF00C02813
:1008D00003A581C28327C50363840700E78007005F
:1008E00013050400EFF01FCE130101FF2324810044
:1008F0002322910037140080B714008093874400AE
:10090000130444003304F4402326110013542440FC
:1009100063020402931424009384C4FFB384F4009C
:1009200083A704001304F4FF9384C4FFE780070047
:10093000E31804FE8320C1000324810083244100C6
:100940001301010167800000130101FF23248100CE
:1009500023202101371400803719008093070400F9
:10096000130909003309F9402326110023229100BD
:100970001359294063000902130404009304000082
:10098000832704009384140013044400E7800700C5
:10099000E31899FE3714008037190080930704008C
:1009A000130949003309F94013592940630009022A
:1009B00013040400930400008327040093841400AC
:1009C00013044400E7800700E31899FE8320C10068
:1009D0000324810083244100032901001301010144
:1009E000678000001303F00013070500637EC30255
:1009F0009377F7006390070A63920508937606FFE2
:100A00001376F600B386E6002320B7002322B70052
:100A10002324B7002326B70013070701E366D7FE98
:100A20006314060067800000B306C3409396260057
:100A300097020000B38656006780C6002307B70000
:100A4000A306B7002306B700A305B7002305B70028
:100A5000A304B7002304B700A303B7002303B70020
:100A6000A302B7002302B700A301B7002301B70018
:100A7000A300B7002300B7006780000093F5F50FCF
:100A800093968500B3E5D50093960501B3E5D500AF
:100A90006FF0DFF69396270097020000B3865600AA
:100AA00093820000E78006FA93800200938707FF95
:100AB0003307F7403306F600E378C3F66FF0DFF351
:100AC00003A781C283278714638C070403A7470009
:100AD0001308F001634EE8061318270063060502A9
:100AE000338307012324C30883A887181306100043
:100AF0003316E600B3E8C80023A417192324D31043
:100B0000930620006304D5021307170023A2E70011
:100B1000B387070123A4B700130500006780000016
:100B20009307C7142324F7146FF05FFA83A6C7183E
:100B30001307170023A2E70033E6C60023A6C71851
:100B4000B387070123A4B7001305000067800000E6
:100B50001305F0FF67800000130101FD23248101CC
:100B600003AC81C2232E3101232C4101232A5101E0
:100B700023286101232611022324810223229102CA
:100B80002320210323267101930A0500138B0500FE
:100B9000130A10009309F0FF03298C14630809025B
:100BA000832449001384F4FF6342040293942400D5
:100BB000B304990063040B0483A7441063806705A2
:100BC0001304F4FF9384C4FFE31634FF8320C102AF
:100BD0000324810283244102032901028329C101E4
:100BE000032A8101832A4101032B0101832BC100C8
:100BF000032C810013010103678000008327490053
:100C000083A644009387F7FF638A870423A2040026
:100C1000E38806FA8327891833178A00832B490053
:100C2000B377F700639E0700E7800600832749003B
:100C3000E39477F783278C14E38427F96FF0DFF5CB
:100C40008327C91883A544083377F700631C07007E
:100C500013850A00E78006006FF05FFD23228900FC
:100C60006FF01FFB13850500E78006006FF01FFC87
:100C700030000000310000003200000033000000AE
:100C8000340000003500000036000000370000008E
:100C90003800000039000000610000006200000020
:100CA00063000000640000006500000066000000B2
:100CB00048656C6C6F2066726F6D205F697361743C
:100CC00074790A004552524F523A205F6B696C6C3E
:100CD000206E6F742079657420696D706C656D6528
:100CE0006E7465640A0000004552524F523A205F0C
:100CF000756E6C696E6B206E6F74207965742069F7
:100D00006D706C656D656E7465640A004552524F76
:100D1000523A205F67657474696D656F66646179C6
:100D2000206E6F742079657420696D706C656D65D7
:100D30006E7465640A0000004552524F523A205FBB
:100D40006C696E6B206E6F742079657420696D70AC
:0A0D50006C656D656E7465640A0041
:04100000500000801C
:1010080000000000F41200805C130080C41300800C
:1010180000000000000000000000000000000000C8
:1010280000000000000000000000000000000000B8
:1010380000000000000000000000000000000000A8
:101048000000000000000000000000000000000098
:101058000000000000000000000000000000000088
:101068000000000000000000000000000000000078
:101078000000000000000000000000000000000068
:101088000000000000000000000000000000000058
:101098000000000000000000000000000000000048
:1010A8000000000000000000010000000000000037
:1010B8000E33CDAB34126DE6ECDE05000B000000FC
:1010C8000000000000000000000000000000000018
:1010D8000000000000000000000000000000000008
:1010E80000000000000000000000000000000000F8
:1010F80000000000000000000000000000000000E8
:1011080000000000000000000000000000000000D7
:1011180000000000000000000000000000000000C7
:1011280000000000000000000000000000000000B7
:1011380000000000000000000000000000000000A7
:101148000000000000000000000000000000000097
:101158000000000000000000000000000000000087
:101168000000000000000000000000000000000077
:101178000000000000000000000000000000000067
:101188000000000000000000000000000000000057
:101198000000000000000000000000000000000047
:1011A8000000000000000000000000000000000037
:1011B8000000000000000000000000000000000027
:1011C8000000000000000000000000000000000017
:1011D8000000000000000000000000000000000007
:1011E80000000000000000000000000000000000F7
:1011F80000000000000000000000000000000000E7
:1012080000000000000000000000000000000000D6
:1012180000000000000000000000000000000000C6
:1012280000000000000000000000000000000000B6
:1012380000000000000000000000000000000000A6
:101248000000000000000000000000000000000096
:101258000000000000000000000000000000000086
:101268000000000000000000000000000000000076
:101278000000000000000000000000000000000066
:101288000000000000000000000000000000000056
:101298000000000000000000000000000000000046
:1012A8000000000000000000000000000000000036
:1012B8000000000000000000000000000000000026
:1012C8000000000000000000000000000000000016
:1012D8000000000000000000000000000000000006
:1012E80000000000000000000000000000000000F6
:1012F80000000000000000000000000000000000E6
:1013080000000000000000000000000000000000D5
:1013180000000000000000000000000000000000C5
:1013280000000000000000000000000000000000B5
:1013380000000000000000000000000000000000A5
:101348000000000000000000000000000000000095
:101358000000000000000000000000000000000085
:101368000000000000000000000000000000000075
:101378000000000000000000000000000000000065
:101388000000000000000000000000000000000055
:101398000000000000000000000000000000000045
:1013A8000000000000000000000000000000000035
:1013B8000000000000000000000000000000000025
:1013C8000000000000000000000000000000000015
:1013D8000000000000000000000000000000000005
:1013E80000000000000000000000000000000000F5
:1013F80000000000000000000000000000000000E5
:1014080000000000000000000000000000000000D4
:1014180000000000000000000000000000000000C4
:081428000000000000000000BC
:101430000810008000000070000000100000002074
:040000058000000077
:00000001FF