From 39c4aefbe9a1dd07576fd58bf9e008e0f28a9849 Mon Sep 17 00:00:00 2001 From: Jiuyang Liu Date: Fri, 18 Oct 2024 17:35:19 +0800 Subject: [PATCH] Add fp field for filter out FP tests Signed-off-by: Avimitin --- generator/insn.go | 16 +++++++++++++++- main.go | 4 +++- single/single.go | 3 +++ 3 files changed, 21 insertions(+), 2 deletions(-) diff --git a/generator/insn.go b/generator/insn.go index c2ef8c8..efbeee6 100644 --- a/generator/insn.go +++ b/generator/insn.go @@ -18,6 +18,7 @@ type insnFormat string type Option struct { VLEN VLEN XLEN XLEN + Fp bool Repeat int Float16 bool } @@ -56,6 +57,7 @@ func (t *TestData) String() string { type Insn struct { Name string `toml:"name"` Format insnFormat `toml:"format"` + Fp bool `toml:"fp"` NoTestfloat3 bool `toml:"notestfloat3"` Vxrm bool `toml:"vxrm"` Vxsat bool `toml:"vxsat"` @@ -287,7 +289,8 @@ func (i *Insn) Generate(splitPerLines int) []string { } func (i *Insn) genHeader() string { - return fmt.Sprintf(`# + if i.Option.Fp { + return fmt.Sprintf(`# # This file is automatically generated. Do not edit. # Instruction: %s @@ -296,6 +299,17 @@ func (i *Insn) genHeader() string { RVTEST_RV%dUV `, i.Name, i.Option.XLEN) + } else { + return fmt.Sprintf(`# +# This file is automatically generated. Do not edit. +# Instruction: %s + +#include "riscv_test.h" +#include "test_macros.h" + +RVTEST_RV%dUVX +`, i.Name, i.Option.XLEN) + } } func (i *Insn) genMergedCodeCombinations(splitPerLines int) ([]string, []string) { diff --git a/main.go b/main.go index d9aeacf..f4b7dc3 100644 --- a/main.go +++ b/main.go @@ -99,6 +99,8 @@ func main() { } if (!strings.HasPrefix(file.Name(), "vf") && !strings.HasPrefix(file.Name(), "vmf")) || strings.HasPrefix(file.Name(), "vfirst") { option.Repeat = 1 + } else { + option.Fp = true } insn, err := generator.ReadInsnFromToml(contents, option) @@ -135,4 +137,4 @@ func writeTo(path string, name string, contents string) { fatalIf(err) err = os.WriteFile(filepath.Join(path, name), []byte(contents), 0644) fatalIf(err) -} \ No newline at end of file +} diff --git a/single/single.go b/single/single.go index 31584f4..a28c03d 100644 --- a/single/single.go +++ b/single/single.go @@ -62,7 +62,10 @@ func main() { if (!strings.HasPrefix(filepath.Base(fp), "vf") && !strings.HasPrefix(filepath.Base(fp), "vmf")) || strings.HasPrefix(filepath.Base(fp), "vfirst") { option.Repeat = 1 + } else { + option.Fp = true } + insn, err := generator.ReadInsnFromToml(contents, option) fatalIf(err)