annotate test/hacking-mips/calls.c @ 0:3e629dc19168

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:24:28 +0100
parents
children f5577f6bf97a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
1 /*
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
2
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
3 Package: dyncall
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
4 Library: test
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
5 File: test/hacking-mips/calls.c
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
7 License:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
8
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
9 Copyright (c) 2011-2015 Daniel Adler <dadler@uni-goettingen.de>,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
10 Tassilo Philipp <tphilipp@potion-studios.com>
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
11
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
12 Permission to use, copy, modify, and distribute this software for any
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
13 purpose with or without fee is hereby granted, provided that the above
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
14 copyright notice and this permission notice appear in all copies.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
15
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
16 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
17 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
18 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
19 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
20 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
21 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
22 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
23
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
24 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
25
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
26 typedef int i;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27 typedef float f;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28 typedef double d;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29 void _();
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30 void _iiiiiiiiii(i,i,i,i,i,i,i,i,i,i);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31 void _ffffffffff(f,f,f,f,f,f,f,f,f,f);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 void _dddddddddd(d,d,d,d,d,d,d,d,d,d);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 void _ifffffffff(i,f,f,f,f,f,f,f,f,f);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 void _iddddddddd(i,d,d,d,d,d,d,d,d,d);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 void _fdidfd(f,d,i,d,f,d);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 void _ddidfd(d,d,i,d,f,d);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37 void _ididfd(i,d,i,d,f,d);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 int ai[] = { 0 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 float af[] = { 0.0f, 1.0f, 2.0f, 3.0f, 4.0f, 5.0f, 6.0f, 7.0f, 8.0f, 9.0f };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 double ad[] = { 0.0 , 1.0 , 2.0 , 3.0 , 4.0 , 5.0 , 6.0 , 7.0 , 8.0 , 9.0 };
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 void call_() { _(); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 void call_iiiiiiiiii() { _iiiiiiiiii(ai[0],ai[1],ai[2],ai[3],ai[4],ai[5],ai[6],ai[7],ai[8],ai[9]); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44 void call_ffffffffff() { _ffffffffff(af[0],af[1],af[2],af[3],af[4],af[5],af[6],af[7],af[8],af[9]); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 void call_dddddddddd() { _dddddddddd(ad[0],ad[1],ad[2],ad[3],ad[4],ad[5],ad[6],ad[7],ad[8],ad[9]); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46 void call_ifffffffff() { _ifffffffff(ai[0],af[1],af[2],af[3],af[4],af[5],af[6],af[7],af[8],af[9]); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47 void call_iddddddddd() { _iddddddddd(ai[0],ad[1],ad[2],ad[3],ad[4],ad[5],ad[6],ad[7],ad[8],ad[9]); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 void call_fififififi() { _fififififi(af[0],ai[1],af[2],ai[3],af[4],ai[5],af[6],ai[7],af[8],ai[9]); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
50
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51 void call_fdidfd() { _fdidfd(1.0f,2.0, 3 ,4.0, 5.0f,6.0 ); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 void call_ddidfd() { _ddidfd(1.0, 2.0, 3 ,4.0, 5.0f,6.0 ); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 void call_ididfd() { _ididfd(1 , 2.0, 3 ,4.0, 5.0f,6.0 ); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54