2015-06-21 09:33:46 -06:00
/*
2024-01-01 14:15:26 -07:00
Copyright ( C ) 1997 - 2024 Sam Lantinga < slouken @ libsdl . org >
2015-06-21 09:33:46 -06:00
This software is provided ' as - is ' , without any express or implied
warranty . In no event will the authors be held liable for any damages
arising from the use of this software .
Permission is granted to anyone to use this software for any purpose ,
including commercial applications , and to alter it and redistribute it
freely .
*/
2022-11-26 21:43:38 -07:00
# include <SDL3/SDL.h>
2022-12-14 21:58:20 -07:00
# include <SDL3/SDL_main.h>
2023-03-16 17:25:39 -06:00
# include <SDL3/SDL_test.h>
2015-06-21 09:33:46 -06:00
/*
* Watcom C flags these as Warning 201 : " Unreachable code " if you just
* compare them directly , so we push it through a function to keep the
* compiler quiet . - - ryan .
*/
static int
badsize ( size_t sizeoftype , size_t hardcodetype )
{
return sizeoftype ! = hardcodetype ;
}
2022-03-17 05:56:50 -06:00
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_SINT8 , SDL_MAX_SINT8 = = 127 ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_SINT8 , SDL_MIN_SINT8 = = - 128 ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_UINT8 , SDL_MAX_UINT8 = = 255 ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_UINT8 , SDL_MIN_UINT8 = = 0 ) ;
2015-06-21 09:33:46 -06:00
2022-03-17 05:56:50 -06:00
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_SINT16 , SDL_MAX_SINT16 = = 32767 ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_SINT16 , SDL_MIN_SINT16 = = - 32768 ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_UINT16 , SDL_MAX_UINT16 = = 65535 ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_UINT16 , SDL_MIN_UINT16 = = 0 ) ;
2017-10-16 15:39:56 -06:00
2022-03-17 05:56:50 -06:00
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_SINT32 , SDL_MAX_SINT32 = = 2147483647 ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_SINT32 , SDL_MIN_SINT32 = = ~ 0x7fffffff ) ; /* Instead of -2147483648, which is treated as unsigned by some compilers */
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_UINT32 , SDL_MAX_UINT32 = = 4294967295u ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_UINT32 , SDL_MIN_UINT32 = = 0 ) ;
2017-10-16 15:39:56 -06:00
2022-03-17 05:56:50 -06:00
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_SINT64 , SDL_MAX_SINT64 = = 9223372036854775807ll ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_SINT64 , SDL_MIN_SINT64 = = ~ 0x7fffffffffffffffll ) ; /* Instead of -9223372036854775808, which is treated as unsigned by compilers */
SDL_COMPILE_TIME_ASSERT ( SDL_MAX_UINT64 , SDL_MAX_UINT64 = = 18446744073709551615ull ) ;
SDL_COMPILE_TIME_ASSERT ( SDL_MIN_UINT64 , SDL_MIN_UINT64 = = 0 ) ;
2017-10-16 15:39:56 -06:00
2023-03-08 08:12:45 -07:00
static int TestTypes ( SDL_bool verbose )
2022-03-17 05:56:50 -06:00
{
int error = 0 ;
2017-10-16 15:39:56 -06:00
2015-06-21 09:33:46 -06:00
if ( badsize ( sizeof ( Uint8 ) , 1 ) ) {
2022-11-27 09:38:43 -07:00
if ( verbose ) {
SDL_Log ( " sizeof(Uint8) != 1, instead = %u \n " , ( unsigned int ) sizeof ( Uint8 ) ) ;
}
2015-06-21 09:33:46 -06:00
+ + error ;
}
if ( badsize ( sizeof ( Uint16 ) , 2 ) ) {
2022-11-27 09:38:43 -07:00
if ( verbose ) {
SDL_Log ( " sizeof(Uint16) != 2, instead = %u \n " , ( unsigned int ) sizeof ( Uint16 ) ) ;
}
2015-06-21 09:33:46 -06:00
+ + error ;
}
if ( badsize ( sizeof ( Uint32 ) , 4 ) ) {
2022-11-27 09:38:43 -07:00
if ( verbose ) {
SDL_Log ( " sizeof(Uint32) != 4, instead = %u \n " , ( unsigned int ) sizeof ( Uint32 ) ) ;
}
2015-06-21 09:33:46 -06:00
+ + error ;
}
if ( badsize ( sizeof ( Uint64 ) , 8 ) ) {
2022-11-27 09:38:43 -07:00
if ( verbose ) {
SDL_Log ( " sizeof(Uint64) != 8, instead = %u \n " , ( unsigned int ) sizeof ( Uint64 ) ) ;
}
2015-06-21 09:33:46 -06:00
+ + error ;
}
2022-11-27 09:38:43 -07:00
if ( verbose & & ! error ) {
2015-06-21 09:33:46 -06:00
SDL_Log ( " All data types are the expected size. \n " ) ;
2022-11-27 09:38:43 -07:00
}
2015-06-21 09:33:46 -06:00
2022-11-27 09:38:43 -07:00
return error ? 1 : 0 ;
2015-06-21 09:33:46 -06:00
}
2023-03-08 08:12:45 -07:00
static int TestEndian ( SDL_bool verbose )
2015-06-21 09:33:46 -06:00
{
int error = 0 ;
Uint16 value = 0x1234 ;
int real_byteorder ;
2022-05-03 16:21:10 -06:00
int real_floatwordorder = 0 ;
2015-06-21 09:33:46 -06:00
Uint16 value16 = 0xCDAB ;
Uint16 swapped16 = 0xABCD ;
Uint32 value32 = 0xEFBEADDE ;
Uint32 swapped32 = 0xDEADBEEF ;
Uint64 value64 , swapped64 ;
2022-11-30 13:51:59 -07:00
union
{
double d ;
Uint32 ui32 [ 2 ] ;
2022-05-03 16:21:10 -06:00
} value_double ;
2015-06-21 09:33:46 -06:00
value64 = 0xEFBEADDE ;
value64 < < = 32 ;
value64 | = 0xCDAB3412 ;
swapped64 = 0x1234ABCD ;
swapped64 < < = 32 ;
swapped64 | = 0xDEADBEEF ;
2022-05-03 16:21:10 -06:00
value_double . d = 3.141593 ;
2015-06-21 09:33:46 -06:00
if ( verbose ) {
SDL_Log ( " Detected a %s endian machine. \n " ,
2022-11-30 13:51:59 -07:00
( SDL_BYTEORDER = = SDL_LIL_ENDIAN ) ? " little " : " big " ) ;
2015-06-21 09:33:46 -06:00
}
2022-11-30 13:51:59 -07:00
if ( ( * ( ( char * ) & value ) > > 4 ) = = 0x1 ) {
2015-06-21 09:33:46 -06:00
real_byteorder = SDL_BIG_ENDIAN ;
} else {
real_byteorder = SDL_LIL_ENDIAN ;
}
if ( real_byteorder ! = SDL_BYTEORDER ) {
if ( verbose ) {
SDL_Log ( " Actually a %s endian machine! \n " ,
2022-11-30 13:51:59 -07:00
( real_byteorder = = SDL_LIL_ENDIAN ) ? " little " : " big " ) ;
2015-06-21 09:33:46 -06:00
}
+ + error ;
}
2022-05-03 16:21:10 -06:00
if ( verbose ) {
SDL_Log ( " Detected a %s endian float word order machine. \n " ,
2022-11-30 13:51:59 -07:00
( SDL_FLOATWORDORDER = = SDL_LIL_ENDIAN ) ? " little " : " big " ) ;
2022-05-03 16:21:10 -06:00
}
if ( value_double . ui32 [ 0 ] = = 0x82c2bd7f & & value_double . ui32 [ 1 ] = = 0x400921fb ) {
real_floatwordorder = SDL_LIL_ENDIAN ;
} else if ( value_double . ui32 [ 0 ] = = 0x400921fb & & value_double . ui32 [ 1 ] = = 0x82c2bd7f ) {
real_floatwordorder = SDL_BIG_ENDIAN ;
}
if ( real_floatwordorder ! = SDL_FLOATWORDORDER ) {
if ( verbose ) {
SDL_Log ( " Actually a %s endian float word order machine! \n " ,
2022-11-30 13:51:59 -07:00
( real_floatwordorder = = SDL_LIL_ENDIAN ) ? " little " : ( real_floatwordorder = = SDL_BIG_ENDIAN ) ? " big "
: " unknown " ) ;
2022-05-03 16:21:10 -06:00
}
+ + error ;
}
2015-06-21 09:33:46 -06:00
if ( verbose ) {
SDL_Log ( " Value 16 = 0x%X, swapped = 0x%X \n " , value16 ,
2022-11-30 13:51:59 -07:00
SDL_Swap16 ( value16 ) ) ;
2015-06-21 09:33:46 -06:00
}
if ( SDL_Swap16 ( value16 ) ! = swapped16 ) {
if ( verbose ) {
SDL_Log ( " 16 bit value swapped incorrectly! \n " ) ;
}
+ + error ;
}
if ( verbose ) {
2022-10-09 23:31:14 -06:00
SDL_Log ( " Value 32 = 0x% " SDL_PRIX32 " , swapped = 0x% " SDL_PRIX32 " \n " ,
value32 ,
SDL_Swap32 ( value32 ) ) ;
2015-06-21 09:33:46 -06:00
}
if ( SDL_Swap32 ( value32 ) ! = swapped32 ) {
if ( verbose ) {
SDL_Log ( " 32 bit value swapped incorrectly! \n " ) ;
}
+ + error ;
}
if ( verbose ) {
2022-11-30 13:51:59 -07:00
SDL_Log ( " Value 64 = 0x% " SDL_PRIX64 " , swapped = 0x% " SDL_PRIX64 " \n " , value64 ,
SDL_Swap64 ( value64 ) ) ;
2015-06-21 09:33:46 -06:00
}
if ( SDL_Swap64 ( value64 ) ! = swapped64 ) {
if ( verbose ) {
SDL_Log ( " 64 bit value swapped incorrectly! \n " ) ;
}
+ + error ;
}
2022-11-27 09:38:43 -07:00
return error ? 1 : 0 ;
2015-06-21 09:33:46 -06:00
}
2022-11-30 13:51:59 -07:00
static int TST_allmul ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( long long * ) result ) = ( ( * ( long long * ) a ) * ( * ( long long * ) b ) ) ;
return ( * ( long long * ) result ) = = ( * ( long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_alldiv ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( long long * ) result ) = ( ( * ( long long * ) a ) / ( * ( long long * ) b ) ) ;
return ( * ( long long * ) result ) = = ( * ( long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_allrem ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( long long * ) result ) = ( ( * ( long long * ) a ) % ( * ( long long * ) b ) ) ;
return ( * ( long long * ) result ) = = ( * ( long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_ualldiv ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( unsigned long long * ) result ) = ( ( * ( unsigned long long * ) a ) / ( * ( unsigned long long * ) b ) ) ;
return ( * ( unsigned long long * ) result ) = = ( * ( unsigned long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_uallrem ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( unsigned long long * ) result ) = ( ( * ( unsigned long long * ) a ) % ( * ( unsigned long long * ) b ) ) ;
return ( * ( unsigned long long * ) result ) = = ( * ( unsigned long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_allshl ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( long long * ) result ) = ( * ( long long * ) a ) < < arg ;
return ( * ( long long * ) result ) = = ( * ( long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_aullshl ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( unsigned long long * ) result ) = ( * ( unsigned long long * ) a ) < < arg ;
return ( * ( unsigned long long * ) result ) = = ( * ( unsigned long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_allshr ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( long long * ) result ) = ( * ( long long * ) a ) > > arg ;
return ( * ( long long * ) result ) = = ( * ( long long * ) expected ) ;
}
2022-11-30 13:51:59 -07:00
static int TST_aullshr ( void * a , void * b , int arg , void * result , void * expected )
2016-11-06 11:01:08 -07:00
{
( * ( unsigned long long * ) result ) = ( * ( unsigned long long * ) a ) > > arg ;
return ( * ( unsigned long long * ) result ) = = ( * ( unsigned long long * ) expected ) ;
}
typedef int ( * LL_Intrinsic ) ( void * a , void * b , int arg , void * result , void * expected ) ;
2022-11-30 13:51:59 -07:00
typedef struct
{
2016-11-06 11:01:08 -07:00
const char * operation ;
LL_Intrinsic routine ;
unsigned long long a , b ;
int arg ;
unsigned long long expected_result ;
} LL_Test ;
2022-11-30 13:51:59 -07:00
static LL_Test LL_Tests [ ] = {
2016-11-06 15:13:28 -07:00
/* UNDEFINED {"_allshl", &TST_allshl, 0xFFFFFFFFFFFFFFFFll, 0ll, 65, 0x0000000000000000ll}, */
2022-11-30 13:51:59 -07:00
{ " _allshl " , & TST_allshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 1 , 0xFFFFFFFFFFFFFFFEll } ,
{ " _allshl " , & TST_allshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 32 , 0xFFFFFFFF00000000ll } ,
{ " _allshl " , & TST_allshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 33 , 0xFFFFFFFE00000000ll } ,
{ " _allshl " , & TST_allshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
2016-11-06 11:01:08 -07:00
2022-11-30 13:51:59 -07:00
{ " _allshr " , & TST_allshr , 0xAAAAAAAA55555555ll , 0ll , 63 , 0xFFFFFFFFFFFFFFFFll } ,
2016-11-06 15:13:28 -07:00
/* UNDEFINED {"_allshr", &TST_allshr, 0xFFFFFFFFFFFFFFFFll, 0ll, 65, 0xFFFFFFFFFFFFFFFFll}, */
2022-11-30 13:51:59 -07:00
{ " _allshr " , & TST_allshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 1 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _allshr " , & TST_allshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 32 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _allshr " , & TST_allshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 33 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _allshr " , & TST_allshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
2016-11-06 15:13:28 -07:00
/* UNDEFINED {"_allshr", &TST_allshr, 0x5F5F5F5F5F5F5F5Fll, 0ll, 65, 0x0000000000000000ll}, */
2022-11-30 13:51:59 -07:00
{ " _allshr " , & TST_allshr , 0x5F5F5F5F5F5F5F5Fll , 0ll , 1 , 0x2FAFAFAFAFAFAFAFll } ,
{ " _allshr " , & TST_allshr , 0x5F5F5F5F5F5F5F5Fll , 0ll , 32 , 0x000000005F5F5F5Fll } ,
{ " _allshr " , & TST_allshr , 0x5F5F5F5F5F5F5F5Fll , 0ll , 33 , 0x000000002FAFAFAFll } ,
2016-11-06 11:01:08 -07:00
2016-11-06 15:13:28 -07:00
/* UNDEFINED {"_aullshl", &TST_aullshl, 0xFFFFFFFFFFFFFFFFll, 0ll, 65, 0x0000000000000000ll}, */
2022-11-30 13:51:59 -07:00
{ " _aullshl " , & TST_aullshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 1 , 0xFFFFFFFFFFFFFFFEll } ,
{ " _aullshl " , & TST_aullshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 32 , 0xFFFFFFFF00000000ll } ,
{ " _aullshl " , & TST_aullshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 33 , 0xFFFFFFFE00000000ll } ,
{ " _aullshl " , & TST_aullshl , 0xFFFFFFFFFFFFFFFFll , 0ll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
2016-11-06 11:01:08 -07:00
2016-11-06 15:13:28 -07:00
/* UNDEFINED {"_aullshr", &TST_aullshr, 0xFFFFFFFFFFFFFFFFll, 0ll, 65, 0x0000000000000000ll}, */
2022-11-30 13:51:59 -07:00
{ " _aullshr " , & TST_aullshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 1 , 0x7FFFFFFFFFFFFFFFll } ,
{ " _aullshr " , & TST_aullshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 32 , 0x00000000FFFFFFFFll } ,
{ " _aullshr " , & TST_aullshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 33 , 0x000000007FFFFFFFll } ,
{ " _aullshr " , & TST_aullshr , 0xFFFFFFFFFFFFFFFFll , 0ll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _allmul " , & TST_allmul , 0xFFFFFFFFFFFFFFFFll , 0x0000000000000000ll , 0 , 0x0000000000000000ll } ,
{ " _allmul " , & TST_allmul , 0x0000000000000000ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _allmul " , & TST_allmul , 0x000000000FFFFFFFll , 0x0000000000000001ll , 0 , 0x000000000FFFFFFFll } ,
{ " _allmul " , & TST_allmul , 0x0000000000000001ll , 0x000000000FFFFFFFll , 0 , 0x000000000FFFFFFFll } ,
{ " _allmul " , & TST_allmul , 0x000000000FFFFFFFll , 0x0000000000000010ll , 0 , 0x00000000FFFFFFF0ll } ,
{ " _allmul " , & TST_allmul , 0x0000000000000010ll , 0x000000000FFFFFFFll , 0 , 0x00000000FFFFFFF0ll } ,
{ " _allmul " , & TST_allmul , 0x000000000FFFFFFFll , 0x0000000000000100ll , 0 , 0x0000000FFFFFFF00ll } ,
{ " _allmul " , & TST_allmul , 0x0000000000000100ll , 0x000000000FFFFFFFll , 0 , 0x0000000FFFFFFF00ll } ,
{ " _allmul " , & TST_allmul , 0x000000000FFFFFFFll , 0x0000000010000000ll , 0 , 0x00FFFFFFF0000000ll } ,
{ " _allmul " , & TST_allmul , 0x0000000010000000ll , 0x000000000FFFFFFFll , 0 , 0x00FFFFFFF0000000ll } ,
{ " _allmul " , & TST_allmul , 0x000000000FFFFFFFll , 0x0000000080000000ll , 0 , 0x07FFFFFF80000000ll } ,
{ " _allmul " , & TST_allmul , 0x0000000080000000ll , 0x000000000FFFFFFFll , 0 , 0x07FFFFFF80000000ll } ,
{ " _allmul " , & TST_allmul , 0xFFFFFFFFFFFFFFFEll , 0x0000000080000000ll , 0 , 0xFFFFFFFF00000000ll } ,
{ " _allmul " , & TST_allmul , 0x0000000080000000ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0xFFFFFFFF00000000ll } ,
{ " _allmul " , & TST_allmul , 0xFFFFFFFFFFFFFFFEll , 0x0000000080000008ll , 0 , 0xFFFFFFFEFFFFFFF0ll } ,
{ " _allmul " , & TST_allmul , 0x0000000080000008ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0xFFFFFFFEFFFFFFF0ll } ,
{ " _allmul " , & TST_allmul , 0x00000000FFFFFFFFll , 0x00000000FFFFFFFFll , 0 , 0xFFFFFFFE00000001ll } ,
{ " _alldiv " , & TST_alldiv , 0x0000000000000000ll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _alldiv " , & TST_alldiv , 0x0000000000000000ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _alldiv " , & TST_alldiv , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _alldiv " , & TST_alldiv , 0xFFFFFFFFFFFFFFFFll , 0x0000000000000001ll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _alldiv " , & TST_alldiv , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _alldiv " , & TST_alldiv , 0x0000000000000001ll , 0x0000000000000001ll , 0 , 0x0000000000000001ll } ,
{ " _alldiv " , & TST_alldiv , 0xFFFFFFFFFFFFFFFFll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000001ll } ,
{ " _alldiv " , & TST_alldiv , 0x000000000FFFFFFFll , 0x0000000000000001ll , 0 , 0x000000000FFFFFFFll } ,
{ " _alldiv " , & TST_alldiv , 0x0000000FFFFFFFFFll , 0x0000000000000010ll , 0 , 0x00000000FFFFFFFFll } ,
{ " _alldiv " , & TST_alldiv , 0x0000000000000100ll , 0x000000000FFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _alldiv " , & TST_alldiv , 0x00FFFFFFF0000000ll , 0x0000000010000000ll , 0 , 0x000000000FFFFFFFll } ,
{ " _alldiv " , & TST_alldiv , 0x07FFFFFF80000000ll , 0x0000000080000000ll , 0 , 0x000000000FFFFFFFll } ,
{ " _alldiv " , & TST_alldiv , 0xFFFFFFFFFFFFFFFEll , 0x0000000080000000ll , 0 , 0x0000000000000000ll } ,
{ " _alldiv " , & TST_alldiv , 0xFFFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0x0000000080000008ll } ,
{ " _alldiv " , & TST_alldiv , 0x7FFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0xC000000080000008ll } ,
{ " _alldiv " , & TST_alldiv , 0x7FFFFFFEFFFFFFF0ll , 0x0000FFFFFFFFFFFEll , 0 , 0x0000000000007FFFll } ,
{ " _alldiv " , & TST_alldiv , 0x7FFFFFFEFFFFFFF0ll , 0x7FFFFFFEFFFFFFF0ll , 0 , 0x0000000000000001ll } ,
{ " _allrem " , & TST_allrem , 0x0000000000000000ll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x0000000000000000ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0xFFFFFFFFFFFFFFFFll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x0000000000000001ll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0xFFFFFFFFFFFFFFFFll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x000000000FFFFFFFll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x0000000FFFFFFFFFll , 0x0000000000000010ll , 0 , 0x000000000000000Fll } ,
{ " _allrem " , & TST_allrem , 0x0000000000000100ll , 0x000000000FFFFFFFll , 0 , 0x0000000000000100ll } ,
{ " _allrem " , & TST_allrem , 0x00FFFFFFF0000000ll , 0x0000000010000000ll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x07FFFFFF80000000ll , 0x0000000080000000ll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0xFFFFFFFFFFFFFFFEll , 0x0000000080000000ll , 0 , 0xFFFFFFFFFFFFFFFEll } ,
{ " _allrem " , & TST_allrem , 0xFFFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x7FFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0x0000000000000000ll } ,
{ " _allrem " , & TST_allrem , 0x7FFFFFFEFFFFFFF0ll , 0x0000FFFFFFFFFFFEll , 0 , 0x0000FFFF0000FFEEll } ,
{ " _allrem " , & TST_allrem , 0x7FFFFFFEFFFFFFF0ll , 0x7FFFFFFEFFFFFFF0ll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x0000000000000000ll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x0000000000000000ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0xFFFFFFFFFFFFFFFFll , 0x0000000000000001ll , 0 , 0xFFFFFFFFFFFFFFFFll } ,
{ " _ualldiv " , & TST_ualldiv , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x0000000000000001ll , 0x0000000000000001ll , 0 , 0x0000000000000001ll } ,
{ " _ualldiv " , & TST_ualldiv , 0xFFFFFFFFFFFFFFFFll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000001ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x000000000FFFFFFFll , 0x0000000000000001ll , 0 , 0x000000000FFFFFFFll } ,
{ " _ualldiv " , & TST_ualldiv , 0x0000000FFFFFFFFFll , 0x0000000000000010ll , 0 , 0x00000000FFFFFFFFll } ,
{ " _ualldiv " , & TST_ualldiv , 0x0000000000000100ll , 0x000000000FFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x00FFFFFFF0000000ll , 0x0000000010000000ll , 0 , 0x000000000FFFFFFFll } ,
{ " _ualldiv " , & TST_ualldiv , 0x07FFFFFF80000000ll , 0x0000000080000000ll , 0 , 0x000000000FFFFFFFll } ,
{ " _ualldiv " , & TST_ualldiv , 0xFFFFFFFFFFFFFFFEll , 0x0000000080000000ll , 0 , 0x00000001FFFFFFFFll } ,
{ " _ualldiv " , & TST_ualldiv , 0xFFFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x7FFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0x0000000000000000ll } ,
{ " _ualldiv " , & TST_ualldiv , 0x7FFFFFFEFFFFFFF0ll , 0x0000FFFFFFFFFFFEll , 0 , 0x0000000000007FFFll } ,
{ " _ualldiv " , & TST_ualldiv , 0x7FFFFFFEFFFFFFF0ll , 0x7FFFFFFEFFFFFFF0ll , 0 , 0x0000000000000001ll } ,
{ " _uallrem " , & TST_uallrem , 0x0000000000000000ll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0x0000000000000000ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000001ll } ,
{ " _uallrem " , & TST_uallrem , 0xFFFFFFFFFFFFFFFFll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0x0000000000000001ll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000001ll } ,
{ " _uallrem " , & TST_uallrem , 0x0000000000000001ll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0xFFFFFFFFFFFFFFFFll , 0xFFFFFFFFFFFFFFFFll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0x000000000FFFFFFFll , 0x0000000000000001ll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0x0000000FFFFFFFFFll , 0x0000000000000010ll , 0 , 0x000000000000000Fll } ,
{ " _uallrem " , & TST_uallrem , 0x0000000000000100ll , 0x000000000FFFFFFFll , 0 , 0x0000000000000100ll } ,
{ " _uallrem " , & TST_uallrem , 0x00FFFFFFF0000000ll , 0x0000000010000000ll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0x07FFFFFF80000000ll , 0x0000000080000000ll , 0 , 0x0000000000000000ll } ,
{ " _uallrem " , & TST_uallrem , 0xFFFFFFFFFFFFFFFEll , 0x0000000080000000ll , 0 , 0x000000007FFFFFFEll } ,
{ " _uallrem " , & TST_uallrem , 0xFFFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0xFFFFFFFEFFFFFFF0ll } ,
{ " _uallrem " , & TST_uallrem , 0x7FFFFFFEFFFFFFF0ll , 0xFFFFFFFFFFFFFFFEll , 0 , 0x7FFFFFFEFFFFFFF0ll } ,
{ " _uallrem " , & TST_uallrem , 0x7FFFFFFEFFFFFFF0ll , 0x0000FFFFFFFFFFFEll , 0 , 0x0000FFFF0000FFEEll } ,
{ " _uallrem " , & TST_uallrem , 0x7FFFFFFEFFFFFFF0ll , 0x7FFFFFFEFFFFFFF0ll , 0 , 0x0000000000000000ll } ,
2023-03-08 08:12:45 -07:00
{ NULL , NULL , 0 , 0 , 0 , 0 }
2016-11-06 11:01:08 -07:00
} ;
2023-03-08 08:12:45 -07:00
static int Test64Bit ( SDL_bool verbose )
2016-11-06 11:01:08 -07:00
{
LL_Test * t ;
int failed = 0 ;
2023-11-09 14:29:15 -07:00
for ( t = LL_Tests ; t - > routine ; t + + ) {
2016-11-06 11:01:08 -07:00
unsigned long long result = 0 ;
unsigned int * al = ( unsigned int * ) & t - > a ;
unsigned int * bl = ( unsigned int * ) & t - > b ;
unsigned int * el = ( unsigned int * ) & t - > expected_result ;
unsigned int * rl = ( unsigned int * ) & result ;
if ( ! t - > routine ( & t - > a , & t - > b , t - > arg , & result , & t - > expected_result ) ) {
2022-11-27 09:38:43 -07:00
if ( verbose ) {
SDL_Log ( " %s(0x%08X%08X, 0x%08X%08X, %3d, produced: 0x%08X%08X, expected: 0x%08X%08X \n " , t - > operation , al [ 1 ] , al [ 0 ] , bl [ 1 ] , bl [ 0 ] ,
t - > arg , rl [ 1 ] , rl [ 0 ] , el [ 1 ] , el [ 0 ] ) ;
}
2016-11-06 11:01:08 -07:00
+ + failed ;
}
}
2022-11-27 09:38:43 -07:00
if ( verbose & & ( failed = = 0 ) ) {
2023-07-03 09:29:42 -06:00
SDL_Log ( " All 64bit intrinsic tests passed \n " ) ;
2022-11-27 09:38:43 -07:00
}
return failed ? 1 : 0 ;
2016-11-06 11:01:08 -07:00
}
2015-06-21 09:33:46 -06:00
2023-03-08 08:12:45 -07:00
static int TestCPUInfo ( SDL_bool verbose )
2015-06-21 09:33:46 -06:00
{
if ( verbose ) {
SDL_Log ( " CPU count: %d \n " , SDL_GetCPUCount ( ) ) ;
SDL_Log ( " CPU cache line size: %d \n " , SDL_GetCPUCacheLineSize ( ) ) ;
2022-11-30 13:51:59 -07:00
SDL_Log ( " AltiVec %s \n " , SDL_HasAltiVec ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " MMX %s \n " , SDL_HasMMX ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " SSE %s \n " , SDL_HasSSE ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " SSE2 %s \n " , SDL_HasSSE2 ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " SSE3 %s \n " , SDL_HasSSE3 ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " SSE4.1 %s \n " , SDL_HasSSE41 ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " SSE4.2 %s \n " , SDL_HasSSE42 ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " AVX %s \n " , SDL_HasAVX ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " AVX2 %s \n " , SDL_HasAVX2 ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " AVX-512F %s \n " , SDL_HasAVX512F ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " ARM SIMD %s \n " , SDL_HasARMSIMD ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " NEON %s \n " , SDL_HasNEON ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " LSX %s \n " , SDL_HasLSX ( ) ? " detected " : " not detected " ) ;
SDL_Log ( " LASX %s \n " , SDL_HasLASX ( ) ? " detected " : " not detected " ) ;
2015-06-21 09:33:46 -06:00
SDL_Log ( " System RAM %d MB \n " , SDL_GetSystemRAM ( ) ) ;
}
2022-11-27 09:38:43 -07:00
return 0 ;
2015-06-21 09:33:46 -06:00
}
2023-03-08 08:12:45 -07:00
static int TestAssertions ( SDL_bool verbose )
2015-06-21 09:33:46 -06:00
{
SDL_assert ( 1 ) ;
SDL_assert_release ( 1 ) ;
SDL_assert_paranoid ( 1 ) ;
SDL_assert ( 0 | | 1 ) ;
SDL_assert_release ( 0 | | 1 ) ;
SDL_assert_paranoid ( 0 | | 1 ) ;
2022-11-30 13:51:59 -07:00
#if 0 /* enable this to test assertion failures. */
2015-06-21 09:33:46 -06:00
SDL_assert_release ( 1 = = 2 ) ;
SDL_assert_release ( 5 < 4 ) ;
SDL_assert_release ( 0 & & " This is a test " ) ;
# endif
{
const SDL_AssertData * item = SDL_GetAssertionReport ( ) ;
while ( item ) {
SDL_Log ( " '%s', %s (%s:%d), triggered %u times, always ignore: %s. \n " ,
2022-11-30 13:51:59 -07:00
item - > condition , item - > function , item - > filename ,
item - > linenum , item - > trigger_count ,
item - > always_ignore ? " yes " : " no " ) ;
2015-06-21 09:33:46 -06:00
item = item - > next ;
}
}
2022-11-27 09:38:43 -07:00
return 0 ;
2015-06-21 09:33:46 -06:00
}
2022-11-30 13:51:59 -07:00
int main ( int argc , char * argv [ ] )
2015-06-21 09:33:46 -06:00
{
2023-03-16 17:25:39 -06:00
int i ;
2015-06-21 09:33:46 -06:00
SDL_bool verbose = SDL_TRUE ;
int status = 0 ;
2023-03-16 17:25:39 -06:00
SDLTest_CommonState * state ;
/* Initialize test framework */
state = SDLTest_CommonCreateState ( argv , 0 ) ;
2023-11-09 14:29:15 -07:00
if ( ! state ) {
2023-03-16 17:25:39 -06:00
return 1 ;
}
2015-06-21 09:33:46 -06:00
/* Enable standard application logging */
SDL_LogSetPriority ( SDL_LOG_CATEGORY_APPLICATION , SDL_LOG_PRIORITY_INFO ) ;
2023-03-16 17:25:39 -06:00
/* Parse commandline */
for ( i = 1 ; i < argc ; ) {
int consumed ;
consumed = SDLTest_CommonArg ( state , i ) ;
if ( ! consumed ) {
if ( SDL_strcmp ( argv [ i ] , " -q " ) = = 0 ) {
verbose = SDL_FALSE ;
consumed = 1 ;
}
}
if ( consumed < = 0 ) {
static const char * options [ ] = { " [-q] " , NULL } ;
SDLTest_CommonLogUsage ( state , argv [ 0 ] , options ) ;
return 1 ;
}
i + = consumed ;
2015-06-21 09:33:46 -06:00
}
2023-03-16 17:25:39 -06:00
2015-06-21 09:33:46 -06:00
if ( verbose ) {
SDL_Log ( " This system is running %s \n " , SDL_GetPlatform ( ) ) ;
}
status + = TestTypes ( verbose ) ;
status + = TestEndian ( verbose ) ;
2016-11-06 11:01:08 -07:00
status + = Test64Bit ( verbose ) ;
2015-06-21 09:33:46 -06:00
status + = TestCPUInfo ( verbose ) ;
status + = TestAssertions ( verbose ) ;
2023-03-16 17:25:39 -06:00
SDLTest_CommonDestroyState ( state ) ;
2015-06-21 09:33:46 -06:00
return status ;
}