diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2012-03-19 17:38:32 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2012-03-19 17:38:32 +0000 |
commit | 227e066fd9009304a6c891f3cb9faf2854a5ece1 (patch) | |
tree | b8c52235f5a79e4ba42e7efbf3ffa12f32b30de6 /sys/arch/sgi/stand/boot/netio.c | |
parent | 5f9c7bf79f6f68b257dd9c5b019b47217ab87267 (diff) |
Teach the bootblocks how to load kernel from tftp (i.e. when OSLoadPartition
is bootp() instead of a disk). Kind of ugly because of the usual `can't seek'
problem causing kernels with symbols to be read from the network twice.
While there, add a 32 bit ECOFF boot block, not hooked to the build yet,
to be used shortly.
Diffstat (limited to 'sys/arch/sgi/stand/boot/netio.c')
-rw-r--r-- | sys/arch/sgi/stand/boot/netio.c | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/sys/arch/sgi/stand/boot/netio.c b/sys/arch/sgi/stand/boot/netio.c new file mode 100644 index 00000000000..2a25d7f8aa0 --- /dev/null +++ b/sys/arch/sgi/stand/boot/netio.c @@ -0,0 +1,84 @@ +/* $OpenBSD: netio.c,v 1.1 2012/03/19 17:38:31 miod Exp $ */ + +/* + * Copyright (c) 2012 Miodrag Vallat. + * + * Permission to use, copy, modify, and distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + + +#include <sys/param.h> +#include <lib/libkern/libkern.h> +#include <stand.h> + +#include <mips64/arcbios.h> + +int +netstrategy(void *devdata, int rw, daddr32_t bn, size_t reqcnt, void *addr, + size_t *cnt) +{ + long fd = (long)devdata; + long result; + int rc; + + rc = Bios_Read(fd, addr, reqcnt, &result); + if (rc != 0) + return (EIO); + + *cnt = result; + return 0; +} + +int +netopen(struct open_file *f, ...) +{ + char *path; + long fd; + int rc; + va_list ap; + + va_start(ap, f); + path = va_arg(ap, char *); + va_end(ap); + + /* to match netfs.c filename buffers... */ + if (strlen(path) > 128 - 1) + return ENAMETOOLONG; + + rc = Bios_Open(path, 0, &fd); + if (rc != 0) { + switch (rc) { + case arc_EACCES: + return EACCES; + case arc_EISDIR: + return EISDIR; + case arc_ENOENT: + return ENOENT; + default: + return ENXIO; + } + } + + f->f_devdata = (void *)fd; + + return 0; +} + +int +netclose(struct open_file *f) +{ + long fd = (long)f->f_devdata; + + (void)Bios_Close(fd); + return 0; +} |