mirror of
git://repo.or.cz/tinycc.git
synced 2026-06-20 03:44:19 +08:00
Comprehensive verification of all ARM64 opcode constants against the ARM Architecture Reference Manual. Critical fixes: - ARM64_MUL_REG/MULS_REG: 0x1B007C00/0x3B007C00 → 0x1B000000/0x3B000000 - ARM64_RET: 0xD65F03C0 → 0xD65F001F Corrected to base templates: - ARM64_STR_Q_PRE: 0x3C9F0FE0 → 0x3C800000 - ARM64_LDR_Q_POST: 0x3CC107E0 → 0x3CC00000 - ARM64_ORR_REG_LSL: 0x2A0043E0 → 0x2A000000 - ARM64_SUB_REG_LSL: 0xCB2063FF → 0xCB000000 Removed incorrect constants: - ARM64_FMOV_S_D, ARM64_LDPSW, ARM64_LDR_S_SIMD, ARM64_MOV_V_D - ARM64_ORR_REG_LSL32, ARM64_LSR_W_8, ARM64_LSR_X_8/16/24 - ARM64_MOVI_W/X (SIMD instruction, not general-purpose) - Duplicate definitions All 108 remaining opcode constants verified correct. Builds successfully with no functional changes. |
||
|---|---|---|
| .github/workflows | ||
| examples | ||
| include | ||
| lib | ||
| tests | ||
| win32 | ||
| .gitignore | ||
| arm64-asm.c | ||
| arm64-gen.c | ||
| arm64-link.c | ||
| arm64-tok.h | ||
| arm-asm.c | ||
| arm-gen.c | ||
| arm-link.c | ||
| arm-tok.h | ||
| c67-gen.c | ||
| c67-link.c | ||
| Changelog | ||
| CodingStyle | ||
| coff.h | ||
| configure | ||
| conftest.c | ||
| COPYING | ||
| dwarf.h | ||
| elf.h | ||
| i386-asm.c | ||
| i386-asm.h | ||
| i386-gen.c | ||
| i386-link.c | ||
| i386-tok.h | ||
| il-gen.c | ||
| il-opcodes.h | ||
| libtcc.c | ||
| libtcc.h | ||
| Makefile | ||
| optclash | ||
| README | ||
| RELICENSING | ||
| riscv64-asm.c | ||
| riscv64-gen.c | ||
| riscv64-link.c | ||
| riscv64-tok.h | ||
| stab.def | ||
| stab.h | ||
| tcc-doc.texi | ||
| tcc.c | ||
| tcc.h | ||
| tccasm.c | ||
| tcccoff.c | ||
| tccdbg.c | ||
| tccelf.c | ||
| tccgen.c | ||
| tcclib.h | ||
| tccmacho.c | ||
| tccpe.c | ||
| tccpp.c | ||
| tccrun.c | ||
| tcctok.h | ||
| tcctools.c | ||
| texi2pod.pl | ||
| TODO | ||
| USES | ||
| VERSION | ||
| x86_64-asm.h | ||
| x86_64-gen.c | ||
| x86_64-link.c | ||
Tiny C Compiler - C Scripting Everywhere - The Smallest ANSI C compiler ----------------------------------------------------------------------- Features: -------- - SMALL! You can compile and execute C code everywhere, for example on rescue disks. - FAST! tcc generates machine code for i386, x86_64, arm, aarch64 or riscv64. Compiles and links about 10 times faster than 'gcc -O0'. - UNLIMITED! Any C dynamic library can be used directly. TCC is heading toward full ISOC99 compliance. TCC can of course compile itself. - SAFE! tcc includes an optional memory and bound checker. Bound checked code can be mixed freely with standard code. - Compile and execute C source directly. No linking or assembly necessary. Full C preprocessor included. - C script supported : just add '#!/usr/local/bin/tcc -run' at the first line of your C source, and execute it directly from the command line. Documentation: ------------- 1) Installation on Linux, BSD variants or macOS hosts: ./configure make make test make install Notes: On BSD hosts, gmake should be used instead of make. For Windows read tcc-win32.txt. makeinfo must be installed to compile the doc. By default, tcc is installed in /usr/local/bin. ./configure --help shows configuration options. 2) Introduction We assume here that you know ANSI C. Look at the example ex1.c to know what the programs look like. The include file <tcclib.h> can be used if you want a small basic libc include support (especially useful for floppy disks). Of course, you can also use standard headers, although they are slower to compile. You can begin your C script with '#!/usr/local/bin/tcc -run' on the first line and set its execute bits (chmod a+x your_script). Then, you can launch the C code as a shell or perl script :-) The command line arguments are put in 'argc' and 'argv' of the main functions, as in ANSI C. 3) Examples ex1.c: simplest example (hello world). Can also be launched directly as a script: './ex1.c'. ex2.c: more complicated example: find a number with the four operations given a list of numbers (benchmark). ex3.c: compute fibonacci numbers (benchmark). ex4.c: more complicated: X11 program. Very complicated test in fact because standard headers are being used ! As for ex1.c, can also be launched directly as a script: './ex4.c'. ex5.c: 'hello world' with standard glibc headers. tcc.c: TCC can of course compile itself. Used to check the code generator. tcctest.c: auto test for TCC which tests many subtle possible bugs. Used when doing 'make test'. 4) Full Documentation Please read tcc-doc.html to have all the features of TCC. Additional information for the Windows port is in tcc-win32.txt. License: ------- TCC is distributed under the GNU Lesser General Public License (see COPYING file). Fabrice Bellard.