Tool Comparison: Difference between revisions

m
use cite extension
[unchecked revision][unchecked revision]
m (use cite extension)
 
(22 intermediate revisions by 12 users not shown)
Line 22:
! [[GAS]]
| {{Yes}}
| {{Yes}}{{<ref|1}} name="note1" group="Note" />
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{Yes}}{{<ref|2}} name="note2" group="Note" />
| {{Yes}}
| {{Yes}}{{<ref|3}} name="note3" group="Note" />
|-
! [[NASM]]
Line 40:
| {{Yes}}
| {{Yes}}
| {{Yes}}{{<ref|4}} name="note4" group="Note" />
|-
! [[MASMYASM]]
| {{NoYes}}
| {{Yes}}
| {{Yes}}
| {{No}}
| {{No}}
| {{Yes}}
Line 51:
| {{Yes}}
| {{Yes}}
| {{Yes}}{{ref|6}}
|-
! [[YASMFASM]]
| {{YesNo}}
| {{Yes}}
| {{Yes}}
Line 64:
| {{Yes}}
|-
! [[FASMJWASM]]
| {{No}}
| {{Yes}}
| {{Yes}}
| {{No}}
| n/a{{Yes}}
| {{Yes}}
| {{Yes}}
Line 75:
| {{Yes}}
|-
! [[MASM]]<ref name="note5" group="Note" />
! [[JWASM]]
| {{No}}
| {{Yes}}
| {{YesNo}}
| {{No}}
| {{Yes}}
Line 84:
| {{Yes}}
| {{Yes}}
| {{Yes}}<ref name="note6" group="Note" />
|-
! [[Sol_asm]]
| {{No}}
| {{Yes}}{{ref|5}}
| {{Yes}}
| {{No}}
Line 97:
| {{Yes}}
|-
! [[WASMAS86]]
| {{No}}
| {{Yes}}
Line 103:
| {{No}}
| {{No}}
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{No}}
|-
! [[LLVM|llvm-mc]]
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{No}}
| {{No}}
| {{Yes}}
| {{Yes}}
|}
 
<references group="Note">
* {{note|1}} using the <code>.intel_syntax</code> directive. Several opcodes will still use the AT&T name.
<ref name="note1">Using the <code>.intel_syntax</code> directive. Several opcodes will still use the AT&T name.</ref>
* {{note|2}} While GAS normally writes only "pure" 32-bit i386 code, it has [http://sourceware.org/binutils/docs/as/i386_002d16bit.html#i386_002d16bit limited support] for writing code to run in real mode or in 16-bit protected mode code segments.
<ref name="note2">While GAS normally writes only "pure" 32-bit i386 code, it has [http://sourceware.org/binutils/docs/as/i386_002d16bit.html limited support] for writing code to run in real mode or in 16-bit protected mode code segments.</ref>
* {{note|3}} You have to choose the instruction set at compile time. GAS can not assemble for more than one operating mode at a time.
<ref name="note3">You have to choose the instruction set at compile time (of the assembler). GAS can not assemble for more than one operating mode at a time, i.e. you would need one GAS for 32bit and one GAS for 64bit if you'd want to mix those two.</ref>
* {{note|4}} 64-bit support is only available in NASM 2.x.
<ref name="note4">64-bit support is only available in NASM 2.x.</ref>
* {{note|5}} Sol_Asm uses its own syntax, which looks like the Intel syntax.
* {{note|6}}<ref name="note5">64-bit support is only available in a separate executable, named ml64.</ref>
<ref name="note6">Sol_Asm uses its own syntax, which looks like the Intel syntax.</ref>
</references>
 
==Compilers==
Line 121 ⟶ 134:
!
! Extensions
! colspan=78 | Output format
|-
!
Line 130 ⟶ 143:
! [[PE]]
! COFF
! 16-bit code segments
! 32-bit code segments
! 64-bit code segments
|-
! gcc[[GCC]]
| {{Yes}}
| {{Yes}}
| {{Yes}}
Line 139 ⟶ 154:
| {{Yes}}
| {{Yes}}
| ?
| ?
| {{Yes}}
| {{Yes}}
|-
! [[LLVM|Clang]]
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{No}}
| {{Yes}}
| {{Yes}}
| {{No}}
| {{Yes}}
| {{Yes}}
|-
Line 147 ⟶ 173:
| {{No}}
| {{No}}
| {{No}}<ref name="note7" group="Note" />
| {{No}}{{Ref|4}}
| {{Yes}}
| {{Yes}}
| Version 4.X
| {{Yes}}
| {{Yes}}
|-
Line 161 ⟶ 188:
| {{Yes}}
| {{No}}
| {{Yes}}
| {{Yes}}
|-
! [[Watcom]]
! watcom
| {{Yes}}
| {{No}}
Line 172 ⟶ 200:
| {{Yes}}
| {{Yes}}
| {{Yes}}
|-
! [[Smaller C]]
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{No}}
| {{Yes}} (incl. huge & unreal mode(l)s)<ref name="note8" group="Note" />
| {{Yes}}
| {{No}}
|}
 
<references group="Note">
* {{Note|4}} Visual Studio can emit <code>.COM</code> files.
<ref name="note7">Visual Studio can emit <code>.COM</code> files.</ref>
<ref name="note8">Smaller C [https://github.com/alexfru/SmallerC/pull/25#issuecomment-516694067| wasn't really designed to properly support 16-bit and 64-bit CPUs].</ref>
</references>
 
==Linkers==
Line 180 ⟶ 223:
|-
! rowspan=2 | Name
! rowspancolspan=25 | OMF/OBJInput
! colspan=4 | Input
! colspan=5 | Output
! rowspan=2 | Flat Binary Images
Line 189 ⟶ 231:
! rowspan=2 | 32bit Code
|-
! OMF/ OBJ
! Win32/ COFF
! ELF
Line 316 ⟶ 359:
| {{Yes}}
| WATCOM CODEVIEW DWARF
| {{Yes}}
|-
! [[smlrl]]
| {{No}}
| {{No}}
| {{Yes}}
| {{No}}
|
| {{Yes}}
| {{No}}
| {{Yes}}
| {{Yes}}
| DOS/COM DOS/EXE MACH-O
| {{Yes}}
| {{Yes}}
| {{Yes}}
| {{No}}
| {{Yes}}
|-
! [[LLVM|LLD]]
|
| {{Yes}}
| {{Yes}}
|
|
|
|
|
|
|
|
|
| {{Yes}}
|
| {{Yes}}
|}