The x86 wiki (which I just updated again :) has links to the system call ABI (what the numbers are for every call, where to put the params, what instruction to run, and which registers will clobbered on return). This is not documented in the man page because it's architecture-specific. Same for binary constants: they don't have to be the same on every architecture.
grep -r O_APPEND /usr/include
for your target architecture to recursively search the .h
files.
Even better is to set things up so you can use the symbolic constants in your asm source, for readability and to avoid the risk of errors.
The gcc actually does use the C Preprocessor when processing .S
files, but including most C header files will also get you some C prototypes.
Or convert the #define
s to NASM macros with sed
or something. Maybe feed some #include<>
lines to the C preprocessor and have it print out just the macro definitions.
printf '#include <%s>\n' unistd.h sys/stat.h |
gcc -dD -E - |
sed -ne 's/^#define \([A-Za-z_0-9]*\) \(.\)/\1\tequ \2/p'
That turns every non-empty #define
into a NASM symbol equ value
. The resulting file has many lines of error: expression syntax error
when I tried to run NASM on it, but manually selecting some valid lines from that may work.
Some constants are defined in multiple steps, e.g. #define S_IRGRP (S_IRUSR >> 3)
. This might or might not work when converted to NASM equ
symbol definitions.
Also note that in C 0666
, is an octal constant. In NASM, you need either 0o666
or 666o
; a leading 0 is not special. Otherwise, NASM syntax for hex and decimal constants is compatible with C.
const char*
would just be the address of a NUL-terminated string. – Michaelman
from the terminal. The system calls are in section 2 of the man pages, so e.g. to view the man page foropen
you'd runman 2 open
in a terminal. – Michael