📄 nasmdoc.src
字号:
\# $Id: nasmdoc.src,v 1.77 2003/08/29 19:25:46 hpa Exp $\#\# Source code to NASM documentation\#\M{category}{Programming}\M{title}{NASM - The Netwide Assembler}\M{year}{2003}\M{author}{The NASM Development Team}\M{license}{All rights reserved. This document is redistributable under the licence given in the file "COPYING" distributed in the NASM archive.}\M{summary}{This file documents NASM, the Netwide Assembler: an assembler targetting the Intel x86 series of processors, with portable source.}\M{infoname}{NASM}\M{infofile}{nasm}\M{infotitle}{The Netwide Assembler for x86}\M{epslogo}{nasmlogo.eps}\IR{-D} \c{-D} option\IR{-E} \c{-E} option\IR{-F} \c{-F} option\IR{-I} \c{-I} option\IR{-M} \c{-M} option\IR{-On} \c{-On} option\IR{-P} \c{-P} option\IR{-U} \c{-U} option\IR{-X} \c{-X} option\IR{-a} \c{-a} option\IR{-d} \c{-d} option\IR{-e} \c{-e} option\IR{-f} \c{-f} option\IR{-g} \c{-g} option\IR{-i} \c{-i} option\IR{-l} \c{-l} option\IR{-o} \c{-o} option\IR{-p} \c{-p} option\IR{-s} \c{-s} option\IR{-u} \c{-u} option\IR{-v} \c{-v} option\IR{-w} \c{-w} option\IR{-y} \c{-y} option\IR{!=} \c{!=} operator\IR{$, here} \c{$}, Here token\IR{$, prefix} \c{$}, prefix\IR{$$} \c{$$} token\IR{%} \c{%} operator\IR{%%} \c{%%} operator\IR{%+1} \c{%+1} and \c{%-1} syntax\IA{%-1}{%+1}\IR{%0} \c{%0} parameter count\IR{&} \c{&} operator\IR{&&} \c{&&} operator\IR{*} \c{*} operator\IR{..@} \c{..@} symbol prefix\IR{/} \c{/} operator\IR{//} \c{//} operator\IR{<} \c{<} operator\IR{<<} \c{<<} operator\IR{<=} \c{<=} operator\IR{<>} \c{<>} operator\IR{=} \c{=} operator\IR{==} \c{==} operator\IR{>} \c{>} operator\IR{>=} \c{>=} operator\IR{>>} \c{>>} operator\IR{?} \c{?} MASM syntax\IR{^} \c{^} operator\IR{^^} \c{^^} operator\IR{|} \c{|} operator\IR{||} \c{||} operator\IR{~} \c{~} operator\IR{%$} \c{%$} and \c{%$$} prefixes\IA{%$$}{%$}\IR{+ opaddition} \c{+} operator, binary\IR{+ opunary} \c{+} operator, unary\IR{+ modifier} \c{+} modifier\IR{- opsubtraction} \c{-} operator, binary\IR{- opunary} \c{-} operator, unary\IR{alignment, in bin sections} alignment, in \c{bin} sections\IR{alignment, in elf sections} alignment, in \c{elf} sections\IR{alignment, in win32 sections} alignment, in \c{win32} sections\IR{alignment, of elf common variables} alignment, of \c{elf} commonvariables\IR{alignment, in obj sections} alignment, in \c{obj} sections\IR{a.out, bsd version} \c{a.out}, BSD version\IR{a.out, linux version} \c{a.out}, Linux version\IR{autoconf} Autoconf\IR{bin} bin\IR{bitwise and} bitwise AND\IR{bitwise or} bitwise OR\IR{bitwise xor} bitwise XOR\IR{block ifs} block IFs\IR{borland pascal} Borland, Pascal\IR{borland's win32 compilers} Borland, Win32 compilers\IR{braces, after % sign} braces, after \c{%} sign\IR{bsd} BSD\IR{c calling convention} C calling convention\IR{c symbol names} C symbol names\IA{critical expressions}{critical expression}\IA{command line}{command-line}\IA{case sensitivity}{case sensitive}\IA{case-sensitive}{case sensitive}\IA{case-insensitive}{case sensitive}\IA{character constants}{character constant}\IR{common object file format} Common Object File Format\IR{common variables, alignment in elf} common variables, alignmentin \c{elf}\IR{common, elf extensions to} \c{COMMON}, \c{elf} extensions to\IR{common, obj extensions to} \c{COMMON}, \c{obj} extensions to\IR{declaring structure} declaring structures\IR{default-wrt mechanism} default-\c{WRT} mechanism\IR{devpac} DevPac\IR{djgpp} DJGPP\IR{dll symbols, exporting} DLL symbols, exporting\IR{dll symbols, importing} DLL symbols, importing\IR{dos} DOS\IR{dos archive} DOS archive\IR{dos source archive} DOS source archive\IA{effective address}{effective addresses}\IA{effective-address}{effective addresses}\IR{elf} ELF\IR{elf, 16-bit code and} ELF, 16-bit code and\IR{elf shared libraries} ELF, shared libraries\IR{executable and linkable format} Executable and Linkable Format\IR{extern, obj extensions to} \c{EXTERN}, \c{obj} extensions to\IR{freebsd} FreeBSD\IR{freelink} FreeLink\IR{functions, c calling convention} functions, C calling convention\IR{functions, pascal calling convention} functions, Pascal callingconvention\IR{global, aoutb extensions to} \c{GLOBAL}, \c{aoutb} extensions to\IR{global, elf extensions to} \c{GLOBAL}, \c{elf} extensions to\IR{global, rdf extensions to} \c{GLOBAL}, \c{rdf} extensions to\IR{got} GOT\IR{got relocations} \c{GOT} relocations\IR{gotoff relocation} \c{GOTOFF} relocations\IR{gotpc relocation} \c{GOTPC} relocations\IR{intel number formats} Intel number formats\IR{linux, elf} Linux, ELF\IR{linux, a.out} Linux, \c{a.out}\IR{linux, as86} Linux, \c{as86}\IR{logical and} logical AND\IR{logical or} logical OR\IR{logical xor} logical XOR\IR{masm} MASM\IA{memory reference}{memory references}\IR{minix} Minix\IA{misc directory}{misc subdirectory}\IR{misc subdirectory} \c{misc} subdirectory\IR{microsoft omf} Microsoft OMF\IR{mmx registers} MMX registers\IA{modr/m}{modr/m byte}\IR{modr/m byte} ModR/M byte\IR{ms-dos} MS-DOS\IR{ms-dos device drivers} MS-DOS device drivers\IR{multipush} \c{multipush} macro\IR{nasm version} NASM version\IR{netbsd} NetBSD\IR{omf} OMF\IR{openbsd} OpenBSD\IR{operating system} operating system\IR{os/2} OS/2\IR{pascal calling convention}Pascal calling convention\IR{passes} passes, assembly\IR{perl} Perl\IR{pic} PIC\IR{pharlap} PharLap\IR{plt} PLT\IR{plt} \c{PLT} relocations\IA{pre-defining macros}{pre-define}\IA{preprocessor expressions}{preprocessor, expressions}\IA{preprocessor loops}{preprocessor, loops}\IA{preprocessor variables}{preprocessor, variables}\IA{rdoff subdirectory}{rdoff}\IR{rdoff} \c{rdoff} subdirectory\IR{relocatable dynamic object file format} Relocatable DynamicObject File Format\IR{relocations, pic-specific} relocations, PIC-specific\IA{repeating}{repeating code}\IR{section alignment, in elf} section alignment, in \c{elf}\IR{section alignment, in bin} section alignment, in \c{bin}\IR{section alignment, in obj} section alignment, in \c{obj}\IR{section alignment, in win32} section alignment, in \c{win32}\IR{section, elf extensions to} \c{SECTION}, \c{elf} extensions to\IR{section, win32 extensions to} \c{SECTION}, \c{win32} extensions to\IR{segment alignment, in bin} segment alignment, in \c{bin}\IR{segment alignment, in obj} segment alignment, in \c{obj}\IR{segment, obj extensions to} \c{SEGMENT}, \c{elf} extensions to\IR{segment names, borland pascal} segment names, Borland Pascal\IR{shift command} \c{shift} command\IA{sib}{sib byte}\IR{sib byte} SIB byte\IR{solaris x86} Solaris x86\IA{standard section names}{standardised section names}\IR{symbols, exporting from dlls} symbols, exporting from DLLs\IR{symbols, importing from dlls} symbols, importing from DLLs\IR{test subdirectory} \c{test} subdirectory\IR{tlink} \c{TLINK}\IR{underscore, in c symbols} underscore, in C symbols\IR{unix} Unix\IA{sco unix}{unix, sco}\IR{unix, sco} Unix, SCO\IA{unix source archive}{unix, source archive}\IR{unix, source archive} Unix, source archive\IA{unix system v}{unix, system v}\IR{unix, system v} Unix, System V\IR{unixware} UnixWare\IR{val} VAL\IR{version number of nasm} version number of NASM\IR{visual c++} Visual C++\IR{www page} WWW page\IR{win32} Win32\IR{windows} Windows\IR{windows 95} Windows 95\IR{windows nt} Windows NT\# \IC{program entry point}{entry point, program}\# \IC{program entry point}{start point, program}\# \IC{MS-DOS device drivers}{device drivers, MS-DOS}\# \IC{16-bit mode, versus 32-bit mode}{32-bit mode, versus 16-bit mode}\# \IC{c symbol names}{symbol names, in C}\C{intro} Introduction\H{whatsnasm} What Is NASM?The Netwide Assembler, NASM, is an 80x86 assembler designed forportability and modularity. It supports a range of object fileformats, including Linux and \c{NetBSD/FreeBSD} \c{a.out}, \c{ELF}, \c{COFF}, Microsoft 16-bit \c{OBJ} and \c{Win32}. It will also outputplain binary files. Its syntax is designed to be simple and easy tounderstand, similar to Intel's but less complex. It supports \c{Pentium},\c{P6}, \c{MMX}, \c{3DNow!}, \c{SSE} and \c{SSE2} opcodes, and hasmacro capability.\S{yaasm} Why Yet Another Assembler?The Netwide Assembler grew out of an idea on \i\c{comp.lang.asm.x86}(or possibly \i\c{alt.lang.asm} - I forget which), which wasessentially that there didn't seem to be a good \e{free} x86-seriesassembler around, and that maybe someone ought to write one.\b \i\c{a86} is good, but not free, and in particular you don't get any32-bit capability until you pay. It's DOS only, too.\b \i\c{gas} is free, and ports over DOS and Unix, but it's notvery good, since it's designed to be a back end to \i\c{gcc}, whichalways feeds it correct code. So its error checking is minimal. Also,its syntax is horrible, from the point of view of anyone trying toactually \e{write} anything in it. Plus you can't write 16-bit code init (properly).\b \i\c{as86} is Minix- and Linux-specific, and (my version at least)doesn't seem to have much (or any) documentation.\b \i\c{MASM} isn't very good, and it's (was) expensive, and it runs only underDOS.\b \i\c{TASM} is better, but still strives for MASM compatibility,which means millions of directives and tons of red tape. And its syntaxis essentially MASM's, with the contradictions and quirks thatentails (although it sorts out some of those by means of Ideal mode).It's expensive too. And it's DOS-only.So here, for your coding pleasure, is NASM. At present it'sstill in prototype stage - we don't promise that it can outperformany of these assemblers. But please, \e{please} send us bug reports,fixes, helpful information, and anything else you can get your handson (and thanks to the many people who've done this already! You allknow who you are), and we'll improve it out of all recognition.Again.\S{legal} Licence ConditionsPlease see the file \c{COPYING}, supplied as part of any NASMdistribution archive, for the \i{licence} conditions under which youmay use NASM. NASM is now under the so-called GNU Lesser GeneralPublic License, LGPL.\H{contact} Contact InformationThe current version of NASM (since about 0.98.08) are maintained by ateam of developers, accessible through the \c{nasm-devel} mailing list(see below for the link).If you want to report a bug, please read \k{bugs} first.NASM has a \i{WWW page} at\W{http://nasm.sourceforge.net}\c{http://nasm.sourceforge.net}. If it'snot there, google for us!The original authors are \i{e\-mail}able as\W{mailto:jules@dsf.org.uk}\c{jules@dsf.org.uk} and\W{mailto:anakin@pobox.com}\c{anakin@pobox.com}.The latter is no longer involved in the development team.\i{New releases} of NASM are uploaded to the official sites\W{http://nasm.sourceforge.net}\c{http://nasm.sourceforge.net}and to\W{ftp://ftp.kernel.org/pub/software/devel/nasm/}\i\c{ftp.kernel.org}and\W{ftp://ibiblio.org/pub/Linux/devel/lang/assemblers/}\i\c{ibiblio.org}.Announcements are posted to\W{news:comp.lang.asm.x86}\i\c{comp.lang.asm.x86},\W{news:alt.lang.asm}\i\c{alt.lang.asm} and\W{news:comp.os.linux.announce}\i\c{comp.os.linux.announce}If you want information about NASM beta releases, and the currentdevelopment status, please subscribe to the \i\c{nasm-devel} email listby registering at\W{http://sourceforge.net/projects/nasm}\c{http://sourceforge.net/projects/nasm}.\H{install} Installation\S{instdos} \i{Installing} NASM under MS-\i{DOS} or WindowsOnce you've obtained the \i{DOS archive} for NASM, \i\c{nasmXXX.zip}(where \c{XXX} denotes the version number of NASM contained in thearchive), unpack it into its own directory (for example \c{c:\\nasm}).The archive will contain four executable files: the NASM executablefiles \i\c{nasm.exe} and \i\c{nasmw.exe}, and the NDISASM executablefiles \i\c{ndisasm.exe} and \i\c{ndisasmw.exe}. In each case, the
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -