Karoly Balogh
|
e507f612f5
|
m68k-palmos: further fixes to assembly section. also actually use aout, as we have aout binutils for palmos
|
2024-05-25 00:14:11 +03:00 |
|
Karoly Balogh
|
627734e104
|
m68k: try to fold two consecutive AND instructions into one. This usually happens when a zero extension is followed by another AND.
|
2024-05-25 00:01:35 +03:00 |
|
Karoly Balogh
|
d9c786fee6
|
m68k: also allow TST from before Sxx instructions with explicit .b size to be optimized away
|
2024-05-25 00:00:22 +03:00 |
|
Karoly Balogh
|
19fe377455
|
m68k: fix tw40182 test
|
2024-01-09 10:57:11 +01:00 |
|
Karoly Balogh
|
88ffc9e228
|
m68k: refactored the optimizer to avoid direct asml management where possible, and use standard functions instead
|
2024-01-09 03:03:27 +01:00 |
|
Karoly Balogh
|
020ca55e25
|
m68k: add more cases, where TST instructions can beoptimized away, because the previous instruction already sets all the required flags
|
2024-01-08 15:06:38 +01:00 |
|
Karoly Balogh
|
53e7006d56
|
m68k: fix the assembler reader to bail out earlier on a failed parsing of a constant expression
|
2023-12-23 15:36:51 +01:00 |
|
Pierre Muller
|
f1e32bb187
|
Add human68k OS to list of supported OSes for m68k GNU assembler
|
2023-12-01 22:12:58 +01:00 |
|
Karoly Balogh
|
9eda172a48
|
m68k: do not generate argument popping for a noreturn call
|
2023-11-30 23:43:27 +00:00 |
|
Karoly Balogh
|
439faf0da8
|
m68k: basic DOS syscall generation for human68k
|
2023-11-30 23:43:27 +00:00 |
|
Karoly Balogh
|
4a1db1dc79
|
m68k: initial compiler changes for Human68k (Sharp X68000) support
|
2023-11-30 23:43:27 +00:00 |
|
Karoly Balogh
|
6bbb10e64d
|
m68k: do not generate LEA instructions with explicitly specified size. only long is possible anyway.
|
2023-01-30 09:56:41 +01:00 |
|
Karoly Balogh
|
c577ac5ce9
|
m68k: add tables to convert from some stub opcodes + condition into real opcodes. Use them in the external assembler writer for now. Later the internal assembler will need these tables too.
|
2023-01-30 09:56:41 +01:00 |
|
Karoly Balogh
|
3cea1706e9
|
m68k: more work on instruction validation for the internal assembler
|
2023-01-09 12:01:10 +01:00 |
|
Karoly Balogh
|
69761839c0
|
m68k: removed the unused S_IQ opsize
|
2023-01-09 12:01:10 +01:00 |
|
Karoly Balogh
|
459dc68ab9
|
m68k: more boiler plate and refactor for a future internal assembler
|
2023-01-05 13:32:34 +01:00 |
|
Karoly Balogh
|
f2d6b4d530
|
m68k: added a helper function to check if a register is an FPU register
|
2023-01-05 13:32:33 +01:00 |
|
Karoly Balogh
|
721e988da2
|
m68k: add some initial CPU-specifc boilerplate for an internal ELF writer
|
2022-12-29 05:08:46 +01:00 |
|
Karoly Balogh
|
e19f60503b
|
m68k: updated instruction tables to match vasm release 1.9a
|
2022-12-29 03:36:51 +01:00 |
|
Karoly Balogh
|
92e5ede347
|
m68k: fixed the capabilities flags inverted logic issues committed in 7d23c2e9
|
2022-08-30 10:42:26 +02:00 |
|
Karoly Balogh
|
832b566097
|
m68k: add a CPU capability to signal the CPU has no 48 bit encodiing limits
|
2022-08-26 18:42:24 +02:00 |
|
Karoly Balogh
|
6c67798272
|
m68k: disable an A_MOVE in the spilling code in an effort to finally try to unbreak paszlib
|
2022-08-26 18:42:24 +02:00 |
|
Karoly Balogh
|
7d23c2e9d0
|
m68k: use CPU capabilities at places instead of hardwiring cpu_coldfire
|
2022-08-26 18:42:24 +02:00 |
|
Sven/Sarah Barth
|
7f3a5eb9ab
|
* extend tabstractprocdef.getcopyas by a parameter to control whether the copy should be registered or not
|
2022-05-26 21:42:59 +02:00 |
|
Karoly Balogh
|
57107c3310
|
m68k: opcode table updates based on vasm 1.9 (used with permission)
|
2022-04-05 12:07:49 +02:00 |
|
Karoly Balogh
|
59c33d69ab
|
Revert "m68k: utilize cg.a_loadaddr_ref_cgpara in hlcgcpu" for now, turns out it's not needed
|
2022-03-24 09:48:25 +01:00 |
|
Karoly Balogh
|
ed520548be
|
m68k: utilize cg.a_loadaddr_ref_cgpara in hlcgcpu, as m68k has an instruction for loading addresses directly to the stack (PEA), and the default implementation of hlcg.a_loadaddr_ref_cgpara doesn't use that code path
|
2022-03-23 11:06:18 +01:00 |
|
Karoly Balogh
|
22eb1e099f
|
* m68k: make sure right is in an address register for muln,addn,orn,xorn, before calling the low level cg
|
2022-03-22 09:02:31 +01:00 |
|
Karoly Balogh
|
be2c1c751d
|
* m68k: fixed the register save/restore for larger than 32K stackframes on subarchs which has no long displacement, to not trash register A0
|
2022-03-12 21:22:42 +01:00 |
|
Karoly Balogh
|
0600287c63
|
* m68k: spilling read, write, and replace is now bound to CPU capabilities instead of CPU family. This probably fixes some issues on 68000, where spilling replacement was not respecting CPU displacement handling boundaries, leading to assembler errors.
|
2022-03-11 16:03:21 +01:00 |
|
florian
|
27fb9086aa
|
* cleanup: cs_opt_loopunroll is a generic optimization for a long time already
|
2022-03-08 23:03:18 +01:00 |
|
Karoly Balogh
|
554ae218ca
|
* m68k: fix an endless syntax error loop in the assembler reader
|
2022-03-06 22:03:01 +01:00 |
|
Karoly Balogh
|
10191477ae
|
* m68k: allow vasm to be used for system_m68k_embedded target, simplify some code
|
2022-03-05 17:59:15 +01:00 |
|
Karoly Balogh
|
077a3f1892
|
* m68k: don't attempt to copy less than 1 byte in g_concatcopy, this fixes tdfa7.pp on 68000 and removes some superfluous address processing on 68020+ in the same test
|
2022-02-08 03:04:28 +01:00 |
|
Karoly Balogh
|
8f083f6342
|
* m68k: do not generate unnecessary unaligned load sequences for byte loads into registers, this fixes tcnvint1 test on plain 68000
|
2022-02-08 01:26:28 +01:00 |
|
Karoly Balogh
|
06da0b3db6
|
* fix m68k IE after e9acd759 , patch by Yuriy Sydorov
|
2021-12-13 16:14:59 +01:00 |
|
florian
|
6404478ea4
|
* cleanup of VER3_0 defines
|
2021-11-17 22:19:57 +01:00 |
|
florian
|
ff3acfb8cd
|
* cleanup of 2.7.0 defines
|
2021-10-31 13:20:28 +01:00 |
|
Károly Balogh
|
cdc7fec019
|
m68k: D2 is considered volatile on macosclassic
git-svn-id: trunk@49294 -
|
2021-04-29 22:06:26 +00:00 |
|
Károly Balogh
|
d06cb1a20a
|
m68k: fixed a comment. no functional change
git-svn-id: trunk@49275 -
|
2021-04-27 06:25:13 +00:00 |
|
Károly Balogh
|
2a7aa11163
|
m68k: added support to references like (a0,d0.w) in inline assembly, also fixed a bug, where sometimes the index register would have been randomly set as smaller than .l size, when the size wasn't specified
git-svn-id: trunk@49233 -
|
2021-04-19 09:13:02 +00:00 |
|
Károly Balogh
|
665180a579
|
m68k: always use ELF objects with vasm for improved cross-compatibility with other tools and compilers
git-svn-id: trunk@49210 -
|
2021-04-16 11:42:04 +00:00 |
|
Károly Balogh
|
b5216a1990
|
m68k: on the Sinclair QL insert the main program's name into the object, so the RTL later can set it as default job name
git-svn-id: trunk@49189 -
|
2021-04-12 11:51:12 +00:00 |
|
Károly Balogh
|
c8e712f400
|
m68k: cleaned up some ancient mess from cpunode.pas, no significant functional change, apart from unit inclusion order
git-svn-id: trunk@49187 -
|
2021-04-12 09:33:51 +00:00 |
|
Károly Balogh
|
2703b36fe1
|
m68k: removed some helper function which was added, but in the end it never saw any use
git-svn-id: trunk@48798 -
|
2021-02-24 09:10:40 +00:00 |
|
Károly Balogh
|
2ffe777b44
|
m68k: extend the the register to full size, when multiplied by an immediate in memory references. Patch based on the work of Pierre Muller.
git-svn-id: trunk@48732 -
|
2021-02-20 11:21:14 +00:00 |
|
Károly Balogh
|
ada3d2050c
|
m68k: write inline floating point immediates as hex consts, instead of scientific notation. the scientific notation format parsing depends on the libc the assembler was linked against, which can lead to varying results and compile errors
git-svn-id: trunk@48524 -
|
2021-02-08 05:01:45 +00:00 |
|
Károly Balogh
|
d0178f7ae0
|
m68k: fix a_loadfpu_ref_reg to call a_loadfpu_reg_reg instead of a_load_reg_reg. made a_loadfpu_reg_reg internalerror on invalid target sizes when loading to a different reg size
git-svn-id: trunk@48523 -
|
2021-02-08 04:12:21 +00:00 |
|
Károly Balogh
|
77fee8b4eb
|
m68k: do not use OS_NO for FPU locations, but properly promote location sizes into the CG
git-svn-id: trunk@48522 -
|
2021-02-08 04:07:04 +00:00 |
|
Károly Balogh
|
67fcf0f03e
|
m68k: revert r48224, the fix proposed in that patch was just hiding an underlying issue
git-svn-id: trunk@48415 -
|
2021-01-25 00:42:01 +00:00 |
|