#ifndef _SYS_KOBJ_IMPL_H
#define _SYS_KOBJ_IMPL_H
#include <sys/kdi.h>
#include <sys/kobj.h>
#include <sys/varargs.h>
#ifdef __cplusplus
extern "C" {
#endif
#define BA_DYNAMIC 0
#define BA_PHDR 1
#define BA_PHNUM 2
#define BA_PHENT 3
#define BA_ENTRY 4
#define BA_PAGESZ 5
#define BA_LPAGESZ 6
#define BA_LDELF 7
#define BA_LDSHDR 8
#define BA_LDNAME 9
#define BA_BSS 10
#define BA_IFLUSH 11
#define BA_CPU 12
#define BA_MMU 13
#define BA_GOTADDR 14
#define BA_NEXTGOT 15
#define BA_NUM 16
typedef union {
unsigned long ba_val;
void *ba_ptr;
} val_t;
struct proginfo {
uint_t size;
uint_t align;
};
#define KOBJ_EXEC 0x0004
#define KOBJ_INTERP 0x0008
#define KOBJ_PRIM 0x0010
#define KOBJ_RESOLVED 0x0020
#define KOBJ_RELOCATED 0x0080
#define KOBJ_NOPARENTS 0x0200
#define KOBJ_IGNMULDEF 0x0400
#define KOBJ_NOKSYMS 0x0800
#define KOBJ_EXPORTED 0x1000
typedef void kobj_notify_f(uint_t, struct modctl *);
typedef struct kobj_notify_list {
kobj_notify_f *kn_func;
uint_t kn_type;
struct kobj_notify_list *kn_prev;
struct kobj_notify_list *kn_next;
} kobj_notify_list_t;
#define KOBJ_NOTIFY_MODLOADING 1
#define KOBJ_NOTIFY_MODUNLOADING 2
#define KOBJ_NOTIFY_MODLOADED 3
#define KOBJ_NOTIFY_MODUNLOADED 4
#define KOBJ_NOTIFY_MAX 4
#define ALIGN(x, a) ((a) == 0 ? (uintptr_t)(x) : \
(((uintptr_t)(x) + (uintptr_t)(a) - 1l) & ~((uintptr_t)(a) - 1l)))
#ifdef DEBUG
#define KOBJ_DEBUG
#endif
#ifdef KOBJ_DEBUG
#define D_DEBUG 0x001
#define D_SYMBOLS 0x002
#define D_RELOCATIONS 0x004
#define D_LOADING 0x008
extern int kobj_debug;
#endif
#define KM_WAIT 0x0
#define KM_NOWAIT 0x1
#define KM_TMP 0x1000
#define KM_SCRATCH 0x2000
#ifdef KOBJ_OVERRIDES
#define bcopy(s, d, n) kobj_bcopy((s), (d), (n))
#define bzero(p, n) kobj_bzero((p), (n))
#define strlcat(s, d, n) kobj_strlcat((s), (d), (n))
#endif
extern kdi_t kobj_kdi;
struct bootops;
extern struct modctl_list *kobj_linkmaps[];
extern char *kobj_kmdb_argv[];
extern int kobj_mmu_pagesize;
extern void kobj_init(void *romvec, void *dvec,
struct bootops *bootvec, val_t *bootaux);
extern int kobj_notify_add(kobj_notify_list_t *);
extern int kobj_notify_remove(kobj_notify_list_t *);
extern int do_relocations(struct module *);
extern int do_relocate(struct module *, char *, int, int, Addr);
extern struct bootops *ops;
extern void exitto(caddr_t);
extern void kobj_sync_instruction_memory(caddr_t, size_t);
extern uint_t kobj_gethashsize(uint_t);
extern void * kobj_mod_alloc(struct module *, size_t, int, reloc_dest_t *);
extern void mach_alloc_funcdesc(struct module *);
extern uint_t kobj_hash_name(const char *);
extern caddr_t kobj_segbrk(caddr_t *, size_t, size_t, caddr_t);
extern int get_progbits_size(struct module *, struct proginfo *,
struct proginfo *, struct proginfo *);
extern Sym *kobj_lookup_kernel(const char *);
extern struct modctl *kobj_boot_mod_lookup(const char *);
extern void kobj_export_module(struct module *);
extern int kobj_load_primary_module(struct modctl *);
extern int boot_compinfo(int, struct compinfo *);
extern void mach_modpath(char *, const char *);
extern void kobj_setup_standalone_vectors(void);
extern void kobj_restore_vectors(void);
extern void (*_kobj_printf)(void *, const char *fmt, ...) __KPRINTFLIKE(2);
extern void (*_vkobj_printf)(void *, const char *fmt, va_list)
__KVPRINTFLIKE(2);
extern void (*kobj_bcopy)(const void *, void *, size_t);
extern void (*kobj_bzero)(void *, size_t);
extern size_t (*kobj_strlcat)(char *, const char *, size_t);
#define KOBJ_LM_PRIMARY 0x0
#define KOBJ_LM_DEBUGGER 0x1
extern void kobj_lm_append(int, struct modctl *modp);
extern struct modctl_list *kobj_lm_lookup(int);
extern void kobj_lm_dump(int);
#ifdef __cplusplus
}
#endif
#endif