summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/f2c_4.c
blob: 7fb1debf31dbdc8483f72efce900464957d82e22 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/*  Check -ff2c calling conventions
    Return value of COMPLEX function is via an extra argument in the
     calling sequence that points to where to store the return value
    Additional underscore appended to function name
  
   Simplified from f2c output and tested with g77 */

/* We used to #include <complex.h>, but this fails for some platforms
   (like cygwin) who don't have it yet.  */
#define complex __complex__
#define _Complex_I (1.0iF)

typedef float real;
typedef double doublereal;

extern double f2c_4b__(double *);
extern void f2c_4d__( complex float *, complex float *);
extern void f2c_4f__( complex float *, int *,complex float *);
extern void f2c_4h__( complex double *, complex double *);
extern void f2c_4j__( complex double *, int *, complex double *);
extern void abort (void);

void f2c_4a__(void) {
  double a,b;
  a = 1023.0;
  b=f2c_4b__(&a);
  if ( a != b ) abort();
}

void f2c_4c__(void) {
  complex float x,ret_val;
  x = 1234 + 5678 * _Complex_I;
  f2c_4d__(&ret_val,&x);
  if ( x != ret_val ) abort();
}

void f2c_4e__(void) {
  complex float x,ret_val;
  int i=0;
  x = 1234 + 5678 * _Complex_I;
  f2c_4f__(&ret_val,&i,&x);
  if ( x != ret_val ) abort();
}

void f2c_4g__(void) {
  complex double x,ret_val;
  x = 1234 + 5678.0f * _Complex_I;
  f2c_4h__(&ret_val,&x);
  if ( x != ret_val ) abort();
}

void f2c_4i__(void) {
  complex double x,ret_val;
  int i=0;
  x = 1234.0f + 5678.0f * _Complex_I;
  f2c_4j__(&ret_val,&i,&x);
  if ( x != ret_val ) abort();
}

void f2c_4k__(complex float *ret_val, complex float *x) {
  *ret_val = *x;
}

void f2c_4l__(complex float *ret_val, int *i, complex float *x) {
  *ret_val = *x;
}

void f2c_4m__(complex double *ret_val, complex double *x) {
  *ret_val = *x;
}

void f2c_4n__(complex double *ret_val, int *i, complex double *x) {
  *ret_val = *x;
}