annotate dyncallback/dyncall_args_mips.c @ 544:111236b31c75

- C++ non-trivial aggregate-by-value handling: * dyncallback support for dcbArgAggr() * better doc
author Tassilo Philipp
date Tue, 31 May 2022 18:25:13 +0200
parents 71c884e610f0
children 2562c89d5bb5
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_args_mips.c
109
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
6 Description: Callback's Arguments VM - Implementation for non-o32 MIPS
0
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
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 281
diff changeset
9 Copyright (c) 2013-2022 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_args_mips.h"
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
29 DCint dcbArgInt(DCArgs* p)
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 DCint value;
109
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
32 if(p->reg_count.i < DCARGS_MIPS_NUM_IREGS)
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
33 value = p->ireg_data[p->reg_count.i++];
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 else {
109
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
35 value = *((DCint*)p->stackptr);
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
36 p->stackptr += sizeof(DCint);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 return value;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 DCuint dcbArgUInt(DCArgs* p) { return (DCuint)dcbArgInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
42 DCulonglong dcbArgULongLong(DCArgs* p)
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44 DCulonglong value;
110
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
45 p->reg_count.i += (p->reg_count.i & 1); /* Skip one reg if not aligned. */
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
46 p->stackptr += ((DCulong)p->stackptr & 4) & -4; /* 64bit values are also always aligned on stack */
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
47 #if defined(DC__Endian_LITTLE)
110
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
48 value = dcbArgUInt(p);
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
49 value |= ((DCulonglong)dcbArgUInt(p)) << 32;
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
50 #else
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51 value = ((DCulonglong)dcbArgUInt(p)) << 32;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 value |= dcbArgUInt(p);
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
53 #endif
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54 return value;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
56 DClonglong dcbArgLongLong(DCArgs* p) { return (DClonglong)dcbArgULongLong(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
57
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 DClong dcbArgLong (DCArgs* p) { return (DClong) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59 DCulong dcbArgULong (DCArgs* p) { return (DCulong) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 DCchar dcbArgChar (DCArgs* p) { return (DCchar) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 DCuchar dcbArgUChar (DCArgs* p) { return (DCuchar) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62 DCshort dcbArgShort (DCArgs* p) { return (DCshort) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 DCushort dcbArgUShort (DCArgs* p) { return (DCushort) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 DCbool dcbArgBool (DCArgs* p) { return (DCbool) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 DCpointer dcbArgPointer(DCArgs* p) { return (DCpointer)dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67 DCfloat dcbArgFloat(DCArgs* p)
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
68 {
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69 DCfloat result;
109
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
70 if(p->reg_count.f < DCARGS_MIPS_NUM_FREGS)
110
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
71 result = p->freg_data[p->reg_count.f++];
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 else {
109
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
73 result = *((DCfloat*)p->stackptr);
9e677d4c0b6b - mips comment cleanups
cslag
parents: 102
diff changeset
74 p->stackptr += sizeof(DCfloat);
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75 }
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
76 return result;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77 }
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
78 DCdouble dcbArgDouble(DCArgs* p)
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
79 {
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 union {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81 DCdouble result;
110
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
82 DCulonglong i;
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
83 } d;
110
9aa75a74614c - working mips32 eabi callbacks
cslag
parents: 109
diff changeset
84 d.i = dcbArgULongLong(p); /* those are passed via int regs */
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
85 return d.result;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
86 }
102
b7a9b524f0c3 - mips o32 callbacks, first draft (calls into handler correctly, with correct params, but doesn't return)
cslag
parents: 0
diff changeset
87
544
111236b31c75 - C++ non-trivial aggregate-by-value handling:
Tassilo Philipp
parents: 533
diff changeset
88 DCpointer dcbArgAggr (DCArgs* p, DCpointer target) { /* @@@AGGR not impl */ }
533
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 281
diff changeset
89 void dcbReturnAggr (DCArgs *args, DCValue *result, DCpointer ret) { /* @@@AGGR not impl */ }
71c884e610f0 - integration of patches from Raphael Luba, Thekla, Inc.:
Tassilo Philipp
parents: 281
diff changeset
90