+2007-10-18 Maarten Brock <sourceforge.brock AT dse.nl>
+
+ * support/regression/tests/using.c: new, added
+ * support/regression/tests/vaargs.c: fixed and enabled test
+
2007-10-18 Borut Razem <borut.razem AT siol.net>
* src/SDCCglue.c: fixed bug #983491 - Merge duplicate strings function
--- /dev/null
+/** Test register bank allocation for the "using" keyword.
+ using: no_proto, impl, both
+*/
+#include <testfwk.h>
+
+#define _{using}
+
+#if defined (SDCC_mcs51) && defined (SDCC_MODEL_SMALL)
+
+ #ifndef _no_proto
+ #if defined (_both)
+ void my_isr (void) interrupt (1) using (1);
+ #else
+ void my_isr (void) interrupt (1);
+ #endif
+ #endif
+
+ data char array[8];
+
+ void my_isr (void) interrupt (1) using (1)
+ {
+ array[array[0]] = 1; //generate some register pressure
+ }
+
+#endif
+
+void testUsing (void)
+{
+#if defined (SDCC_mcs51) && defined (SDCC_MODEL_SMALL)
+ ASSERT ((unsigned char)(&array[0]) >= 0x10);
+ ASSERT ((unsigned char)&__numTests >= 0x10);
+#endif
+}
}
void
-disabled_testArgs(void)
+testArgs(void)
{
int marker = 12;
ASSERT(returnSecondArg(marker, ({type1})1, ({type2})-23, ({type3})64) == -23);
ASSERT(returnSecondArg(marker, ({type1})1, ({type2})8, ({type3})64) == 8);
- ASSERT(returnThirdArg(marker, -33, -34, -35) == -35);
- ASSERT(returnThirdArg(marker, -33, -34, 35) == 35);
+ ASSERT(returnThirdArg(marker, ({type1})-33, ({type2})-34, ({type3})-35) == -35);
+ ASSERT(returnThirdArg(marker, ({type1})-33, ({type2})-34, ({type3})35) == 35);
}