annotate dyncallback/dyncall_args_mips.c @ 0:3e629dc19168

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:24:28 +0100
parents
children b7a9b524f0c3
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
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 Description: Callback's Arguments VM - 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
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
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29 DCint dcbArgInt(DCArgs* p)
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;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 if(p->ireg_count < 8)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 value = p->ireg_data[p->ireg_count++];
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35 value = *((int*)p->stackptr);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 p->stackptr += sizeof(int);
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
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 DCulonglong dcbArgULongLong(DCArgs* p)
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;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 p->ireg_count += (p->ireg_count & 1); // Skip one reg if not aligned.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46 value = ((DCulonglong)dcbArgUInt(p)) << 32;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47 value |= dcbArgUInt(p);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48 return value;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
50 DClonglong dcbArgLongLong(DCArgs* p) { return (DClonglong)dcbArgULongLong(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 DClong dcbArgLong (DCArgs* p) { return (DClong) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 DCulong dcbArgULong (DCArgs* p) { return (DCulong) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54 DCchar dcbArgChar (DCArgs* p) { return (DCchar) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55 DCuchar dcbArgUChar (DCArgs* p) { return (DCuchar) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
56 DCshort dcbArgShort (DCArgs* p) { return (DCshort) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
57 DCushort dcbArgUShort (DCArgs* p) { return (DCushort) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 DCbool dcbArgBool (DCArgs* p) { return (DCbool) dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59 DCpointer dcbArgPointer(DCArgs* p) { return (DCpointer)dcbArgUInt(p); }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 DCfloat dcbArgFloat(DCArgs* p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63 DCfloat result;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
64 if(p->freg_count < 8)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
65 result = (DCfloat)p->freg_data[p->freg_count++];
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
66 else {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
67 result = *((float*)p->stackptr);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
68 p->stackptr += sizeof(float);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
69 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
70 return result;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
71 }
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
72 DCdouble dcbArgDouble(DCArgs* p)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
73 {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
74 union {
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
75 DCdouble result;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
76 DCfloat f[2];
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
77 } d;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
78 p->freg_count += (p->freg_count & 1); // Skip one reg if not aligned.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
79 d.f[0] = dcbArgFloat(p);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
80 d.f[1] = dcbArgFloat(p);
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
81 return d.result;
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
82 }