forked from WallyZambotti/Nitros9-CC-CrossCompiler
-
Notifications
You must be signed in to change notification settings - Fork 0
stahta01/Nitros9-CC-CrossCompiler
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
Linux CC cross compiler for (CoCo) Nitros-9 It contains: - cc2.5.3 : c front end - cprep19 : c preprocessor - c.comp : c compiler - c.opt - (c) rma asm optimizer - rma(r63) - relocating macro assembler - rlink - linker - ansifront - ANSI C to K&R preprocessor It has been successfully compiled and tested on Ubuntu 18.04 (AMD). All Linux binaries produced are 32bit. Some binaries are required to be compiled with no optimization or they will fail. Be warned if you change the make files. It is known to work on Intel (AMD) platforms. This C compiler tools chain produces binaries compatible with: Nitros-9 (MC6809 or HD6309). A test directory is provided that contains a dd directory. You should place the Linux executables in the dd/cmds directory and create a symbolic link from /dd to that directory: $ sudo ln -s ~/Nitros9-CC-CrossCompiler/test/dd /dd And add the cmds directory to your path: $ PATH=$PATH:/dd/cmds Some libraries and defs files are also provided under the test/dd/lib & test/dd/defs directories. You can add more by copying them from a Nitros-9 distribution. You will then be able to compile Nitros-9 C programs with the same instructions as normally used under Nitros-9: $ cc253 -A -s helloworld.c -f=helloworld $ cc253 main.c sub1.c sub2.r mylib.r -f=myprog The provided example in the test directory can be compiled with: $ cc253 -A -s texturebm.c gfxlib.c gpulib.c -f=texturebm (However this example program will only run on the OVCC emulator with the MPU device installed in one of the MPI slots.) When copying the executables to Nitros-9 (either real or emulator) for execution remember to set the execute attributes: $ attr myprogram e pe Note: This source will only compile on C implementations where the sizeof(int) equals the sizeof(int*) as pointers and integers are passed interchangably. This means it should compile on most 8/16/32 C compilers but not on most 64 bit compilers. On 64 bit OSes you will need to install a 32 bit tool chain and 32 bit libraries. The CoCo C implementation defines char(s) as signed. Your cross compiler must also define chars as signed. On Linux Arm char is unsigned by default but can be changed via a compile option. This source has been succefully compiled and tested on: CoCo OS9 or Nitros9 Intel Linux 64 bit with 32 bit support ARM Linux 64 bit with 32 bit support ARM Linux 32 bit (PI OS)
About
Nitros9 CC Cross Compiler for Linux
Topics
Resources
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published
Languages
- C 95.5%
- sed 1.7%
- Perl 1.2%
- Makefile 0.6%
- Shell 0.6%
- Assembly 0.3%
- Batchfile 0.1%