forked from Github_Repos/cvw
392 lines
9.5 KiB
ArmAsm
392 lines
9.5 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 lui instruction of the RISC-V E extension for the lui 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;",lui)
|
|
|
|
RVTEST_SIGBASE( x4,signature_x4_1)
|
|
|
|
inst_0:
|
|
// rd==x3, imm_val == ((2**20)-1), imm_val > 0
|
|
// opcode: lui ; dest:x3; immval:0xfffff
|
|
TEST_CASE(x5, x3, -0x1000, x4, 0, lui x3,0xfffff)
|
|
|
|
inst_1:
|
|
// rd==x2, imm_val == 524287,
|
|
// opcode: lui ; dest:x2; immval:0x7ffff
|
|
TEST_CASE(x5, x2, 0x7ffff000, x4, 4, lui x2,0x7ffff)
|
|
|
|
inst_2:
|
|
// rd==x1, imm_val == 786431,
|
|
// opcode: lui ; dest:x1; immval:0xbffff
|
|
TEST_CASE(x5, x1, -0x40001000, x4, 8, lui x1,0xbffff)
|
|
|
|
inst_3:
|
|
// rd==x8, imm_val == 917503,
|
|
// opcode: lui ; dest:x8; immval:0xdffff
|
|
TEST_CASE(x5, x8, -0x20001000, x4, 12, lui x8,0xdffff)
|
|
|
|
inst_4:
|
|
// rd==x14, imm_val == 983039,
|
|
// opcode: lui ; dest:x14; immval:0xeffff
|
|
TEST_CASE(x5, x14, -0x10001000, x4, 16, lui x14,0xeffff)
|
|
|
|
inst_5:
|
|
// rd==x7, imm_val == 1015807,
|
|
// opcode: lui ; dest:x7; immval:0xf7fff
|
|
TEST_CASE(x5, x7, -0x8001000, x4, 20, lui x7,0xf7fff)
|
|
|
|
inst_6:
|
|
// rd==x13, imm_val == 1032191,
|
|
// opcode: lui ; dest:x13; immval:0xfbfff
|
|
TEST_CASE(x5, x13, -0x4001000, x4, 24, lui x13,0xfbfff)
|
|
|
|
inst_7:
|
|
// rd==x12, imm_val == 1040383,
|
|
// opcode: lui ; dest:x12; immval:0xfdfff
|
|
TEST_CASE(x5, x12, -0x2001000, x4, 28, lui x12,0xfdfff)
|
|
|
|
inst_8:
|
|
// rd==x15, imm_val == 1044479,
|
|
// opcode: lui ; dest:x15; immval:0xfefff
|
|
TEST_CASE(x5, x15, -0x1001000, x4, 32, lui x15,0xfefff)
|
|
|
|
inst_9:
|
|
// rd==x10, imm_val == 1046527,
|
|
// opcode: lui ; dest:x10; immval:0xff7ff
|
|
TEST_CASE(x5, x10, -0x801000, x4, 36, lui x10,0xff7ff)
|
|
|
|
inst_10:
|
|
// rd==x6, imm_val == 1047551,
|
|
// opcode: lui ; dest:x6; immval:0xffbff
|
|
TEST_CASE(x5, x6, -0x401000, x4, 40, lui x6,0xffbff)
|
|
|
|
inst_11:
|
|
// rd==x9, imm_val == 1048063,
|
|
// opcode: lui ; dest:x9; immval:0xffdff
|
|
TEST_CASE(x2, x9, -0x201000, x4, 44, lui x9,0xffdff)
|
|
RVTEST_SIGBASE( x1,signature_x1_0)
|
|
|
|
inst_12:
|
|
// rd==x4, imm_val == 1048319,
|
|
// opcode: lui ; dest:x4; immval:0xffeff
|
|
TEST_CASE(x2, x4, -0x101000, x1, 0, lui x4,0xffeff)
|
|
|
|
inst_13:
|
|
// rd==x0, imm_val == 1048447,
|
|
// opcode: lui ; dest:x0; immval:0xfff7f
|
|
TEST_CASE(x2, x0, 0, x1, 4, lui x0,0xfff7f)
|
|
|
|
inst_14:
|
|
// rd==x5, imm_val == 1048511,
|
|
// opcode: lui ; dest:x5; immval:0xfffbf
|
|
TEST_CASE(x2, x5, -0x41000, x1, 8, lui x5,0xfffbf)
|
|
|
|
inst_15:
|
|
// rd==x11, imm_val == 1048543,
|
|
// opcode: lui ; dest:x11; immval:0xfffdf
|
|
TEST_CASE(x2, x11, -0x21000, x1, 12, lui x11,0xfffdf)
|
|
|
|
inst_16:
|
|
// imm_val == 1048559,
|
|
// opcode: lui ; dest:x10; immval:0xfffef
|
|
TEST_CASE(x2, x10, -0x11000, x1, 16, lui x10,0xfffef)
|
|
|
|
inst_17:
|
|
// imm_val == 1048567,
|
|
// opcode: lui ; dest:x10; immval:0xffff7
|
|
TEST_CASE(x2, x10, -0x9000, x1, 20, lui x10,0xffff7)
|
|
|
|
inst_18:
|
|
// imm_val == 1048571,
|
|
// opcode: lui ; dest:x10; immval:0xffffb
|
|
TEST_CASE(x2, x10, -0x5000, x1, 24, lui x10,0xffffb)
|
|
|
|
inst_19:
|
|
// imm_val == 1048573,
|
|
// opcode: lui ; dest:x10; immval:0xffffd
|
|
TEST_CASE(x2, x10, -0x3000, x1, 28, lui x10,0xffffd)
|
|
|
|
inst_20:
|
|
// imm_val == 1048574,
|
|
// opcode: lui ; dest:x10; immval:0xffffe
|
|
TEST_CASE(x2, x10, -0x2000, x1, 32, lui x10,0xffffe)
|
|
|
|
inst_21:
|
|
// imm_val == 524288,
|
|
// opcode: lui ; dest:x10; immval:0x80000
|
|
TEST_CASE(x2, x10, -0x80000000, x1, 36, lui x10,0x80000)
|
|
|
|
inst_22:
|
|
// imm_val == 262144,
|
|
// opcode: lui ; dest:x10; immval:0x40000
|
|
TEST_CASE(x2, x10, 0x40000000, x1, 40, lui x10,0x40000)
|
|
|
|
inst_23:
|
|
// imm_val == 131072,
|
|
// opcode: lui ; dest:x10; immval:0x20000
|
|
TEST_CASE(x2, x10, 0x20000000, x1, 44, lui x10,0x20000)
|
|
|
|
inst_24:
|
|
// imm_val == 65536,
|
|
// opcode: lui ; dest:x10; immval:0x10000
|
|
TEST_CASE(x2, x10, 0x10000000, x1, 48, lui x10,0x10000)
|
|
|
|
inst_25:
|
|
// imm_val == 32768,
|
|
// opcode: lui ; dest:x10; immval:0x8000
|
|
TEST_CASE(x2, x10, 0x8000000, x1, 52, lui x10,0x8000)
|
|
|
|
inst_26:
|
|
// imm_val == 16384,
|
|
// opcode: lui ; dest:x10; immval:0x4000
|
|
TEST_CASE(x2, x10, 0x4000000, x1, 56, lui x10,0x4000)
|
|
|
|
inst_27:
|
|
// imm_val == 8192,
|
|
// opcode: lui ; dest:x10; immval:0x2000
|
|
TEST_CASE(x2, x10, 0x2000000, x1, 60, lui x10,0x2000)
|
|
|
|
inst_28:
|
|
// imm_val == 4096,
|
|
// opcode: lui ; dest:x10; immval:0x1000
|
|
TEST_CASE(x2, x10, 0x1000000, x1, 64, lui x10,0x1000)
|
|
|
|
inst_29:
|
|
// imm_val == 2048,
|
|
// opcode: lui ; dest:x10; immval:0x800
|
|
TEST_CASE(x2, x10, 0x800000, x1, 68, lui x10,0x800)
|
|
|
|
inst_30:
|
|
// imm_val == 1024, imm_val==1024
|
|
// opcode: lui ; dest:x10; immval:0x400
|
|
TEST_CASE(x2, x10, 0x400000, x1, 72, lui x10,0x400)
|
|
|
|
inst_31:
|
|
// imm_val == 512,
|
|
// opcode: lui ; dest:x10; immval:0x200
|
|
TEST_CASE(x2, x10, 0x200000, x1, 76, lui x10,0x200)
|
|
|
|
inst_32:
|
|
// imm_val == 256,
|
|
// opcode: lui ; dest:x10; immval:0x100
|
|
TEST_CASE(x2, x10, 0x100000, x1, 80, lui x10,0x100)
|
|
|
|
inst_33:
|
|
// imm_val == 128,
|
|
// opcode: lui ; dest:x10; immval:0x80
|
|
TEST_CASE(x2, x10, 0x80000, x1, 84, lui x10,0x80)
|
|
|
|
inst_34:
|
|
// imm_val == 64,
|
|
// opcode: lui ; dest:x10; immval:0x40
|
|
TEST_CASE(x2, x10, 0x40000, x1, 88, lui x10,0x40)
|
|
|
|
inst_35:
|
|
// imm_val == 32,
|
|
// opcode: lui ; dest:x10; immval:0x20
|
|
TEST_CASE(x2, x10, 0x20000, x1, 92, lui x10,0x20)
|
|
|
|
inst_36:
|
|
// imm_val == 16,
|
|
// opcode: lui ; dest:x10; immval:0x10
|
|
TEST_CASE(x2, x10, 0x10000, x1, 96, lui x10,0x10)
|
|
|
|
inst_37:
|
|
// imm_val==349525, imm_val == 349525
|
|
// opcode: lui ; dest:x10; immval:0x55555
|
|
TEST_CASE(x2, x10, 0x55555000, x1, 100, lui x10,0x55555)
|
|
|
|
inst_38:
|
|
// imm_val==3,
|
|
// opcode: lui ; dest:x10; immval:0x3
|
|
TEST_CASE(x2, x10, 0x3000, x1, 104, lui x10,0x3)
|
|
|
|
inst_39:
|
|
// imm_val == 699050, imm_val==699050
|
|
// opcode: lui ; dest:x10; immval:0xaaaaa
|
|
TEST_CASE(x2, x10, -0x55556000, x1, 108, lui x10,0xaaaaa)
|
|
|
|
inst_40:
|
|
// imm_val == 0, imm_val==0
|
|
// opcode: lui ; dest:x10; immval:0x0
|
|
TEST_CASE(x2, x10, 0x0, x1, 112, lui x10,0x0)
|
|
|
|
inst_41:
|
|
// imm_val == 8,
|
|
// opcode: lui ; dest:x10; immval:0x8
|
|
TEST_CASE(x2, x10, 0x8000, x1, 116, lui x10,0x8)
|
|
|
|
inst_42:
|
|
// imm_val == 4, imm_val==4
|
|
// opcode: lui ; dest:x10; immval:0x4
|
|
TEST_CASE(x2, x10, 0x4000, x1, 120, lui x10,0x4)
|
|
|
|
inst_43:
|
|
// imm_val == 2, imm_val==2
|
|
// opcode: lui ; dest:x10; immval:0x2
|
|
TEST_CASE(x2, x10, 0x2000, x1, 124, lui x10,0x2)
|
|
|
|
inst_44:
|
|
// imm_val == 1, imm_val==1
|
|
// opcode: lui ; dest:x10; immval:0x1
|
|
TEST_CASE(x2, x10, 0x1000, x1, 128, lui x10,0x1)
|
|
|
|
inst_45:
|
|
// imm_val==725,
|
|
// opcode: lui ; dest:x10; immval:0x2d5
|
|
TEST_CASE(x2, x10, 0x2d5000, x1, 132, lui x10,0x2d5)
|
|
|
|
inst_46:
|
|
// imm_val==419431,
|
|
// opcode: lui ; dest:x10; immval:0x66667
|
|
TEST_CASE(x2, x10, 0x66667000, x1, 136, lui x10,0x66667)
|
|
|
|
inst_47:
|
|
// imm_val==209716,
|
|
// opcode: lui ; dest:x10; immval:0x33334
|
|
TEST_CASE(x2, x10, 0x33334000, x1, 140, lui x10,0x33334)
|
|
|
|
inst_48:
|
|
// imm_val==6,
|
|
// opcode: lui ; dest:x10; immval:0x6
|
|
TEST_CASE(x2, x10, 0x6000, x1, 144, lui x10,0x6)
|
|
|
|
inst_49:
|
|
// imm_val==699051,
|
|
// opcode: lui ; dest:x10; immval:0xaaaab
|
|
TEST_CASE(x2, x10, -0x55555000, x1, 148, lui x10,0xaaaab)
|
|
|
|
inst_50:
|
|
// imm_val==349526,
|
|
// opcode: lui ; dest:x10; immval:0x55556
|
|
TEST_CASE(x2, x10, 0x55556000, x1, 152, lui x10,0x55556)
|
|
|
|
inst_51:
|
|
// imm_val==1022,
|
|
// opcode: lui ; dest:x10; immval:0x3fe
|
|
TEST_CASE(x2, x10, 0x3fe000, x1, 156, lui x10,0x3fe)
|
|
|
|
inst_52:
|
|
// imm_val==723,
|
|
// opcode: lui ; dest:x10; immval:0x2d3
|
|
TEST_CASE(x2, x10, 0x2d3000, x1, 160, lui x10,0x2d3)
|
|
|
|
inst_53:
|
|
// imm_val==419429,
|
|
// opcode: lui ; dest:x10; immval:0x66665
|
|
TEST_CASE(x2, x10, 0x66665000, x1, 164, lui x10,0x66665)
|
|
|
|
inst_54:
|
|
// imm_val==209714,
|
|
// opcode: lui ; dest:x10; immval:0x33332
|
|
TEST_CASE(x2, x10, 0x33332000, x1, 168, lui x10,0x33332)
|
|
|
|
inst_55:
|
|
// imm_val==699049,
|
|
// opcode: lui ; dest:x10; immval:0xaaaa9
|
|
TEST_CASE(x2, x10, -0x55557000, x1, 172, lui x10,0xaaaa9)
|
|
|
|
inst_56:
|
|
// imm_val==349524,
|
|
// opcode: lui ; dest:x10; immval:0x55554
|
|
TEST_CASE(x2, x10, 0x55554000, x1, 176, lui x10,0x55554)
|
|
|
|
inst_57:
|
|
// imm_val==1023,
|
|
// opcode: lui ; dest:x10; immval:0x3ff
|
|
TEST_CASE(x2, x10, 0x3ff000, x1, 180, lui x10,0x3ff)
|
|
|
|
inst_58:
|
|
// imm_val==724,
|
|
// opcode: lui ; dest:x10; immval:0x2d4
|
|
TEST_CASE(x2, x10, 0x2d4000, x1, 184, lui x10,0x2d4)
|
|
|
|
inst_59:
|
|
// imm_val==419430,
|
|
// opcode: lui ; dest:x10; immval:0x66666
|
|
TEST_CASE(x2, x10, 0x66666000, x1, 188, lui x10,0x66666)
|
|
|
|
inst_60:
|
|
// imm_val==209715,
|
|
// opcode: lui ; dest:x10; immval:0x33333
|
|
TEST_CASE(x2, x10, 0x33333000, x1, 192, lui x10,0x33333)
|
|
|
|
inst_61:
|
|
// imm_val==5,
|
|
// opcode: lui ; dest:x10; immval:0x5
|
|
TEST_CASE(x2, x10, 0x5000, x1, 196, lui x10,0x5)
|
|
|
|
inst_62:
|
|
// imm_val == 1048447,
|
|
// opcode: lui ; dest:x10; immval:0xfff7f
|
|
TEST_CASE(x2, x10, -0x81000, x1, 200, lui x10,0xfff7f)
|
|
#endif
|
|
|
|
|
|
RVTEST_CODE_END
|
|
RVMODEL_HALT
|
|
|
|
RVTEST_DATA_BEGIN
|
|
.align 4
|
|
rvtest_data:
|
|
.word 0xbabecafe
|
|
RVTEST_DATA_END
|
|
|
|
RVMODEL_DATA_BEGIN
|
|
|
|
|
|
signature_x4_0:
|
|
.fill 0*(XLEN/32),4,0xdeadbeef
|
|
|
|
|
|
signature_x4_1:
|
|
.fill 12*(XLEN/32),4,0xdeadbeef
|
|
|
|
|
|
signature_x1_0:
|
|
.fill 51*(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
|