#ifndef _BOOTSTRAP_H_
#define _BOOTSTRAP_H_
#include <sys/types.h>
#include <sys/queue.h>
#include <sys/linker_set.h>
#include <stdbool.h>
typedef int (bootblk_cmd_t)(int argc, char *argv[]);
#define COMMAND_ERRBUFSZ (256)
extern const char *command_errmsg;
extern char command_errbuf[COMMAND_ERRBUFSZ];
#define CMD_OK 0
#define CMD_WARN 1
#define CMD_ERROR 2
#define CMD_CRIT 3
#define CMD_FATAL 4
void interact(const char *rc);
int include(const char *filename);
char *backslash(char *str);
int parse(int *argc, char ***argv, char *str);
void bf_init(char *rc);
int bf_run(char *line);
int autoboot(int timeout, char *prompt);
void autoboot_maybe(void);
int getrootmount(char *rootdev);
char *unargv(int argc, char *argv[]);
void hexdump(caddr_t region, size_t len);
size_t strlenout(vm_offset_t str);
char *strdupout(vm_offset_t str);
void kern_bzero(vm_offset_t dest, size_t len);
int kern_pread(int fd, vm_offset_t dest, size_t len, off_t off);
void *alloc_pread(int fd, off_t off, size_t len);
void bcache_init(size_t nblks, size_t bsize);
void bcache_add_dev(int);
void *bcache_allocate(void);
void bcache_free(void *);
int bcache_strategy(void *devdata, int rw, daddr_t blk,
size_t size, char *buf, size_t *rsize);
struct bcache_devdata
{
int (*dv_strategy)(void *devdata, int rw, daddr_t blk,
size_t size, char *buf, size_t *rsize);
void *dv_devdata;
void *dv_cache;
};
struct console
{
char *c_name;
char *c_desc;
int c_flags;
#define C_PRESENTIN (1<<0)
#define C_PRESENTOUT (1<<1)
#define C_ACTIVEIN (1<<2)
#define C_ACTIVEOUT (1<<3)
#define C_WIDEOUT (1<<4)
#define C_MODERAW (1<<5)
void (*c_probe)(struct console *);
int (*c_init)(struct console *, int);
void (*c_out)(struct console *, int);
int (*c_in)(struct console *);
int (*c_ready)(struct console *);
int (*c_ioctl)(struct console *, int, void *);
void (*c_devinfo)(struct console *);
void *c_private;
};
struct console_template {
struct console *ct_dev;
void (*ct_init)(void);
};
extern struct console_template ct_list[];
extern struct console **consoles;
uint_t cons_array_size(void);
int cons_inputdev(void);
void cons_probe(void);
void cons_mode(int);
struct console *cons_get_console(const char *);
void autoload_font(bool);
struct pnphandler
{
const char *pp_name;
void (*pp_enumerate)(void);
};
struct pnpident
{
char *id_ident;
STAILQ_ENTRY(pnpident) id_link;
};
struct pnpinfo
{
char *pi_desc;
int pi_revision;
char *pi_module;
int pi_argc;
char **pi_argv;
struct pnphandler *pi_handler;
STAILQ_HEAD(, pnpident) pi_ident;
STAILQ_ENTRY(pnpinfo) pi_link;
};
STAILQ_HEAD(pnpinfo_stql, pnpinfo);
extern struct pnphandler *pnphandlers[];
void pnp_addident(struct pnpinfo *pi, char *ident);
struct pnpinfo *pnp_allocinfo(void);
void pnp_freeinfo(struct pnpinfo *pi);
void pnp_addinfo(struct pnpinfo *pi);
char *pnp_eisaformat(uint8_t *data);
extern int isapnp_readport;
extern char bootprog_info[];
struct file_metadata
{
size_t md_size;
uint16_t md_type;
struct file_metadata *md_next;
char md_data[1];
};
struct preloaded_file;
struct mod_depend;
struct kernel_module
{
char *m_name;
int m_version;
char *m_args;
struct preloaded_file *m_fp;
struct kernel_module *m_next;
};
struct preloaded_file
{
char *f_name;
char *f_type;
char *f_args;
struct file_metadata *f_metadata;
int f_loader;
vm_offset_t f_addr;
size_t f_size;
struct kernel_module *f_modules;
struct preloaded_file *f_next;
};
struct file_format
{
int (*l_load)(char *, uint64_t, struct preloaded_file **);
int (*l_exec)(struct preloaded_file *);
};
extern struct file_format *file_formats[];
extern struct preloaded_file *preloaded_files;
int mod_load(char *name, struct mod_depend *verinfo, int argc, char *argv[]);
int mod_loadkld(const char *name, int argc, char *argv[]);
void unload(void);
struct preloaded_file *file_alloc(void);
struct preloaded_file *file_findfile(const char *name, const char *type);
struct file_metadata *file_findmetadata(struct preloaded_file *fp, int type);
struct preloaded_file *file_loadraw(const char *name, char *type, int argc,
char **argv, int insert);
void file_discard(struct preloaded_file *fp);
void file_addmetadata(struct preloaded_file *, int, size_t, void *);
int file_addmodule(struct preloaded_file *, char *, int,
struct kernel_module **);
void build_environment_module(void);
void build_font_module(void);
vm_offset_t bi_copyenv(vm_offset_t);
#ifdef __elfN
#define ELF_RELOC_REL 1
#define ELF_RELOC_RELA 2
extern uint64_t __elfN(relocation_offset);
struct elf_file;
typedef Elf_Addr(symaddr_fn)(struct elf_file *, Elf_Size);
int elf64_loadfile(char *, uint64_t, struct preloaded_file **);
int elf32_loadfile(char *, uint64_t, struct preloaded_file **);
int elf64_obj_loadfile(char *, uint64_t, struct preloaded_file **);
int elf32_obj_loadfile(char *, uint64_t, struct preloaded_file **);
int __elfN(reloc)(struct elf_file *ef, symaddr_fn *symaddr,
const void *reldata, int reltype, Elf_Addr relbase,
Elf_Addr dataaddr, void *data, size_t len);
int elf64_loadfile_raw(char *, uint64_t, struct preloaded_file **, int);
int elf32_loadfile_raw(char *, uint64_t, struct preloaded_file **, int);
int elf64_load_modmetadata(struct preloaded_file *, uint64_t);
int elf32_load_modmetadata(struct preloaded_file *, uint64_t);
#endif
struct bootblk_command
{
const char *c_name;
const char *c_desc;
bootblk_cmd_t *c_fn;
};
#define COMMAND_SET(tag, key, desc, func) \
static bootblk_cmd_t func; \
static struct bootblk_command _cmd_ ## tag = { key, desc, func }; \
DATA_SET(Xcommand_set, _cmd_ ## tag)
SET_DECLARE(Xcommand_set, struct bootblk_command);
struct arch_switch
{
int (*arch_autoload)(void);
int (*arch_getdev)(void **dev, const char *name, const char **path);
ssize_t (*arch_copyin)(const void *src, vm_offset_t dest,
const size_t len);
ssize_t (*arch_copyout)(const vm_offset_t src, void *dest,
const size_t len);
ssize_t (*arch_readin)(const int fd, vm_offset_t dest,
const size_t len);
int (*arch_isainb)(int port);
void (*arch_isaoutb)(int port, int value);
vm_offset_t (*arch_loadaddr)(uint_t type, void *data, vm_offset_t addr);
#define LOAD_ELF 1
#define LOAD_RAW 2
#define LOAD_KERN 3
#define LOAD_MEM 4
void (*arch_free_loadaddr)(vm_offset_t addr, size_t pages);
#ifdef __elfN
void (*arch_loadseg)(Elf_Ehdr *eh, Elf_Phdr *ph, uint64_t delta);
#else
void (*arch_loadseg)(void *eh, void *ph, uint64_t delta);
#endif
void (*arch_zfs_probe)(void);
const char *(*arch_hypervisor)(void);
};
extern struct arch_switch archsw;
void delay(int delay);
void dev_cleanup(void);
typedef int (nvstore_getter_cb_t)(void *, const char *, void **);
typedef int (nvstore_setter_cb_t)(void *, int, const char *,
const void *, size_t);
typedef int (nvstore_setter_str_cb_t)(void *, const char *, const char *,
const char *);
typedef int (nvstore_unset_cb_t)(void *, const char *);
typedef int (nvstore_print_cb_t)(void *, void *);
typedef int (nvstore_iterate_cb_t)(void *, int (*)(void *, void *));
typedef struct nvs_callbacks {
nvstore_getter_cb_t *nvs_getter;
nvstore_setter_cb_t *nvs_setter;
nvstore_setter_str_cb_t *nvs_setter_str;
nvstore_unset_cb_t *nvs_unset;
nvstore_print_cb_t *nvs_print;
nvstore_iterate_cb_t *nvs_iterate;
} nvs_callbacks_t;
int nvstore_init(const char *, nvs_callbacks_t *, void *);
int nvstore_fini(const char *);
void *nvstore_get_store(const char *);
int nvstore_print(void *);
int nvstore_get_var(void *, const char *, void **);
int nvstore_set_var(void *, int, const char *, void *, size_t);
int nvstore_set_var_from_string(void *, const char *, const char *,
const char *);
int nvstore_unset_var(void *, const char *);
#define CTASSERT(x) _Static_assert(x, "compile-time assertion failed")
#endif