A86 | |
Developer: | Eric Isaacson |
Latest Release Version: | 4.05 |
Latest Release Date: | 14 January 2000 |
Operating System: | MS-DOS |
Platform: | x86 |
Genre: | Assembler |
License: | Proprietary |
A86 is an assembler for MS-DOS which generates code for the Intel x86 family of microprocessors. Written by Eric Isaacson, it was first made available as shareware in June 1986. The assembler is contained in one 32K executable and can directly produce a COM file or an object file for use with a standard linker. It comes with a debugger, D86.[1] [2]
While supporting expected x86 syntax, A86 allows simpler shorthand in some cases and does not require directives, such as ASSUME
, SEGMENT
, and PROC
, which Microsoft Macro Assembler and other contemporaries rely on. Speed of assembly is a primary selling point. Isaacson claimed that A86 could assemble 100,000 lines of source per second on a Pentium II or better.[3]
A86 and D86 target 16-bit x86 platforms. Isaacson added 32-bit support in the mid 1990s in the form of A386 and D386.[1] [2] These were not distributed as shareware, but were provided to users who registered A86. The A86 family of products was never ported to Microsoft Windows, but it is possible to use the object files created by A386 with a Windows linker.[4] The assembler does not support 64-bit code.
Any label consisting of one letter followed by one or more digits is local and can be redefined as needed, with each definition replacing the prior. The manual recommends using through for normal code and through in macros. Branches to local labels are assumed to be backward, but a forward branch can be specified by prefixing the label reference with the greater than symbol (e.g.,).
Numbers starting with a zero are hexadecimal, such as, instead of using a prefix such as "0x" or "$". A trailing "K" indicates kibibytes.[5] is the same as 16*1024 or 16384.
Multiple registers can be pushed or popped on the same source line. generates one instruction for each of the three operands.
There's shorthand for conditionally executing a single instruction. outputs two instructions: a conditional branch followed by the move.
If is specified as the label for a conditional branch, it automatically targets a return instruction within the 8-bit branch range (e.g.,).
Macros use a different syntax than contemporaneous assemblers.
The assembler was designed to use particular instruction encodings which are functionally equivalent, but together create a fingerprint that's embedded in the executable file. This is mentioned in the legal terms section of the manual. The fingerprint makes it possible to tell if code was assembled with A86 and also to distinguish between registered and unregistered versions of the assembler. This analysis requires access to the source code.[6]