25-03-2021

FASM (flat assembler) is an assembler for x86 processors. It supports 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. It is a low-level assembler and intentionally uses very few command-line options. It is free and open-source software. Nasm for mac free download. Mingw-w64-dgn drangon's mingw-w64 ( mingw-w64.sf.net ) build, native toolchain and cross toolchain for 32bit windo.

Index>Unix > fasm on MacOS X [Snow Leopard / Lion]
Goto page Previous1, 2
Author
Thread
zab

Joined: 28 May 2012
Posts: 6
zab
Hi guys,
I hope that this thread is still alive!
Following 'Shirk' excellent advices and tips, I successfully built FASM 1.70.02 on my OSX machines (32-bits and 64-bits).
I want to share the binary with everyone interested on programming with FASM under OSX (see USAGE file).
QUESTION for 'Tomasz Grysztar': 'Shrink' provided a patch (fasm-fix-out-of-memory-lion.diff.txt) which allow to compile FASM on OSX. Any chance to get it commited to FASM source code?
Thanks
Zab

Description:FASM (v1.70.02) and OBJCONV (v2.14) binaries.
Allow you compile 32-bits and 64-bits FASM programs on OSX.

Download
Filename:fasm-osx.zip
Filesize:258.3 KB
Downloaded:720 Time(s)

29 May 2012, 21:20
STLVNUB

Joined: 08 Aug 2008
Posts: 13
STLVNUB
30 May 2012, 04:31
Shirk

Joined: 12 Sep 2011
Posts: 10
Shirk
Uh, this got sticky - nice
Apparently I'm back to my pet os project, back to fasm and we still need the patched version.. (checked no path in 1.70.3 or 1.71 previews).
Not sure if Tomasz reads this forum / has interest in the patch but big thanks to zab for providing the binaries!
Maybe someone could mail him?
24 Sep 2012, 17:03
Tomasz Grysztar

Joined: 16 Jun 2003
Posts: 7797
Location: Kraków, Poland
Tomasz Grysztar
I cannot approve such kind of fix. If that one relocation is processed incorrectly then the other relocations also cannot be trusted and it is inherently unsafe to try fixing it this way. One should rather search for the real source of the problem, that is the underlying bug related to relocations - and report it.
24 Sep 2012, 17:21
Shirk

Joined: 12 Sep 2011
Posts: 10
Shirk
Hi Tomasz,
please don't get me wrong - my post was in no way meant to insult anyone.
It was just written in a challenging tone to lure an answer out of you.
I agree that the real fix would be to determine why this one relocation is messed up. If you ask me - it's a flaw in objconv.. I looked through most of the code by now and everything else seems fine. (could be related to different reloc handling in mach-o).
But to be honest - osx or mach-o is nowhere near your target / planned features list and I neither have the time nor the fasm-guts to dig through the whole code to add a mach-o backend. So it looks like mac users are still dependent on this (possibly flawed, however working-fine-so-far) patched binary.
I'm fine with that and most of us can resort back to a VM if hard comes to hard..
so keep the thread sticky and most of us should be happy
Cheers,
Shirk
P.S. - my vote for a fasm mach-o backend
25 Sep 2012, 05:52
STLVNUB

Joined: 08 Aug 2008
Posts: 13
STLVNUB
15 Dec 2012, 20:25
STLVNUB

Joined: 08 Aug 2008
Posts: 13
STLVNUB
Weird, can compile and run fasm.asm with fasm, but try to compile for efi and back to 'out of memory'
15 Dec 2012, 20:55
STLVNUB

Joined: 08 Aug 2008
Posts: 13
STLVNUB
ok changed buffer rb 1000h in fasm.asm to buffer rb 4000h
Now compiles efi
15 Dec 2012, 21:45
STLVNUB

Joined: 08 Aug 2008
Posts: 13
STLVNUB
Just compiled fasm.efi and works
I should note that fast.asm for efi already had buffer set to 4000h
so that appears to be the 'out of memory' bug
15 Dec 2012, 22:12
STLVNUB

Joined: 08 Aug 2008
Posts: 13
STLVNUB
OS X appears to need more buffer space as 1000h leads to 'Out Of Memory' errors and also leads to some examples that have buffer set to 1000h, getting errors too.
Is there a reason why OS X needs bigger buffer space??
Of course, it won't work otherwise.
So set the buffer to 4000h and you can do wonders.
16 Dec 2012, 06:21
STLVNUB

Joined: 08 Aug 2008
Posts: 13
STLVNUB
tools/libc/listing.asm is one example that now works.
As well as compiling fasm and fasm.efi from newest sources.
All this on Mountain Lion.
Anybody interested???

Last edited by STLVNUB on 17 Dec 2012, 20:07; edited 1 time in total
16 Dec 2012, 06:25
KevinN

Joined: 09 Oct 2012
Posts: 161
KevinN
Yep, as soon as my monitor works again.. And if i can get mountain lion up on a custom
16 Dec 2012, 06:44
Fasm for macbook pro
KevinN

Joined: 09 Oct 2012
Posts: 161
KevinN
I've got ML running now.. it might be interesting to get fasm running
I found a few OSX Nasm examples too.. there was a quartz and an OPENGL one.. and a boilerplated hello world
http://michaux.ca/articles/assembly-hello-world-for-os-x
http://forum.nasm.us/index.php?topic=1075.0 (OpenGL)
22 Dec 2012, 16:36
KevinN

Joined: 09 Oct 2012
Posts: 161
KevinN
http://osxbook.com/blog/2009/03/15/crafting-a-tiny-mach-o-executable/
https://gist.github.com/1084476
http://www.feiri.de/macho/
http://seriot.ch/hello_macho.php
looks like others have, and continue to play with macho-o. I think the above examples are good for understanding the bare minimum requirements for a macho32 and macho64. I just nasm assembled the second example off git and it works:

251 bytes on ML! hehe small enough to get to know macho bit by bit and byte by byte
im trying to see if i can get some function out of tinycc on osx with objconv [edit: tinycc can be used same way fasm works with objconvert and ld.. ld adds a lot of weight, probably a lot unnecessary.]

Last edited by KevinN on 02 Jan 2013, 14:53; edited 6 times in total
01 Jan 2013, 23:55
KevinN

Joined: 09 Oct 2012
Posts: 161
KevinN
here are some gui programs used as tools to examine macho:
http://sourceforge.net/projects/machoview/
http://www.affinic.com/?page_id=109
02 Jan 2013, 00:13
KevinN

Joined: 09 Oct 2012
Posts: 161
KevinN
http://opensource.apple.com/release/developer-tools-45/
the source for cctools including ld, otool, as etc
02 Jan 2013, 07:00
Shirk

Joined: 12 Sep 2011
Posts: 10
Shirk
Nice analysis on mach-o so far -- I had a look into a fasm mach-o backend but tbh. couldn't find my way around mach-o 64..
@STLVNUB - the buffer size problems could be a result of things like the additional alignment requirements and other features like these that Xnu enforces.
19 Aug 2013, 10:01
alexfru

Joined: 23 Mar 2014
Posts: 79
alexfru
I'm getting close to declaring official support of Mac OS X in my C compiler and just for the fun of it I made FASM executables out of fasm.o for Linux, Mac OS X and DOS/DPMI.
I used my compiler's C library and two pages of simple asm & C code to translate names (leading underscores are used by default in my compiler), preserve regs (my compiler preserves only the obvious: EBP, ESP) and intercept fopen() (it should really be called with 'rb' and 'wb' and not 'r' and 'w') and gettimeofday() (not implemented in my library, not part of the C standard).
The result seems to be working so far. I compiled a few C apps with my compiler instructed to use FASM in place of NASM.
Btw, the DOS/DPMI version is somewhat 'cleaner' in that it does not try to use unreal mode.
If anyone is interested I could share the code & instructions and the binary(-ies).
16 Oct 2017, 10:22
alexfru

Joined: 23 Mar 2014
Posts: 79
alexfru
So, it looks like my Smaller C compiler is working on Mac OS X 10.6 (Snow Leopard) through Mac OS X 10.12 (Sierra).
Here's how I turn fasm.o into various executables.


Compiling for MacOS:

Compiling for DOS/DPMI:

Compiling for Windows:

My compiler depends on NASM and the above asm code is for NASM, so you should have NASM 2.03 or newer if you want to recompile FASM using Smaller C and the above pieces of code.
Smaller C should work out of the box on Windows and DOS, just include the path to v0100binw or v0100bind in %PATH%.
On Linux and Mac OS X you can simply recompile the compiler, using the usual (you will need NASM already installed):

On Mac you may see an error from readlink, but it should still work.
I'm attaching the binaries.
What else?.. Feel free to poke around the compiler's library source for Mac OS X system calls. Ditto for the linker if you want to make 32-bit Mach-O executables by hand. Or you could just use the linker as-is.

Description:Precompiled FASM 1.71.64 for Windows
Download
Filename:fasmw.exe.zip
Filesize:66.51 KB
Downloaded:479 Time(s)

Description:Precompiled FASM 1.71.64 for DOS/DPMI (will need CWSDPMI)
Download
Filename:fasmdp.exe.zip
Filesize:68.29 KB
Downloaded:473 Time(s)

Description:Precompiled FASM 1.71.64 for Mac OS X
Download
Filename:fasmm.zip
Filesize:58.6 KB
Downloaded:464 Time(s)

18 Oct 2017, 03:44

Goto page Previous1, 2
< Last Thread | Next Thread >
Forum Rules:
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum

FASM
Developer(s)Tomasz Grysztar
Initial releaseMarch 2000; 20 years ago
Stable release
1.73.24 / April 29, 2020; 6 months ago
Operating systemUnix-like, Linux, Windows and IDE, DOS and IDE, OpenBSD, etc., MenuetOS, KolibriOS, OctaOS, DexOS and IDE, SkyOS, Solar_OS
Platformx86, x86-64
TypeAssembler
LicenseSimplified BSD with a weak copyleft clause
Websiteflatassembler.net

Fast For Ac1

FASM (flat assembler) is an assembler for x86 processors. It supports Intel-styleassembly 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. 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[edit]

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).

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.

Design[edit]

FASM 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.[6]

Fasm Macro Example

FASM is a multi-pass assembler. It makes extensive code-size optimization and allows unconstrained forward referencing.[2][6] 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.

FASM is based on the 'same source, same output' principle: the contents of the resulting file are not affected by the command line.[6] 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.[7] FASM projects can be built from one source file directly into an executable file without a linking stage.[2]

IDE[edit]

Fast Formation Card

Fresh, an internet community supported project started by John Found, is an integrated development environment for FASM.[8] Fresh currently supports Microsoft Windows and Linux.[8]

Use[edit]

Operating systems written with FASM:

  • DexOS[9] – by Craig Bamford and the DexOS community
  • MenuetOS[10] – 32- and 64-bit GUI operating systems by Ville Turijanmaa

Compilers that use FASM as a backend:

  • High Level Assembly (HLA)

See also[edit]

References[edit]

Fast format recover
  1. ^Tomasz Grysztar. 'Flat Assembler Programmer's Manual'. Retrieved 2008-05-12.
  2. ^ abcdeRandall Hyde. 'Which Assembler is the Best?'. Retrieved 2008-05-18.
  3. ^'FASMARM'. 2008-03-20. Retrieved 2008-05-12.
  4. ^ ab'Interview with Privalov the author of FASM'. 2004-08-12. Archived from the original on 2007-10-08. Retrieved 2008-05-12.
  5. ^Tomasz Grysztar (2000-03-15). 'flat assembler'. Retrieved 2008-05-19.
  6. ^ abcTomasz Grysztar. 'Flat Assembler Design Principles'. Retrieved 2008-05-12.
  7. ^Tomasz Grysztar. 'FA – command line extension for fasm'. Retrieved 2012-05-11.
  8. ^ ab'Fresh ID project'.
  9. ^'DexOS FAQ'. Archived from the original on 2016-03-03. Retrieved 2008-05-18.
  10. ^'MenuetOS'. Retrieved 2008-05-18.
Fasm mac

External links[edit]

  • FASM project: Official website
  • FASMLIB 0.8.0 – portable 32-bit x86 asm lib for FASM/MASM/YASM/NASM/GASM
  • FASMARM – FASM for ARM processors, v1.27, June 9, 2012
Retrieved from 'https://en.wikipedia.org/w/index.php?title=FASM&oldid=960955381'