aboutsummaryrefslogtreecommitdiff
path: root/modules/objfmts/macho/tests/nasm32/machotest.c
diff options
context:
space:
mode:
Diffstat (limited to 'modules/objfmts/macho/tests/nasm32/machotest.c')
-rw-r--r--modules/objfmts/macho/tests/nasm32/machotest.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/modules/objfmts/macho/tests/nasm32/machotest.c b/modules/objfmts/macho/tests/nasm32/machotest.c
new file mode 100644
index 0000000..42fc92c
--- /dev/null
+++ b/modules/objfmts/macho/tests/nasm32/machotest.c
@@ -0,0 +1,45 @@
+/*
+ * test source file for assembling to ELF
+ * copied from cofftest.c; s/coff/elf/g
+ * build with (under Linux, for example):
+ * yasm -f elf elftest.asm
+ * gcc -o elftest elftest.c elftest.o
+ */
+
+#include <stdio.h>
+
+extern int lrotate(long, int);
+extern void greet(void);
+extern char asmstr[];
+extern void *selfptr;
+extern void *textptr;
+extern int integer, commvar;
+
+int main(void) {
+
+ printf("Testing lrotate: should get 0x00400000, 0x00000001\n");
+ printf("lrotate(0x00040000, 4) = 0x%08lx\n", lrotate(0x40000,4));
+ printf("lrotate(0x00040000, 14) = 0x%08lx\n", lrotate(0x40000,14));
+
+ printf("This string should read `hello, world': `%s'\n", asmstr);
+
+ printf("The integers here should be 1234, 1235 and 4321:\n");
+ integer = 1234;
+ commvar = 4321;
+ greet();
+
+ printf("These pointers should be equal: %p and %p\n",
+ &greet, textptr);
+
+ printf("So should these: %p and %p\n", selfptr, &selfptr);
+}
+
+/*
+ there is no support for dynamically linkable objects in current
+ mach-o module. Therefore put "printf" statement here and redirect
+ the asm call to druck()
+*/
+void druck( char *string, int a, int b, int c )
+{
+ printf(string,a,b,c);
+}