2016-04-10 10:54:35 -04:00
|
|
|
# See LICENSE for license details.
|
|
|
|
|
|
|
|
#*****************************************************************************
|
|
|
|
# div.S
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# Test div instruction.
|
|
|
|
#
|
|
|
|
|
|
|
|
#include "riscv_test.h"
|
|
|
|
#include "test_macros.h"
|
|
|
|
|
|
|
|
RVTEST_RV32U
|
|
|
|
RVTEST_CODE_BEGIN
|
|
|
|
|
|
|
|
#-------------------------------------------------------------
|
|
|
|
# Arithmetic tests
|
|
|
|
#-------------------------------------------------------------
|
|
|
|
|
|
|
|
TEST_RR_OP( 2, div, 3, 20, 6 );
|
|
|
|
TEST_RR_OP( 3, div, -3, -20, 6 );
|
|
|
|
TEST_RR_OP( 4, div, -3, 20, -6 );
|
|
|
|
TEST_RR_OP( 5, div, 3, -20, -6 );
|
|
|
|
|
2017-01-13 09:55:02 -05:00
|
|
|
TEST_RR_OP( 6, div, -1<<31, -1<<31, 1 );
|
|
|
|
TEST_RR_OP( 7, div, -1<<31, -1<<31, -1 );
|
2016-04-10 10:54:35 -04:00
|
|
|
|
2017-01-13 09:55:02 -05:00
|
|
|
TEST_RR_OP( 8, div, -1, -1<<31, 0 );
|
2016-04-10 10:54:35 -04:00
|
|
|
TEST_RR_OP( 9, div, -1, 1, 0 );
|
|
|
|
TEST_RR_OP(10, div, -1, 0, 0 );
|
|
|
|
|
|
|
|
TEST_PASSFAIL
|
|
|
|
|
|
|
|
RVTEST_CODE_END
|
|
|
|
|
|
|
|
.data
|
|
|
|
RVTEST_DATA_BEGIN
|
|
|
|
|
|
|
|
TEST_DATA
|
|
|
|
|
|
|
|
RVTEST_DATA_END
|