annotate dyncallback/dyncall_thunk_mips.c @ 256:7520e2260097

- added to configure some detection on how to compile .s/.S with --noexecstack (or similar), as compilers' defaults are often insane - since no-execstack handling is now in build, remove .note.GNU-stack section markers (were of limites use, anyways, b/c unportable or implemented inconsistently across platforms) - some ToDo, etc. updates
author Tassilo Philipp
date Sat, 20 May 2017 00:02:59 +0200
parents bbefb8b8e74c
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: dyncallback
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
5 File: dyncallback/dyncall_thunk_mips.c
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: Thunk - Implementation for MIPS
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) 2013-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 #include "dyncall_thunk.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27
97
d0787f3b81fb - internal linkage for some helper functions
cslag
parents: 0
diff changeset
28 static unsigned short hi16(x) { return ( (unsigned short) (((unsigned int)x)>>16UL) ); }
d0787f3b81fb - internal linkage for some helper functions
cslag
parents: 0
diff changeset
29 static unsigned short lo16(x) { return ( (unsigned short) ((unsigned int)x) ); }
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31 void dcbInitThunk(DCThunk* p, void (*entry)())
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 /*
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 Thunk Register: $t4 ($12)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 According to o32abi: $t9
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37
101
1ce60358fbad - mips related cleanup, mostly comments, cpp macro lib
cslag
parents: 97
diff changeset
38 'The Linux/MIPS convention is that all PIC calls use t9 to hold the address of
1ce60358fbad - mips related cleanup, mostly comments, cpp macro lib
cslag
parents: 97
diff changeset
39 the called function.' [See MIPS Run, p.413]
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41 mips thunk code:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 lui $t4, %hi(p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 lui $t9, %hi(entry)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44 ori $t9, $t9, %lo(entry)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 jr $t9
97
d0787f3b81fb - internal linkage for some helper functions
cslag
parents: 0
diff changeset
46 ori $t4, $t4, %lo(p) ; branch delay slot
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 00000000 <thunk>:
155
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
50 0: 3c0c0000 lui t4,0x0
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
51 4: 3c190000 lui t9,0x0
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
52 8: 37390000 ori t9,t9,0x0
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
53 c: 03200008 jr t9
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
54 10: 00200825 move at,at
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
55 14: 358c0000 ori t4,t4,0x0
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
56 18: 00200825 move at,at
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
57 1c: 00200825 move at,at
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58
155
bbefb8b8e74c - sparc32 thunk code
cslag
parents: 101
diff changeset
59 */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 #if defined(DC__Endian_BIG)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 p->data[0] = 0x3c0c; p->data[1] = hi16(p); /* lui $t4, hi(p) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 p->data[2] = 0x3c19; p->data[3] = hi16(entry); /* lui $t9, hi(entry) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 p->data[4] = 0x3739; p->data[5] = lo16(entry); /* ori $t9, $t9, lo(entry) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 p->jump = 0x03200008; /* jr $t9 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67 p->bddt[0] = 0x358c; p->bddt[1] = lo16(p); /* ori $t4, $t4, lo(p) - branch delay slot */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
68
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69 #else /* defined(DC__Endian_LITTLE) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
71 p->data[1] = 0x3c0c; p->data[0] = hi16(p); /* lui $t4, hi(p) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 p->data[3] = 0x3c19; p->data[2] = hi16(entry); /* lui $t9, hi(entry) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73 p->data[5] = 0x3739; p->data[4] = lo16(entry); /* ori $t9, $t9, lo(entry) */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 p->jump = 0x03200008; /* jr $t9 */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75 p->bddt[1] = 0x358c; p->bddt[0] = lo16(p); /* ori $t4, $t4, lo(p) - branch delay slot */
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77 #endif
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80