2020-03-26 13:57:37 +01:00
|
|
|
int cc_plus_one_c(int *arg) {
|
|
|
|
return *arg + 1;
|
|
|
|
}
|
2020-03-26 15:05:43 +01:00
|
|
|
|
|
|
|
int cc_plus_one_c_asm(int *arg) {
|
|
|
|
int value = 0;
|
|
|
|
|
|
|
|
asm volatile ( " movl (%1), %0\n"
|
|
|
|
" inc %0\n"
|
|
|
|
" jmp 1f\n"
|
2020-09-25 15:13:55 +02:00
|
|
|
" retq\n" // never executed, but a shortcut to determine how
|
|
|
|
// the assembler deals with `ret` instructions
|
2020-03-26 15:05:43 +01:00
|
|
|
"1:\n"
|
|
|
|
: "=r"(value)
|
|
|
|
: "r"(arg) );
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|