annotate dyncallback/dyncall_thunk.c @ 542:a73a5cd50c19

- fix passing aggregate-by-val on x64/sysv: subaggr classification for aggr *arrays* was wrong (was problematic when there ware exactly 2 8bytes to be classified, potentially be passed via registers)
author Tassilo Philipp
date Mon, 02 May 2022 15:32:41 +0200
parents f5577f6bf97a
children 0c8838766866
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: dyncallback
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
5 File: dyncallback/dyncall_thunk.c
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: Thunk - Implementation Back-end selection
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
281
f5577f6bf97a - file header cleanups for release
Tassilo Philipp
parents: 179
diff changeset
9 Copyright (c) 2007-2018 Daniel Adler <dadler@uni-goettingen.de>,
0
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
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27 #include "dyncall_thunk.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30 #if defined(DC__Arch_Intel_x86)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31 # include "dyncall_thunk_x86.c"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 #elif defined(DC__Arch_AMD64)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 # include "dyncall_thunk_x64.c"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 #elif defined(DC__Arch_PPC32)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 # if defined(DC__OS_Darwin)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 # include "dyncall_thunk_ppc32.c"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37 # else
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 # include "dyncall_thunk_ppc32_sysv.c"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 # endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 #elif defined(DC__Arch_PPC64)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41 # include "dyncall_thunk_ppc64.c"
143
170cde9e2a83 - arm arm/thumb cleanup, sharing more files, directly
cslag
parents: 116
diff changeset
42 #elif defined(DC__Arch_ARM)
170cde9e2a83 - arm arm/thumb cleanup, sharing more files, directly
cslag
parents: 116
diff changeset
43 #include "dyncall_thunk_arm32.c"
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44 #elif defined(DC__Arch_MIPS)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 #include "dyncall_thunk_mips.c"
116
c5cb02203df4 - mips n64 working thunks
cslag
parents: 0
diff changeset
46 #elif defined(DC__Arch_MIPS64)
c5cb02203df4 - mips n64 working thunks
cslag
parents: 0
diff changeset
47 #include "dyncall_thunk_mips64.c"
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48 #elif defined(DC__Arch_Sparc)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 #include "dyncall_thunk_sparc32.c"
179
b11b0735b09f - renamings: sparc_v9 -> sparc64
cslag
parents: 143
diff changeset
50 #elif defined(DC__Arch_Sparc64)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51 #include "dyncall_thunk_sparc64.c"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 #elif defined(DC__Arch_ARM64)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 #include "dyncall_thunk_arm64.c"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54 #endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55