Go to file
Michael Matz ce8814cdd6 Avoid array overflow
with fuzzed source code we might run into this with idx out of bounds.
We're going to error out on this later, but let's not access
out-of-bounds elements.
2021-02-12 23:46:21 +01:00
examples makefile: unify cross with native builds 2017-02-25 12:51:04 +01:00
include stdatomic: memory models as macros 2021-01-27 13:26:48 +03:00
lib test coverage update 2021-01-27 13:27:10 +01:00
tests Fix a VLA problem 2021-02-03 04:30:11 +01:00
win32 Fix wine 2021-01-03 20:12:34 +01:00
.gitignore include/tccdefs.h: moved and use it 2020-12-22 11:06:19 +01:00
arm64-asm.c Makefile: Split arm64-asm from arm-asm 2021-01-03 15:49:17 +01:00
arm64-gen.c implement test coverage 2021-01-23 18:17:38 +01:00
arm64-link.c add arm64 relocs 2021-01-03 19:14:53 +01:00
arm-asm.c arm-asm: Support immediate values without "#" (Unified Assembly Language) 2021-01-28 16:32:31 +01:00
arm-gen.c debug_modes, re-unalign, cleanups 2021-01-24 18:00:33 +01:00
arm-link.c BSD: arm support 2021-01-16 07:01:59 +01:00
arm-tok.h arm-asm: Add vmsr, vmrs 2021-01-26 14:25:39 +01:00
c67-gen.c configure chmod 755 etc. 2021-01-26 18:44:37 +01:00
c67-link.c allow libtcc states to be used concurrently 2019-12-11 02:36:19 +01:00
Changelog 'long' review 2017-09-24 18:57:48 +02:00
CodingStyle CodingStyle: Remove reference to misaligned struct CString. 2016-01-06 19:09:28 +00:00
coff.h Spelling fixes in C comments only 2017-05-07 21:38:09 -07:00
configure configure chmod 755 etc. 2021-01-26 18:44:37 +01:00
conftest.c conftest correctly detects NetBSD and OpenBSD for TRIPLET_OS 2021-01-17 08:49:37 +01:00
COPYING changed license to LGPL 2003-05-24 14:18:56 +00:00
elf.h OpenBSD: -arm- Add more R_ARM* constants in elf.h. 2021-01-11 07:21:57 +01:00
i386-asm.c tccgen: introduce TOK_NEG for unary minus 2021-01-06 01:44:22 +01:00
i386-asm.h x86-asm: Fix lar opcode operands 2016-12-15 17:47:08 +01:00
i386-gen.c implement test coverage 2021-01-23 18:17:38 +01:00
i386-link.c lazy binding 2020-12-18 15:24:32 +01:00
i386-tok.h x86-64-asm: Support high registers %r8 - %r15 2016-12-15 17:47:09 +01:00
il-gen.c Spelling fixes in C comments only 2017-05-07 21:38:09 -07:00
il-opcodes.h Revert all of my changes to directories & codingstyle. 2015-07-29 16:57:12 -04:00
libtcc.c debug_modes, re-unalign, cleanups 2021-01-24 18:00:33 +01:00
libtcc.h libtcc: accept tcc_define_symbol(s1, "sym=value", NULL) 2020-07-06 13:00:47 +02:00
Makefile configure chmod 755 etc. 2021-01-26 18:44:37 +01:00
README *BSD: mention all BSD ports in README. 2020-12-20 10:50:07 +01:00
RELICENSING Relicensing TinyCC 2021-02-02 14:07:43 +01:00
riscv64-asm.c Add bound checking to arm, arm64 and riscv64 2020-06-16 07:39:48 +02:00
riscv64-gen.c debug_modes, re-unalign, cleanups 2021-01-24 18:00:33 +01:00
riscv64-link.c lazy binding 2020-12-18 15:24:32 +01:00
stab.def Revert all of my changes to directories & codingstyle. 2015-07-29 16:57:12 -04:00
stab.h Revert all of my changes to directories & codingstyle. 2015-07-29 16:57:12 -04:00
tcc-doc.texi implement test coverage 2021-01-23 18:17:38 +01:00
tcc.c implement test coverage 2021-01-23 18:17:38 +01:00
tcc.h test coverage update 2021-01-27 13:27:10 +01:00
tccasm.c tccgen: introduce TOK_NEG for unary minus 2021-01-06 01:44:22 +01:00
tcccoff.c allow libtcc states to be used concurrently 2019-12-11 02:36:19 +01:00
tccelf.c test coverage update 2021-01-27 13:27:10 +01:00
tccgen.c Revert "Long double Constant problem" 2021-02-12 22:52:05 +01:00
tcclib.h Revert all of my changes to directories & codingstyle. 2015-07-29 16:57:12 -04:00
tccmacho.c fix cross compiling on openbsd 2021-01-12 09:59:52 +01:00
tccpe.c test coverage update 2021-01-27 13:27:10 +01:00
tccpp.c stdatomic: atomic builtins parsing support 2021-01-26 22:37:44 +03:00
tccrun.c debug_modes, re-unalign, cleanups 2021-01-24 18:00:33 +01:00
tcctok.h stdatomic: c11 prefix; migrate to models macros 2021-01-27 13:33:32 +03:00
tcctools.c Make sure to escape paths in generated make dependencies 2021-01-30 00:51:15 +01:00
texi2pod.pl Revert all of my changes to directories & codingstyle. 2015-07-29 16:57:12 -04:00
TODO Remove a bit-field TODO 2017-04-29 22:09:10 +02:00
USES USES: add mpc library 2020-07-11 20:00:37 +02:00
VERSION update VERSION to 0.9.27 2017-02-08 19:56:15 +01:00
x86_64-asm.h x86-64-asm: Fix mov im64,rax encoding 2017-02-23 00:16:25 +01:00
x86_64-gen.c Avoid array overflow 2021-02-12 23:46:21 +01:00
x86_64-link.c lazy binding 2020-12-18 15:24:32 +01:00

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 optimized x86 code. No byte code
  overhead. Compile, assemble and link about 7 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 a i386/x86_64/arm/aarch64/riscv64
   Linux/macOS/FreeBSD/NetBSD/OpenBSD hosts.

   ./configure
   make
   make test
   make install

   Notes: For FreeBSD, NetBSD and OpenBSD, 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 is available for the Windows port in tcc-win32.txt.

License:
-------

TCC is distributed under the GNU Lesser General Public License (see
COPYING file).

Fabrice Bellard.