OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [testsuite/] [gcc.target/] [x86_64/] [abi/] [callabi/] [vaarg-5b.c] - Diff between revs 328 and 338

Only display areas with differences | Details | Blame | View Log

Rev 328 Rev 338
/* Test for cross x86_64<->w64 abi va_list calls.  */
/* Test for cross x86_64<->w64 abi va_list calls.  */
/* { dg-options "-O2 -mabi=ms -std=gnu99 -fno-builtin" } */
/* { dg-options "-O2 -mabi=ms -std=gnu99 -fno-builtin" } */
 
 
#include <stdarg.h>
#include <stdarg.h>
 
 
#define SZ_ARGS 1ll,2ll,3ll,4ll,5ll,6ll,7ll,0ll
#define SZ_ARGS 1ll,2ll,3ll,4ll,5ll,6ll,7ll,0ll
 
 
static int __attribute__ ((sysv_abi))
static int __attribute__ ((sysv_abi))
fct1 (va_list argp, ...)
fct1 (va_list argp, ...)
{
{
  long long p1,p2;
  long long p1,p2;
  int ret = 1;
  int ret = 1;
  __builtin_sysv_va_list argp_2;
  __builtin_sysv_va_list argp_2;
 
 
  __builtin_sysv_va_start (argp_2, argp);
  __builtin_sysv_va_start (argp_2, argp);
  do {
  do {
    p1 = va_arg (argp_2, long long);
    p1 = va_arg (argp_2, long long);
    p2 = va_arg (argp, long long);
    p2 = va_arg (argp, long long);
    if (p1 != p2)
    if (p1 != p2)
      ret = 0;
      ret = 0;
  } while (ret && p1 != 0);
  } while (ret && p1 != 0);
  __builtin_sysv_va_end (argp_2);
  __builtin_sysv_va_end (argp_2);
 
 
  return ret;
  return ret;
}
}
 
 
int
int
fct2 (int dummy, ...)
fct2 (int dummy, ...)
{
{
  va_list argp;
  va_list argp;
  int ret = dummy;
  int ret = dummy;
 
 
  va_start (argp, dummy);
  va_start (argp, dummy);
  ret += fct1 (argp, SZ_ARGS);
  ret += fct1 (argp, SZ_ARGS);
  va_end (argp);
  va_end (argp);
  return ret;
  return ret;
}
}
 
 

powered by: WebSVN 2.1.0

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