ref: f5f5501c8ea833e2e40f4de72b733c4b50fe86dd
dir: /src/cmd/ld/symbol.c/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <scc/mach.h>
#include <scc/scc.h>
#include "ld.h"
#define NR_SYMBOL 128
static Symbol *symtab[NR_SYMBOL];
static Symbol refhead = {
.next = &refhead,
.prev = &refhead,
};
Symbol *
lookup(char *name)
{
unsigned h;
Symbol *sym;
h = genhash(name) % NR_SYMBOL;
for (sym = symtab[h]; sym; sym = sym->hash) {
if (!strcmp(name, sym->name))
return sym;
}
return NULL;
}
Symbol *
install(char *name)
{
unsigned h;
size_t len;
Symbol *sym;
char *s;
h = genhash(name) % NR_SYMBOL;
len = strlen(name) + 1;
sym = malloc(sizeof(*sym));
s = malloc(len);
if (!len || !s) {
error("out of memory");
exit(EXIT_FAILURE);
}
sym->obj = NULL;
sym->name = memcpy(s, name, len);
sym->hash = symtab[h];
symtab[h] = sym;
sym->value = 0;
sym->size = 0;
refhead.next->prev = sym;
sym->next = refhead.next;
refhead.next = sym;
sym->prev = &refhead;
return sym;
}
int
moreundef(void)
{
return refhead.next != &refhead;
}
void
listundef(void)
{
Symbol *sym, *p;
p = &refhead;
for (sym = p->next; sym != p; sym = sym->next) {
fprintf(stderr,
"ld: symbol '%s' not defined\n",
sym->name);
}
}
int
defasym(Obj *obj)
{
Symbol *sym, *p;
p = &refhead;
for (sym = p->next; sym != p; sym = sym->next) {
if (objlookup(obj, sym->name, 0))
return 1;
}
return 0;
}
#ifndef NDEBUG
int
debugsym(void)
{
Symbol **symp, *sym;
for (symp = symtab; symp < &symtab[NR_SYMBOL]; symp++) {
for (sym = *symp; sym; sym = sym->hash)
fprintf(stderr,
"sym: %s (%#x)\n",
sym->name,
sym->value);
}
}
#endif