| Here's the same example in Microsoft Visual C or C++ inline assembly: 
 int foo(void) {Note that now:__asm{
 mov eax,100
 leave
 ret
 };
 }
 
 
The keyword is __asmThe assembly code is wrapped in curly bracesThe destination register is on the *left*, just like yasm. Note also that I've used the "leave" instruction to clean up foo's
stack frame (mov esp,ebp; pop ebp;) before returning.  The compiler secretly generates the
corresponding function prologue at the start of the function.
 Microsoft Outside Variable Access:In Microsoft Visual C or C++, you can read and write variables from the program by just giving their names.
 Simple example:
    void *frame;Complicated example:__asm mov ebp,frame;
 
 
 int foo(void) {This is clearly very convenient!  But what happens if we try to do
the same thing with a variable named "al"?  (Remember, "al" is a
register on x86!)int joe=1234, fred;
 __asm{
 mov eax,joe  ; eax = joe;
 add eax,2    ; eax += 2;
 mov fred,eax ; fred = eax
 };
 return fred;
 }
 | GCC Inline Assembly:Here's an example of how to declare a little assembly snippet inside C or C++ code using the Linux/UNIX/MacOS gcc compiler:
int foo(void) {Note that:__asm__( /* Assembly function body */
 "  mov $100,%eax\n"  /* moves 100 into eax! */
 "  leave\n"
 "  ret\n"
 );
 }
 
 
        I've linked the text to the NetRun version of this code.  Note that
I've set the NetRun "Mode" to "Whole Subroutine"--this keeps NetRun
from pasting in the start and end of the foo subroutine.The keyword is __asm__The assembly code is wrapped in parenthesis.The assembly code shows up as a stringThere are weird symbols in front of constants ($ means constant) and registers (% means register)DYSLEXIA ALERT: GCC sasembly is abckwards.  The destination register goes at the *end* of the instruction.
 
 The bottom line is just to use the __asm__ keyword, which takes the assembly code as a big string.
 
 GCC Outside Variable Access:Accessing outside variables is truly hideous in gcc inline assembly.
 Simple example:
     void *frame; /* Frame pointer */Complicated example:__asm__ ("mov %%ebp,%0":"=r"(frame));
 
 
 int foo(void) {The __asm__ keyword can take up to four strings, separated by colons:int joe=1234, fred;
 __asm__(
 "  mov %1,%%eax\n"
 "  add $2,%%eax\n"
 "  mov %%eax,%0\n"
 :"=r" (fred) /* %0: Out */
 :"r" (joe) /* %1: In */
 :"%eax" /* Overwrite */
 );
 return fred;
 }
 
 
See page 227 of the text for more details, or the gcc manual for so many hideous details you'll want to cry.The assembly code.  Now registers need to be prefixed with "%%", not just "%", to distinguish them from arguments.
A comma-separated list of output arguments.  These can go into registers ("=r"), memory ("=m"), etc.
A comma-separated list of input arguments.A comma-separated list of overwritten registers ("trashed"
registers).  The compiler then knows not to put anything important
in these registers. 
 GCC Whole Subroutine in AssemblyPartly because GCC's inline assembly syntax is so horrible, it's often
easier to just write the whole subroutine (argument access, frame
setup, and value return) in assembly.  There doesn't seem to be a
way to do this in Visual C++, although (in either case) it's easy
enough to separately compile a whole file full of pure assembly code
and just link it in.
 To write a subroutine in assembly, just:
 
 
Here's a complete example, where my assembly subroutine just returns 100:Write a C function prototype.  In C++, make the prototype 'extern "C"' to avoid a link error.
Put your code in an "__asm__" block outside any subroutine.Put the subroutine name at the start of the assembly block as a label.If you want to call the subroutine from outside that file, use ".globl my_sub" to make the subroutine's name visible outside. 
 extern "C" int my_sub(void); /* Prototype */This is actually a pretty clean way to do inline assembly in gcc,
although you do have to remember the calling convention to find your
arguments!  (Hint: the first argument is at 4(%esp) if you don't
have a stack frame; 8(%ebp) if you do...)
 __asm__( /* Assembly function body */
 "my_sub:\n"
 "  mov $100,%eax\n"
 "  ret\n"
 );
 
 int foo(void) {
 return my_sub()+1;
 }
 
 
 |