#include <sys/param.h>
#include <sys/reboot.h>
#include <sys/stat.h>
#include <libsa.h>
#include <lib/libsa/cd9660.h>
#include <lib/libsa/loadfile.h>
#include <lib/libsa/arc4.h>
#include <dev/cons.h>
#include <machine/pdc.h>
#include <machine/cpu.h>
#include <stand/boot/bootarg.h>
#include "dev_hppa.h"
#include "cmd.h"
dev_t bootdev;
int debug = 1;
int boottimeout = 5;
struct fs_ops file_system[] = {
{ cd9660_open, cd9660_close, cd9660_read, cd9660_write, cd9660_seek,
cd9660_stat, cd9660_readdir },
};
int nfsys = nitems(file_system);
struct devsw devsw[] = {
{ "dk", iodcstrategy, dkopen, dkclose, noioctl },
};
int ndevs = nitems(devsw);
struct consdev constab[] = {
{ ite_probe, ite_init, ite_getc, ite_putc },
{ NULL }
};
struct consdev *cn_tab;
typedef void (*startfuncp)(int, int, int, int, int, int, caddr_t)
__attribute__ ((noreturn));
char rnddata[BOOTRANDOM_MAX];
struct rc4_ctx randomctx;
void
boot(dev_t dev)
{
uint64_t marks[MARK_MAX];
char path[128];
pdc_init();
cninit();
devboot(dev, path);
strncpy(path + strlen(path), ":/bsd.rd", 9);
printf(">> OpenBSD/" MACHINE " CDBOOT 0.2\n"
"booting %s: ", path);
rc4_keysetup(&randomctx, rnddata, sizeof rnddata);
rc4_skip(&randomctx, 1536);
marks[MARK_START] = 0;
if (!loadfile(path, marks, LOAD_KERNEL)) {
marks[MARK_END] = ALIGN(marks[MARK_END]);
fcacheall();
__asm("mtctl %r0, %cr17");
__asm("mtctl %r0, %cr17");
(*(startfuncp)((u_long)marks[MARK_ENTRY]))((int)pdc, 0, bootdev,
(u_long)marks[MARK_END], BOOTARG_APIVER, BOOTARG_LEN,
(caddr_t)BOOTARG_OFF);
}
}