[NTLK] [ANN] Newton C++ toolchain utilities (ELFtoNTK & ELFtoPKG)
cedric at sartoo.fr
Mon Jun 8 08:12:16 EDT 2020
Juste Wow !
thank you Paul
Envoyé de mon iPhone
> Le 8 juin 2020 à 12:45, Paul Guyot <pguyot at kallisys.net> a écrit :
> Hello all,
> I am pleased to announce the release of Newton C++ toolchain utilities that can be used to generate C++ code for NewtonOS using gcc.
> This is available as part of the DCL (Desktop Connection Library) and was successfully used to generate a Newton package on macOS X 10.15 with arm-none-eabi-g++ 8.3.0 and arm-none-eabi-binutils.
> Source code is available for download on GitHub here:
> ELFtoNTK is the equivalent of AIFtoNTK and actually a clone of a similar tool developed by Eckhart Köppen . From an ELF shared library, it generates a .ntkc file for use with Newton Toolkit (NTK).
> ELFtoPKG is the most innovative tool. From an ELF shared library, it generates a Newton package with a single "protocol" part. It effectively replaces Packer that generated a package part from a raw protocol part. The innovation lies in allowing relocation in the protocol code, something that the original Newton C++ Tools did not allow.
> Sample code is provided to illustrate the use case.
> For the history, I've been working on porting a large library to NewtonOS and was hit by a bug in NewtonOS. It doesn't handle embedded C++ code in NewtonScript packages larger than about 128KB (the package store was eventually corrupted and I had to erase the flash file), so I tried to package the library as a protocol only to realize Newton C++ Tools did not handle relocation, which were also needed. After writing a prototype ELF loader on NewtonOS and toying with global read/write variables using fdpic runtime, I wrote ELFtoPKG to try and apply relocations with protocol parts and it just worked. Additionally, Newton C++ compiler just couldn't compile some of the bits, so this made the porting process much easier.
> For newcomers to Newton programming, Newton programs mostly rely on NewtonScript and C++ can only be used to accelerate computation or writing drivers. This toolchain doesn't allow you to write a regular Newton application, Newton Toolkit (or alternative tools) is still required.
>  https://40hz.org/Pages/newton/hacking/experiments/
More information about the NewtonTalk