Sanne Wouda
7b8a99db3c
Add a preprocessor-only mode
...
- Very useful for testing and debugging
- Add preprocess() stub and skip compilation in preprocessor mode
2021-01-05 22:53:04 +00:00
Sanne Wouda
a18e0c1782
Add newline tokens to parse stream
...
- needed to determine start and end of macro directives
- the main parser doesn't need them, so strip out the newline tokens
before parsing to avoid changing it
2021-01-05 22:23:15 +00:00
Jeremiah Orians
921cc86ce6
First generation implemention of typedef
2021-01-02 22:00:02 -05:00
Jeremiah Orians
358b6cfb96
Fix modulus behavior that is wrong.
...
Thank you janneke
2021-01-01 16:39:27 -05:00
Jeremiah Orians
c220d14928
Catching some segfaults
2020-12-31 09:53:05 -05:00
Jeremiah Orians
e25c1995aa
Make types more proper
2020-12-27 21:51:46 -05:00
Jeremiah Orians
6fe6f44a29
Make type information localized to the inside of statements
2020-12-19 16:35:33 -05:00
Jeremiah Orians
d9504e3872
Allow M2-Planet to support larger outputs without hitting a segfault
2020-12-19 06:50:11 -05:00
Sanne Wouda
968fdfea65
AArch64 support for unsigned comparison
2020-12-17 00:01:17 +00:00
Jeremiah Orians
e5befc4fee
armv7l support for unsigned comparisons
2020-12-15 21:09:26 -05:00
Jeremiah Orians
f2cae3d501
AMD64 support for unsigned comparisons
2020-12-15 20:28:04 -05:00
Jeremiah Orians
132e685f97
Fix x86 behavior on unsigned compares
2020-12-15 17:46:45 -05:00
Jeremiah Orians
9da48c5ece
match gcc behavior in regards to if(-1 > 0)
2020-12-15 07:24:07 -05:00
Jeremiah Orians
5c22aac02d
Change knight-posix HEAP behavior and leverage better relational choices for knight-posix
2020-12-15 06:02:38 -05:00
Sanne Wouda
a63b8837c0
[AArch64] Use arithmetic right shift for signed
...
- as discussed with deesix, this is the proper fix
- the test1000 checksum changes as it uses the M2-Planet source as input
2020-12-05 14:59:16 +00:00
Jeremiah Orians
67dbbbdcfc
Enable support for C multi-strings
2020-11-15 18:58:25 -05:00
Jeremiah Orians
57264eb157
Catch potential segfaulting behavior in generated binaries
2020-11-08 21:13:12 -05:00
Jeremiah Orians
39915de931
harmonize integer behavior when reading strings
2020-10-17 13:50:25 -04:00
Jeremiah Orians
c4a636c99d
Fix shift behavior to better match C standard
2020-10-16 22:07:06 -04:00
Jeremiah Orians
09783ac089
Fixed continue behavior and added a test to verify correct behavior
2020-02-28 18:48:58 -05:00
deesix
b2ece54864
aarch64: do not generate a wasteful stack anymore
...
Until now, each element on the compiled program stack was 128 bits long,
half of them unused because only one 64 bits value was stored.
Now it's 64 bits long, so we don't waste all that memory.
We workaround the architectural alignment restriction of the SP register by
using a free regular register. X18 is for platform use so it seems a good
candidate for this task.
At _start we copy the value of SP into X18. SP is not used anymore. When a
definition refers to SP it doesn't mean it literaly now, because here we
redefine (without renaming) the involved M1 macro definitions to operate
on X18 (easier transition; abstraction). INIT_SP is introduced.
The function arguments are passed via stack, so the offset from the Base
Pointer ("depth") to each of them is different now. Changes both to
compiler code (cc_core.c) and libc reflect that the arguments are 8 bytes
(instead of 16 bytes) apart now. Note that SUB_X0_32 and SUB_X0_48 are
removed, because we only need 8, 16 and 24 bytes subtraction to reach the
arguments from asm libc functions. SUB_X0_8 and SUB_X0_24 are introduced.
2020-02-08 00:16:54 +01:00
deesix
fbc2bf3333
aarch64: statement
2020-02-01 21:23:49 +01:00
deesix
803cf4ffa3
aarch64: flow control
2020-02-01 21:23:49 +01:00
deesix
ebb0e4a3f9
aarch64: expression
2020-02-01 21:23:49 +01:00
deesix
c32cb92daa
aarch64: arithmetic, relational and bitwise expressions
2020-02-01 21:23:49 +01:00
deesix
39936d81cb
aarch64: primary, postfix and unary expressions
2020-02-01 21:23:49 +01:00
deesix
b581244df0
aarch64: load of function, constant, global and variable
2020-02-01 21:23:49 +01:00
deesix
02bac66940
aarch64: function, function call, arguments, locals and return
2020-02-01 21:23:49 +01:00
deesix
0737a2acf0
aarch64: common recursion
2020-02-01 21:23:49 +01:00
Jeremiah Orians
095664e680
Fix knight-native to be able to support much larger binaries
2020-01-31 22:43:51 -05:00
Jeremiah Orians
5c4c6aee71
prevent void foo () { if(0) {} class of segfaults
2020-01-30 18:40:45 -05:00
Jeremiah Orians
0709770730
Enabled forgotten cleanup scripts and add logic to catch ?alloc errors
2020-01-25 14:15:45 -05:00
Jeremiah Orians
4b2a048f14
Start reducing number of segfaults possible in M2-Planet
2020-01-22 18:03:28 -05:00
Jeremiah Orians
1221a5e6dc
Replace NOP with NULL because that is what is really ment by it
2020-01-06 20:21:26 -05:00
Jeremiah Orians
64a3a1b674
Get division on x86/AMD64 a closer approximation of what is correct
2019-11-29 12:55:55 -05:00
Jeremiah Orians
9eb0a8706e
Fixed amd64's xchg behavior, removed fixup_int32 and updated Changelog
2019-10-31 20:54:43 -04:00
Jeremiah Orians
dea4f902b7
Adding support for additional type compatibility with C and backported
...
regression fix for ARMv7l debug headers
2019-10-27 12:55:07 -04:00
Andrius Štikonas
96588d406f
Fix a typo:
...
Recieved -> Received
2019-10-23 22:55:56 +01:00
Jeremiah Orians
465b4c9c31
Fixup behavior on 64bit platforms
2019-06-19 21:43:34 -04:00
Jeremiah Orians
f43aa4a44c
Minor tweaks to better match amd64 assembly
2019-06-03 21:01:14 -04:00
Jeremiah Orians
27cf071ee9
Release_1.3.0
2019-04-22 19:30:08 -04:00
Jeremiah Orians
e55dc78597
4/24 working tests for AMD64
2019-04-19 17:43:59 -04:00
deesix
a3acf66077
Global string (char*) value indirect store, to fix segfault
...
Because, as OriansJ found, we don't want to read the first bytes of the
value as a pointer. See global_load() for programs like:
char* s = "xyzzy\n";
int main(void){ file_print(s, 1); return 0; }
There's an alternative: "fix the GLOBAL behavior to be type sensitive" but
this indirect store was choosen because it "preserve[s] the ability to
assign new strings to a global char*".
2019-04-18 16:48:41 +02:00
Jeremiah Orians
420f8b62b9
1/24 working tests for AMD64 Port
2019-04-17 20:19:17 -04:00
Jeremiah Orians
119226d569
Fixed ARMV7l stack behavior thanks to dddddd
2019-04-13 08:31:39 -04:00
Jeremiah Orians
442601197c
17/24 working tests for armv7l
2019-03-30 09:25:52 -04:00
Jeremiah Orians
c3ad31d66a
15/24 working tests for armv7l
2019-03-23 18:29:19 -04:00
Jeremiah Orians
87b1daaaa9
13/24 working tests for armv7l
2019-03-17 22:34:26 -04:00
Jeremiah Orians
95107d9fb6
10/24 working tests for armv7l
2019-03-17 10:08:56 -04:00
Jeremiah Orians
fe95136b49
8/24 working tests for ARMv7l
2019-03-17 06:15:20 -04:00