annotate dyncallback/dyncall_thunk_ppc64.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 bbefb8b8e74c
children
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_ppc64.c
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: Thunk - Implementation for ppc64
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) 2014-2015 Masanori Mitsugi <mitsugi@linux.vnet.ibm.com>
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
10
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
11 Permission to use, copy, modify, and distribute this software for any
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
12 purpose with or without fee is hereby granted, provided that the above
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
13 copyright notice and this permission notice appear in all copies.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
14
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
15 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
16 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
17 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
18 ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
19 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
20 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
21 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
22
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 #include "dyncall_thunk.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
26
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27 #define HIST16(x) (unsigned short)((((unsigned long)(x))>>48UL) & 0xffff)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28 #define HIER16(x) (unsigned short)((((unsigned long)(x))>>32UL) & 0xffff)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29 #define HI16(x) (unsigned short)((((unsigned long)(x))>>16UL) & 0xffff)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30 #define LO16(x) (unsigned short)( ((unsigned long)(x)) & 0xffff)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 void dcbInitThunk(DCThunk* p, void (*entry)())
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 {
7
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
34 #if DC__ABI_PPC64_ELF_V != 2
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 /*
7
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
36 ppc64 thunk code: (v1)
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
37 oris r11, r2, HI16(p)
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
38 ori r11,r11, LO16(p)
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
39 ld r12,48(r11)
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
40 ld r2,56(r11)
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
41 mtctr r12
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
42 bctr
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
43 */
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
44
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
45 p->thunk_entry = (void *)&(p->code_load_hi);
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
46 p->toc_thunk = ((long)(p->thunk_entry) & 0xffffffff00000000UL);
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
47
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
48 p->code_load_hi = 0x644bU; /* oris r11, r2, HI16(p) */
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
49 p->addr_self_hi = HI16(p);
155
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 7
diff changeset
50 p->code_load_lo = 0x616bU; /* ori r11,r11, LO16(p) */
7
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
51 p->addr_self_lo = LO16(p);
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
52 p->code_jump[0] = 0xe98b0030U; /* ld r12,48(r11) */
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
53 p->code_jump[1] = 0xe84b0038U; /* ld r2,56(r11) */
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
54 p->code_jump[2] = 0x7d8903a6U; /* mtclr r12 */
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
55 p->code_jump[3] = 0x4e800420U; /* bctr */
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
56 p->addr_entry = (void *)*((long *)entry);
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
57 p->toc_entry = *((long *)(entry + 8));
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
58
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
59 #else
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
60 /*
7ca57dbefed4 - ppc64 update from Masanori
cslag
parents: 0
diff changeset
61 ppc64 thunk code: (v2)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62 lis r11, HIST16(p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 ori r11,r11, HIER16(p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 rldicr r11,r11,32,31
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 oris r11,r11, HI16(p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 ori r11,r11, LO16(p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67 ld r12,40(r11)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
68 mtctr r12
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69 bctr
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
71
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 p->code_load_hist = 0x3d60U; /* lis r11,HIST16(p) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73 p->addr_self_hist = HIST16(p);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 p->code_load_hier = 0x616bU; /* ori r11,r11, HIER16(p) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75 p->addr_self_hier = HIER16(p);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 p->code_rot = 0x796b07c6U; /* rldicr r11,r11,32,31 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77 p->code_load_hi = 0x656bU; /* oris r11,r11, HI16(p) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78 p->addr_self_hi = HI16(p);
155
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 7
diff changeset
79 p->code_load_lo = 0x616bU; /* ori r11,r11, LO16(p) */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 p->addr_self_lo = LO16(p);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81 p->code_jump[0] = 0xe98b0028U; /* ld r12,40(r11) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
82 p->code_jump[1] = 0x7d8903a6U; /* mtclr r12 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
83 p->code_jump[2] = 0x4e800420U; /* bctr */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
84 p->addr_entry = (void *)(entry);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85 #endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
87