OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [testsuite/] [gcc.target/] [x86_64/] [abi/] [test_m64m128_returning.c] - Blame information for rev 328

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 328 jeremybenn
#include <stdio.h>
2
#include "defines.h"
3
#include "macros.h"
4
#include "args.h"
5
 
6
struct IntegerRegisters iregs;
7
struct FloatRegisters fregs;
8
unsigned int num_iregs, num_fregs;
9
 
10
__m64
11
fun_test_returning___m64 (void)
12
{
13
  volatile_var++;
14
  return (__m64){72,0};
15
}
16
 
17
__m128
18
fun_test_returning___m128 (void)
19
{
20
  volatile_var++;
21
  return (__m128){73,0,0,0};
22
}
23
 
24
__m64 test_64;
25
__m128 test_128;
26
 
27
int
28
main (void)
29
{
30
  unsigned failed = 0;
31
  XMM_T xmmt1, xmmt2;
32
 
33
  /* We jump through hoops to compare the results as gcc 3.3 does throw
34
     an ICE when trying to generate a compare for a == b, when a and b
35
     are of __m64 or __m128 type :-(  */
36
  clear_struct_registers;
37
  test_64 = (__m64){72,0};
38
  xmmt1._m64[0] = test_64;
39
  xmmt2._m64[0] = WRAP_RET (fun_test_returning___m64)();
40
  if (xmmt1._long[0] != xmmt2._long[0]
41
      || xmmt1._long[0] != xmm_regs[0]._long[0])
42
    printf ("fail m64\n"), failed++;
43
 
44
  clear_struct_registers;
45
  test_128 = (__m128){73,0};
46
  xmmt1._m128[0] = test_128;
47
  xmmt2._m128[0] = WRAP_RET (fun_test_returning___m128)();
48
  if (xmmt1._long[0] != xmmt2._long[0]
49
      || xmmt1._long[0] != xmm_regs[0]._long[0])
50
    printf ("fail m128\n"), failed++;
51
  if (failed)
52
    abort ();
53
  return 0;
54
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.