FASM

For the Royal Navy project also known as "FASM", see Future Attack Submarine.
FASM

flat assembler
Developer(s) Tomasz Grysztar
Stable release 1.71.50 / January 30, 2016 (2016-01-30)
Operating system DOS and IDE, Windows and IDE, Unix-like (Linux, OpenBSD, etc.), MenuetOS, KolibriOS, OctaOS, DexOS and IDE, SkyOS, Solar_OS
Platform x86, x86-64
Type Assembler
License Simplified BSD with a weak copyleft clause
Website flatassembler.net

FASM (flat assembler) in computing is an assembler. It supports programming in Intel-style assembly language on the IA-32 and x86-64 computer architectures. It claims high speed, size optimizations, operating system (OS) portability, and macro abilities.[1][2] It is a low-level assembler[2] and intentionally uses very few command-line options (see SSSO principle). It is free and open-source software.

All versions of FASM can directly output any of the following: flat "raw" binary (usable also as DOS COM executable or SYS driver), objects: Executable and Linkable Format (ELF) or Common Object File Format (COFF) (classic or MS-specific), or executables in either MZ, ELF, or Portable Executable (PE) format (including WDM drivers, allows custom MZ DOS stub). An unofficial port targeting the ARM architecture (FASMARM) also exists.[3]

History

The project was started in 1999 by Tomasz Grysztar, a.k.a. Privalov, at that time, an undergraduate student of mathematics from Poland. It was released publicly in March 2000.[4][5] FASM is completely written in assembly language and comes with full source. It is self-hosting and has been able to assemble itself since version 0.90 (May 4, 1999). It has been used to write several operating systems, including MenuetOS[6] and DexOS.[7]

Design

FASM originally only ran in 16-bit flat real mode. 32-bit support was added and then supplemented with optional DPMI support. It was written in a way that made it easy to port to any operating system that allowed flat 32-bit addressing; it was ported to Windows and then Linux.

FASM is a low-level assembler. It does not support as many high-level statements as MASM or TASM.[2] It provides syntax features and macros, which make it possible to customize or create missing statements.[4] Its memory-addressing syntax is similar to TASM's ideal mode and NASM. Brackets are used to denote memory operands as in both assemblers, but their size is placed outside the brackets, like in NASM.[8]

FASM is a multi-pass assembler. It makes extensive code-size optimization and allows unconstrained forward referencing.[2][8] An unusual FASM construct is defining procedures only if they are used somewhere in the code, something that in most languages is done per-object by the linker.

SSSO principle

FASM is based on the SSSO principle (same source, same output): the contents of the resulting file are not affected by the command line.[8] Such an approach saves FASM sources from compiling problems often present in many assembly projects. On the other hand, it makes it harder to maintain a project that consists of multiple separately compiled source files or mixed-language projects. However, there exists a Win32 wrapper called FA, which mitigates this problem.[9] FASM projects can be built from one source file directly into an executable file without a linking stage.[2]

Examples

Several compilers use FASM as a backend:

See also

References

  1. Tomasz Grysztar. "Flat Assembler Programmer's Manual". Retrieved 2008-05-12.
  2. 1 2 3 4 5 Randall Hyde. "Which Assembler is the Best?". Retrieved 2008-05-18.
  3. "FASMARM". 2008-03-20. Retrieved 2008-05-12.
  4. 1 2 "Interview with Privalov the author of FASM". 2004-08-12. Retrieved 2008-05-12.
  5. Tomasz Grysztar (2000-03-15). "flat assembler". Retrieved 2008-05-19.
  6. "MenuetOS". Retrieved 2008-05-18.
  7. "DexOS FAQ". Retrieved 2008-05-18.
  8. 1 2 3 Tomasz Grysztar. "Flat Assembler Design Principles". Retrieved 2008-05-12.
  9. Tomasz Grysztar. "FA - command line extension for fasm". Retrieved 2012-05-11.

External links

This article is issued from Wikipedia - version of the Saturday, April 16, 2016. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.