mirror of
https://github.com/cc65/cc65.git
synced 2024-11-19 06:31:31 +00:00
49 lines
807 B
C
49 lines
807 B
C
|
/*
|
||
|
!!DESCRIPTION!! wrapped-call pragma w/ varags
|
||
|
!!ORIGIN!! cc65 regression tests
|
||
|
!!LICENCE!! Public Domain
|
||
|
!!AUTHOR!! Lauri Kasanen
|
||
|
*/
|
||
|
|
||
|
#include <stdarg.h>
|
||
|
|
||
|
static unsigned char flag;
|
||
|
|
||
|
static void trampoline_set() {
|
||
|
// The Y register is used for variadics - save and restore
|
||
|
asm("sty tmp3");
|
||
|
|
||
|
asm("ldy tmp4");
|
||
|
asm("sty %v", flag);
|
||
|
|
||
|
asm("ldy tmp3");
|
||
|
asm("jsr callptr4");
|
||
|
}
|
||
|
|
||
|
#pragma wrapped-call(push, trampoline_set, 4)
|
||
|
unsigned adder(unsigned char num, ...);
|
||
|
#pragma wrapped-call(pop)
|
||
|
|
||
|
unsigned adder(unsigned char num, ...) {
|
||
|
|
||
|
unsigned char i;
|
||
|
unsigned sum = 0;
|
||
|
va_list ap;
|
||
|
va_start(ap, num);
|
||
|
|
||
|
for (i = 0; i < num; i++) {
|
||
|
sum += va_arg(ap, unsigned);
|
||
|
}
|
||
|
|
||
|
va_end(ap);
|
||
|
|
||
|
return sum;
|
||
|
}
|
||
|
|
||
|
int main() {
|
||
|
|
||
|
flag = 0;
|
||
|
|
||
|
return adder(3, 0, 5, 500) == 505 && flag == 4 ? 0 : 1;
|
||
|
}
|