Skip to content

Compiler Option: -gen


Sets the backend code emitter.

Syntax

-gen< backend >`

`

Parameters

backend

gas for x86 GAS assembly, gcc for GNU C, gas64 for x86_64 GAS assembly, clang for clang, llvm for LLVM IR.

Description

The -gen compiler option sets the backend code emitter and assembler. If this option is not specified, the default is -gen gas for x86 and -gen gcc for x86_64.

-gen gas

The compiler will emit GAS assembler code to a .asm file which will then be compiled to an object file using 'as'. This is fbc's original x86 code generation backend.

-gen gas64

The compiler will emit GAS assembler code (64-bit) to a .asm file which will then be compiled to an object file using 'as'.

-gen gcc

The compiler will emit C code to a .c file which will then be compiled to an .asm file using 'gcc' as a high level assembler. The C backend is intended to make FB portable to more platforms than just x86. This requires gcc to be installed so that fbc can invoke it to compile the C code, also see Installing gcc for -gen gcc.

-gen clang

The compiler will emit C code to a .c file which will then be compiled to an .asm file using 'clang' as a high level assembler.

-gen llvm

The compiler will emit LLVM IR code to a .ll file which will then be compiled to an .asm file using 'llc'. The LLVM backend is still a work in progress. It is intended for the same purpose as the C backend, and could theoretically solve some of the C backend's problems, such as debugging meta data support.

Version

  • -gen clang added in fbc 1.20.0

See also

Back to DocToc

Translated from FreeBASIC official docs. Contact us for removal if infringed.
FreeBASIC is an open-source project, not affiliated with Microsoft