summaryrefslogtreecommitdiff
path: root/src/cmd/8l/asm.c
diff options
context:
space:
mode:
authorDevon H. O'Dell <devon.odell@gmail.com>2009-11-17 23:58:51 -0800
committerDevon H. O'Dell <devon.odell@gmail.com>2009-11-17 23:58:51 -0800
commitcba2fe2462fda1fe7b265f8056a89e6f6e06e938 (patch)
tree9f74efdaa20cae5f6501fd3fe6e50ced586dcfe9 /src/cmd/8l/asm.c
parentdaab757a6fa77ff08a76fa1307a0c5f1f15e5c42 (diff)
downloadgolang-cba2fe2462fda1fe7b265f8056a89e6f6e06e938.tar.gz
FreeBSD/i386 work
This patchset gets Go to pretty much the same state that FreeBSD/amd64 is in. R=rsc http://codereview.appspot.com/157055 Committer: Russ Cox <rsc@golang.org>
Diffstat (limited to 'src/cmd/8l/asm.c')
-rw-r--r--src/cmd/8l/asm.c22
1 files changed, 19 insertions, 3 deletions
diff --git a/src/cmd/8l/asm.c b/src/cmd/8l/asm.c
index 7f101b74e..e496672e5 100644
--- a/src/cmd/8l/asm.c
+++ b/src/cmd/8l/asm.c
@@ -36,6 +36,7 @@
#define Dbufslop 100
char linuxdynld[] = "/lib/ld-linux.so.2";
+char freebsddynld[] = "/usr/libexec/ld-elf.so.1";
uint32 symdatva = 0x99<<24;
int32
@@ -273,7 +274,7 @@ doelf(void)
Sym *s, *shstrtab, *dynamic, *dynstr, *d;
int h, nsym, t;
- if(HEADTYPE != 7 && HEADTYPE != 8)
+ if(HEADTYPE != 7 && HEADTYPE != 8 && HEADTYPE != 9)
return;
/* predefine strings we need for section headers */
@@ -303,7 +304,14 @@ doelf(void)
s = lookup(".interp", 0);
s->reachable = 1;
s->type = SDATA; // TODO: rodata
- addstring(lookup(".interp", 0), linuxdynld);
+ switch(HEADTYPE) {
+ case 7:
+ addstring(lookup(".interp", 0), linuxdynld);
+ break;
+ case 9:
+ addstring(lookup(".interp", 0), freebsddynld);
+ break;
+ }
/*
* hash table - empty for now.
@@ -527,6 +535,7 @@ asmb(void)
break;
case 7:
case 8:
+ case 9:
v = rnd(HEADR+textsize, INITRND);
seek(cout, v, 0);
break;
@@ -583,6 +592,7 @@ asmb(void)
break;
case 7:
case 8:
+ case 9:
symo = rnd(HEADR+textsize, INITRND)+datsize;
symo = rnd(symo, INITRND);
break;
@@ -752,6 +762,7 @@ asmb(void)
case 7:
case 8:
+ case 9:
/* elf 386 */
if(HEADTYPE == 8)
debug['d'] = 1;
@@ -975,10 +986,15 @@ asmb(void)
eh->ident[EI_CLASS] = ELFCLASS32;
eh->ident[EI_DATA] = ELFDATA2LSB;
eh->ident[EI_VERSION] = EV_CURRENT;
- if(HEADTYPE == 8) {
+ switch(HEADTYPE) {
+ case 8:
eh->ident[EI_OSABI] = ELFOSABI_NACL;
eh->ident[EI_ABIVERSION] = 6;
eh->flags = 0x200000; // aligned mod 32
+ break;
+ case 9:
+ eh->ident[EI_OSABI] = 9;
+ break;
}
eh->type = ET_EXEC;