[Builtin] Implement lit-test support (part 1 of 2: test cases update)
Original r297566 is splitted into two parts.
This is part one, which adds "RUN" command for test cases.
Unit/arm/call_apsr.S is updated to support thumb1.
It also fixes a bug in arm/aeabi_uldivmod_test.c
gcc_personality_test is XFAILED as the framework cannot handle it so far.
cpu_model_test is also XFAILED for now as it is expected to return non-zero.
TODO: A few tests are XFAILed for armhf and aarch64.
We need further investigating. [1,2] Tracks the issue.
[1] https://bugs.llvm.org//show_bug.cgi?id=32260
[2] https://bugs.llvm.org//show_bug.cgi?id=32261
Reviewers: rengolin, compnerd, jroelofs, erik.pilkington, arphaman
Reviewed By: jroelofs
Subscribers: jroelofs, aemerson, srhines, nemanjai, llvm-commits, mgorny
Differential Revision: https://reviews.llvm.org/D30802
llvm-svn: 298339
2017-03-21 13:32:51 +08:00
|
|
|
// RUN: %clang_builtins %s %librt -o %t && %run %t
|
[compiler-rt][aarch64] New tests for 128-bit floating-point builtins, fixes of tests and __fixuint
Summary:
The following tests for 128-bit floating-point type behaved in a strange way, thought it were bugs, but seem to be mistakes in tests:
* `fixtfsi` test checked for `0x80000001` as a value returned for number less than can be represented, while `LONG_MIN` should be returned on saturation;
* `fixunstfdi` wasn't enabled for AArch64, only for PPC, but there is nothing PPC specific in that test;
* `multf3` tried to underflow multiplication by producing result with 16383 exponent, while there are still 112 bits of fraction plus implicit bit, so resultant exponent should be 16497.
Tests for some other builtins didn't exist:
* `fixtfdi`
* `fixtfti`
* `fixunstfti`
They were made by copying similar files and adjusting for wider types and adding/removing some reasonable/extra checks.
Also `__fixuint` seems to have off by one error, updated tests to catch this case.
Reviewers: rengolin, zatrazz, howard.hinnant, t.p.northover, jmolloy, enefaim
Subscribers: aemerson, llvm-commits, rengolin
Differential Revision: http://reviews.llvm.org/D14187
llvm-svn: 252180
2015-11-06 02:36:42 +08:00
|
|
|
//===--------------- fixtfdi_test.c - Test __fixtfdi ----------------------===//
|
|
|
|
//
|
2019-01-19 18:56:40 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
[compiler-rt][aarch64] New tests for 128-bit floating-point builtins, fixes of tests and __fixuint
Summary:
The following tests for 128-bit floating-point type behaved in a strange way, thought it were bugs, but seem to be mistakes in tests:
* `fixtfsi` test checked for `0x80000001` as a value returned for number less than can be represented, while `LONG_MIN` should be returned on saturation;
* `fixunstfdi` wasn't enabled for AArch64, only for PPC, but there is nothing PPC specific in that test;
* `multf3` tried to underflow multiplication by producing result with 16383 exponent, while there are still 112 bits of fraction plus implicit bit, so resultant exponent should be 16497.
Tests for some other builtins didn't exist:
* `fixtfdi`
* `fixtfti`
* `fixunstfti`
They were made by copying similar files and adjusting for wider types and adding/removing some reasonable/extra checks.
Also `__fixuint` seems to have off by one error, updated tests to catch this case.
Reviewers: rengolin, zatrazz, howard.hinnant, t.p.northover, jmolloy, enefaim
Subscribers: aemerson, llvm-commits, rengolin
Differential Revision: http://reviews.llvm.org/D14187
llvm-svn: 252180
2015-11-06 02:36:42 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file tests __fixtfdi for the compiler_rt library.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "int_lib.h"
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#if __LDBL_MANT_DIG__ == 113
|
|
|
|
|
|
|
|
#include "fp_test.h"
|
|
|
|
|
|
|
|
di_int __fixtfdi(long double a);
|
|
|
|
|
|
|
|
int test__fixtfdi(long double a, di_int expected)
|
|
|
|
{
|
|
|
|
di_int x = __fixtfdi(a);
|
|
|
|
int ret = (x != expected);
|
|
|
|
|
|
|
|
if (ret)
|
|
|
|
{
|
|
|
|
printf("error in test__fixtfdi(%.20Lf) = %llX, "
|
|
|
|
"expected %llX\n", a, x, expected);
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
char assumption_1[sizeof(long double) * CHAR_BIT == 128] = {0};
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
#if __LDBL_MANT_DIG__ == 113
|
|
|
|
if (test__fixtfdi(makeInf128(), 0x7fffffffffffffffLL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(0, 0x0))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(0x1.23456789abcdefp+5L, 0x24LL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(0x1.23456789abcdefp-3L, 0x0LL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(0x1.23456789abcdef12345678p+20L, 0x123456LL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(0x1.23456789abcdef12345678p+40L, 0x123456789abLL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(0x1.23456789abcdef12345678p+60L, 0x123456789abcdef1LL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(0x1.23456789abcdefp+256L, 0x7fffffffffffffffLL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(-0x1.23456789abcdefp+20L, 0xffffffffffedcbaaLL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(-0x1.23456789abcdefp+40L, 0xfffffedcba987655LL))
|
|
|
|
return 1;
|
|
|
|
if (test__fixtfdi(-0x1.23456789abcdefp+256L, 0x8000000000000000LL))
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
#else
|
|
|
|
printf("skipped\n");
|
|
|
|
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|