forked from Github_Repos/cvw
392 lines
9.6 KiB
ArmAsm
392 lines
9.6 KiB
ArmAsm
// -----------
|
|
// This file was generated by riscv_ctg (https://gitlab.com/incoresemi/riscv-compliance/riscv_ctg)
|
|
// version : 0.5.1
|
|
// timestamp : Mon Aug 2 08:58:53 2021 GMT
|
|
// usage : riscv_ctg \
|
|
// --cgf /home/bilalsakhawat/riscv-ctg/sample_cgfs/dataset.cgf \
|
|
// --cgf /home/bilalsakhawat/riscv-ctg/sample_cgfs/rv32e.cgf \
|
|
// --base-isa rv32e \
|
|
// --randomize
|
|
// -----------
|
|
//
|
|
// -----------
|
|
// Copyright (c) 2020. RISC-V International. All rights reserved.
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
// -----------
|
|
//
|
|
// This assembly file tests the auipc instruction of the RISC-V E extension for the auipc covergroup.
|
|
//
|
|
#define RVTEST_E
|
|
#include "model_test.h"
|
|
#include "arch_test.h"
|
|
RVTEST_ISA("RV32E")
|
|
|
|
.section .text.init
|
|
.globl rvtest_entry_point
|
|
rvtest_entry_point:
|
|
RVMODEL_BOOT
|
|
RVTEST_CODE_BEGIN
|
|
|
|
#ifdef TEST_CASE_1
|
|
|
|
RVTEST_CASE(0,"//check ISA:=regex(.*32.*);check ISA:=regex(.*E.*) ;def RVTEST_E = True;def TEST_CASE_1=True;",auipc)
|
|
|
|
RVTEST_SIGBASE( x2,signature_x2_1)
|
|
|
|
inst_0:
|
|
// rd==x9, imm_val == ((2**20)-1), imm_val > 0
|
|
// opcode: auipc ; dest:x9; immval:0xfffff
|
|
TEST_AUIPC(auipc, x9, -0x1000, 0xfffff, x2, 0, x3)
|
|
|
|
inst_1:
|
|
// rd==x6, imm_val == 524287,
|
|
// opcode: auipc ; dest:x6; immval:0x7ffff
|
|
TEST_AUIPC(auipc, x6, 0x7ffff000, 0x7ffff, x2, 4, x3)
|
|
|
|
inst_2:
|
|
// rd==x1, imm_val == 786431,
|
|
// opcode: auipc ; dest:x1; immval:0xbffff
|
|
TEST_AUIPC(auipc, x1, -0x40001000, 0xbffff, x2, 8, x3)
|
|
|
|
inst_3:
|
|
// rd==x5, imm_val == 917503,
|
|
// opcode: auipc ; dest:x5; immval:0xdffff
|
|
TEST_AUIPC(auipc, x5, -0x20001000, 0xdffff, x2, 12, x3)
|
|
|
|
inst_4:
|
|
// rd==x14, imm_val == 983039,
|
|
// opcode: auipc ; dest:x14; immval:0xeffff
|
|
TEST_AUIPC(auipc, x14, -0x10001000, 0xeffff, x2, 16, x3)
|
|
|
|
inst_5:
|
|
// rd==x7, imm_val == 1015807,
|
|
// opcode: auipc ; dest:x7; immval:0xf7fff
|
|
TEST_AUIPC(auipc, x7, -0x8001000, 0xf7fff, x2, 20, x3)
|
|
|
|
inst_6:
|
|
// rd==x15, imm_val == 1032191,
|
|
// opcode: auipc ; dest:x15; immval:0xfbfff
|
|
TEST_AUIPC(auipc, x15, -0x4001000, 0xfbfff, x2, 24, x3)
|
|
|
|
inst_7:
|
|
// rd==x10, imm_val == 1040383,
|
|
// opcode: auipc ; dest:x10; immval:0xfdfff
|
|
TEST_AUIPC(auipc, x10, -0x2001000, 0xfdfff, x2, 28, x3)
|
|
|
|
inst_8:
|
|
// rd==x12, imm_val == 1044479,
|
|
// opcode: auipc ; dest:x12; immval:0xfefff
|
|
TEST_AUIPC(auipc, x12, -0x1001000, 0xfefff, x2, 32, x3)
|
|
|
|
inst_9:
|
|
// rd==x0, imm_val == 1046527,
|
|
// opcode: auipc ; dest:x0; immval:0xff7ff
|
|
TEST_AUIPC(auipc, x0, 0, 0xff7ff, x2, 36, x3)
|
|
|
|
inst_10:
|
|
// rd==x8, imm_val == 1047551,
|
|
// opcode: auipc ; dest:x8; immval:0xffbff
|
|
TEST_AUIPC(auipc, x8, -0x401000, 0xffbff, x2, 40, x3)
|
|
|
|
inst_11:
|
|
// rd==x4, imm_val == 1048063,
|
|
// opcode: auipc ; dest:x4; immval:0xffdff
|
|
TEST_AUIPC(auipc, x4, -0x201000, 0xffdff, x2, 44, x3)
|
|
|
|
inst_12:
|
|
// rd==x13, imm_val == 1048319,
|
|
// opcode: auipc ; dest:x13; immval:0xffeff
|
|
TEST_AUIPC(auipc, x13, -0x101000, 0xffeff, x2, 48, x4)
|
|
RVTEST_SIGBASE( x1,signature_x1_0)
|
|
|
|
inst_13:
|
|
// rd==x3, imm_val == 1048447,
|
|
// opcode: auipc ; dest:x3; immval:0xfff7f
|
|
TEST_AUIPC(auipc, x3, -0x81000, 0xfff7f, x1, 0, x4)
|
|
|
|
inst_14:
|
|
// rd==x11, imm_val == 1048511,
|
|
// opcode: auipc ; dest:x11; immval:0xfffbf
|
|
TEST_AUIPC(auipc, x11, -0x41000, 0xfffbf, x1, 4, x4)
|
|
|
|
inst_15:
|
|
// rd==x2, imm_val == 1048543,
|
|
// opcode: auipc ; dest:x2; immval:0xfffdf
|
|
TEST_AUIPC(auipc, x2, -0x21000, 0xfffdf, x1, 8, x4)
|
|
|
|
inst_16:
|
|
// imm_val == 1048559,
|
|
// opcode: auipc ; dest:x10; immval:0xfffef
|
|
TEST_AUIPC(auipc, x10, -0x11000, 0xfffef, x1, 12, x4)
|
|
|
|
inst_17:
|
|
// imm_val == 1048567,
|
|
// opcode: auipc ; dest:x10; immval:0xffff7
|
|
TEST_AUIPC(auipc, x10, -0x9000, 0xffff7, x1, 16, x4)
|
|
|
|
inst_18:
|
|
// imm_val == 1048571,
|
|
// opcode: auipc ; dest:x10; immval:0xffffb
|
|
TEST_AUIPC(auipc, x10, -0x5000, 0xffffb, x1, 20, x4)
|
|
|
|
inst_19:
|
|
// imm_val == 1048573,
|
|
// opcode: auipc ; dest:x10; immval:0xffffd
|
|
TEST_AUIPC(auipc, x10, -0x3000, 0xffffd, x1, 24, x4)
|
|
|
|
inst_20:
|
|
// imm_val == 1048574,
|
|
// opcode: auipc ; dest:x10; immval:0xffffe
|
|
TEST_AUIPC(auipc, x10, -0x2000, 0xffffe, x1, 28, x4)
|
|
|
|
inst_21:
|
|
// imm_val == 524288,
|
|
// opcode: auipc ; dest:x10; immval:0x80000
|
|
TEST_AUIPC(auipc, x10, -0x80000000, 0x80000, x1, 32, x4)
|
|
|
|
inst_22:
|
|
// imm_val == 262144,
|
|
// opcode: auipc ; dest:x10; immval:0x40000
|
|
TEST_AUIPC(auipc, x10, 0x40000000, 0x40000, x1, 36, x4)
|
|
|
|
inst_23:
|
|
// imm_val == 131072,
|
|
// opcode: auipc ; dest:x10; immval:0x20000
|
|
TEST_AUIPC(auipc, x10, 0x20000000, 0x20000, x1, 40, x4)
|
|
|
|
inst_24:
|
|
// imm_val == 65536,
|
|
// opcode: auipc ; dest:x10; immval:0x10000
|
|
TEST_AUIPC(auipc, x10, 0x10000000, 0x10000, x1, 44, x4)
|
|
|
|
inst_25:
|
|
// imm_val == 32768,
|
|
// opcode: auipc ; dest:x10; immval:0x8000
|
|
TEST_AUIPC(auipc, x10, 0x8000000, 0x8000, x1, 48, x4)
|
|
|
|
inst_26:
|
|
// imm_val == 16384,
|
|
// opcode: auipc ; dest:x10; immval:0x4000
|
|
TEST_AUIPC(auipc, x10, 0x4000000, 0x4000, x1, 52, x4)
|
|
|
|
inst_27:
|
|
// imm_val == 8192,
|
|
// opcode: auipc ; dest:x10; immval:0x2000
|
|
TEST_AUIPC(auipc, x10, 0x2000000, 0x2000, x1, 56, x4)
|
|
|
|
inst_28:
|
|
// imm_val == 4096,
|
|
// opcode: auipc ; dest:x10; immval:0x1000
|
|
TEST_AUIPC(auipc, x10, 0x1000000, 0x1000, x1, 60, x4)
|
|
|
|
inst_29:
|
|
// imm_val == 2048,
|
|
// opcode: auipc ; dest:x10; immval:0x800
|
|
TEST_AUIPC(auipc, x10, 0x800000, 0x800, x1, 64, x4)
|
|
|
|
inst_30:
|
|
// imm_val == 1024, imm_val==1024
|
|
// opcode: auipc ; dest:x10; immval:0x400
|
|
TEST_AUIPC(auipc, x10, 0x400000, 0x400, x1, 68, x4)
|
|
|
|
inst_31:
|
|
// imm_val == 512,
|
|
// opcode: auipc ; dest:x10; immval:0x200
|
|
TEST_AUIPC(auipc, x10, 0x200000, 0x200, x1, 72, x4)
|
|
|
|
inst_32:
|
|
// imm_val == 256,
|
|
// opcode: auipc ; dest:x10; immval:0x100
|
|
TEST_AUIPC(auipc, x10, 0x100000, 0x100, x1, 76, x4)
|
|
|
|
inst_33:
|
|
// imm_val == 128,
|
|
// opcode: auipc ; dest:x10; immval:0x80
|
|
TEST_AUIPC(auipc, x10, 0x80000, 0x80, x1, 80, x4)
|
|
|
|
inst_34:
|
|
// imm_val == 64,
|
|
// opcode: auipc ; dest:x10; immval:0x40
|
|
TEST_AUIPC(auipc, x10, 0x40000, 0x40, x1, 84, x4)
|
|
|
|
inst_35:
|
|
// imm_val == 32,
|
|
// opcode: auipc ; dest:x10; immval:0x20
|
|
TEST_AUIPC(auipc, x10, 0x20000, 0x20, x1, 88, x4)
|
|
|
|
inst_36:
|
|
// imm_val == 16,
|
|
// opcode: auipc ; dest:x10; immval:0x10
|
|
TEST_AUIPC(auipc, x10, 0x10000, 0x10, x1, 92, x4)
|
|
|
|
inst_37:
|
|
// imm_val==349525, imm_val == 349525
|
|
// opcode: auipc ; dest:x10; immval:0x55555
|
|
TEST_AUIPC(auipc, x10, 0x55555000, 0x55555, x1, 96, x4)
|
|
|
|
inst_38:
|
|
// imm_val==3,
|
|
// opcode: auipc ; dest:x10; immval:0x3
|
|
TEST_AUIPC(auipc, x10, 0x3000, 0x3, x1, 100, x4)
|
|
|
|
inst_39:
|
|
// imm_val == 699050, imm_val==699050
|
|
// opcode: auipc ; dest:x10; immval:0xaaaaa
|
|
TEST_AUIPC(auipc, x10, -0x55556000, 0xaaaaa, x1, 104, x4)
|
|
|
|
inst_40:
|
|
// imm_val == 0, imm_val==0
|
|
// opcode: auipc ; dest:x10; immval:0x0
|
|
TEST_AUIPC(auipc, x10, 0x0, 0x0, x1, 108, x4)
|
|
|
|
inst_41:
|
|
// imm_val == 8,
|
|
// opcode: auipc ; dest:x10; immval:0x8
|
|
TEST_AUIPC(auipc, x10, 0x8000, 0x8, x1, 112, x4)
|
|
|
|
inst_42:
|
|
// imm_val == 4, imm_val==4
|
|
// opcode: auipc ; dest:x10; immval:0x4
|
|
TEST_AUIPC(auipc, x10, 0x4000, 0x4, x1, 116, x4)
|
|
|
|
inst_43:
|
|
// imm_val == 2, imm_val==2
|
|
// opcode: auipc ; dest:x10; immval:0x2
|
|
TEST_AUIPC(auipc, x10, 0x2000, 0x2, x1, 120, x4)
|
|
|
|
inst_44:
|
|
// imm_val == 1, imm_val==1
|
|
// opcode: auipc ; dest:x10; immval:0x1
|
|
TEST_AUIPC(auipc, x10, 0x1000, 0x1, x1, 124, x4)
|
|
|
|
inst_45:
|
|
// imm_val==725,
|
|
// opcode: auipc ; dest:x10; immval:0x2d5
|
|
TEST_AUIPC(auipc, x10, 0x2d5000, 0x2d5, x1, 128, x4)
|
|
|
|
inst_46:
|
|
// imm_val==419431,
|
|
// opcode: auipc ; dest:x10; immval:0x66667
|
|
TEST_AUIPC(auipc, x10, 0x66667000, 0x66667, x1, 132, x4)
|
|
|
|
inst_47:
|
|
// imm_val==209716,
|
|
// opcode: auipc ; dest:x10; immval:0x33334
|
|
TEST_AUIPC(auipc, x10, 0x33334000, 0x33334, x1, 136, x4)
|
|
|
|
inst_48:
|
|
// imm_val==6,
|
|
// opcode: auipc ; dest:x10; immval:0x6
|
|
TEST_AUIPC(auipc, x10, 0x6000, 0x6, x1, 140, x4)
|
|
|
|
inst_49:
|
|
// imm_val==699051,
|
|
// opcode: auipc ; dest:x10; immval:0xaaaab
|
|
TEST_AUIPC(auipc, x10, -0x55555000, 0xaaaab, x1, 144, x4)
|
|
|
|
inst_50:
|
|
// imm_val==349526,
|
|
// opcode: auipc ; dest:x10; immval:0x55556
|
|
TEST_AUIPC(auipc, x10, 0x55556000, 0x55556, x1, 148, x4)
|
|
|
|
inst_51:
|
|
// imm_val==1022,
|
|
// opcode: auipc ; dest:x10; immval:0x3fe
|
|
TEST_AUIPC(auipc, x10, 0x3fe000, 0x3fe, x1, 152, x4)
|
|
|
|
inst_52:
|
|
// imm_val==723,
|
|
// opcode: auipc ; dest:x10; immval:0x2d3
|
|
TEST_AUIPC(auipc, x10, 0x2d3000, 0x2d3, x1, 156, x4)
|
|
|
|
inst_53:
|
|
// imm_val==419429,
|
|
// opcode: auipc ; dest:x10; immval:0x66665
|
|
TEST_AUIPC(auipc, x10, 0x66665000, 0x66665, x1, 160, x4)
|
|
|
|
inst_54:
|
|
// imm_val==209714,
|
|
// opcode: auipc ; dest:x10; immval:0x33332
|
|
TEST_AUIPC(auipc, x10, 0x33332000, 0x33332, x1, 164, x4)
|
|
|
|
inst_55:
|
|
// imm_val==699049,
|
|
// opcode: auipc ; dest:x10; immval:0xaaaa9
|
|
TEST_AUIPC(auipc, x10, -0x55557000, 0xaaaa9, x1, 168, x4)
|
|
|
|
inst_56:
|
|
// imm_val==349524,
|
|
// opcode: auipc ; dest:x10; immval:0x55554
|
|
TEST_AUIPC(auipc, x10, 0x55554000, 0x55554, x1, 172, x4)
|
|
|
|
inst_57:
|
|
// imm_val==1023,
|
|
// opcode: auipc ; dest:x10; immval:0x3ff
|
|
TEST_AUIPC(auipc, x10, 0x3ff000, 0x3ff, x1, 176, x4)
|
|
|
|
inst_58:
|
|
// imm_val==724,
|
|
// opcode: auipc ; dest:x10; immval:0x2d4
|
|
TEST_AUIPC(auipc, x10, 0x2d4000, 0x2d4, x1, 180, x4)
|
|
|
|
inst_59:
|
|
// imm_val==419430,
|
|
// opcode: auipc ; dest:x10; immval:0x66666
|
|
TEST_AUIPC(auipc, x10, 0x66666000, 0x66666, x1, 184, x4)
|
|
|
|
inst_60:
|
|
// imm_val==209715,
|
|
// opcode: auipc ; dest:x10; immval:0x33333
|
|
TEST_AUIPC(auipc, x10, 0x33333000, 0x33333, x1, 188, x4)
|
|
|
|
inst_61:
|
|
// imm_val==5,
|
|
// opcode: auipc ; dest:x10; immval:0x5
|
|
TEST_AUIPC(auipc, x10, 0x5000, 0x5, x1, 192, x4)
|
|
|
|
inst_62:
|
|
// imm_val == 1046527,
|
|
// opcode: auipc ; dest:x10; immval:0xff7ff
|
|
TEST_AUIPC(auipc, x10, -0x801000, 0xff7ff, x1, 196, x4)
|
|
#endif
|
|
|
|
|
|
RVTEST_CODE_END
|
|
RVMODEL_HALT
|
|
|
|
RVTEST_DATA_BEGIN
|
|
.align 4
|
|
rvtest_data:
|
|
.word 0xbabecafe
|
|
RVTEST_DATA_END
|
|
|
|
RVMODEL_DATA_BEGIN
|
|
|
|
|
|
signature_x2_0:
|
|
.fill 0*(XLEN/32),4,0xdeadbeef
|
|
|
|
|
|
signature_x2_1:
|
|
.fill 13*(XLEN/32),4,0xdeadbeef
|
|
|
|
|
|
signature_x1_0:
|
|
.fill 50*(XLEN/32),4,0xdeadbeef
|
|
|
|
#ifdef rvtest_mtrap_routine
|
|
|
|
mtrap_sigptr:
|
|
.fill 64*(XLEN/32),4,0xdeadbeef
|
|
|
|
#endif
|
|
|
|
#ifdef rvtest_gpr_save
|
|
|
|
gpr_save:
|
|
.fill 32*(XLEN/32),4,0xdeadbeef
|
|
|
|
#endif
|
|
|
|
RVMODEL_DATA_END
|