stand.h revision 39665
1/* 2 * Copyright (c) 1998 Michael Smith. 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24 * SUCH DAMAGE. 25 * 26 * $Id: stand.h,v 1.4 1998/09/18 23:00:57 msmith Exp $ 27 * From $NetBSD: stand.h,v 1.22 1997/06/26 19:17:40 drochner Exp $ 28 */ 29 30/*- 31 * Copyright (c) 1993 32 * The Regents of the University of California. All rights reserved. 33 * 34 * Redistribution and use in source and binary forms, with or without 35 * modification, are permitted provided that the following conditions 36 * are met: 37 * 1. Redistributions of source code must retain the above copyright 38 * notice, this list of conditions and the following disclaimer. 39 * 2. Redistributions in binary form must reproduce the above copyright 40 * notice, this list of conditions and the following disclaimer in the 41 * documentation and/or other materials provided with the distribution. 42 * 3. All advertising materials mentioning features or use of this software 43 * must display the following acknowledgement: 44 * This product includes software developed by the University of 45 * California, Berkeley and its contributors. 46 * 4. Neither the name of the University nor the names of its contributors 47 * may be used to endorse or promote products derived from this software 48 * without specific prior written permission. 49 * 50 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 51 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 52 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 53 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 54 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 55 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 56 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 57 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 58 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 59 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 60 * SUCH DAMAGE. 61 * 62 * @(#)stand.h 8.1 (Berkeley) 6/11/93 63 */ 64 65#include <sys/types.h> 66#include <sys/cdefs.h> 67#include <sys/stat.h> 68 69#define CHK(fmt, args...) printf("%s(%d): " fmt "\n", __FUNCTION__, __LINE__ , ##args) 70#define PCHK(fmt, args...) {printf("%s(%d): " fmt "\n", __FUNCTION__, __LINE__ , ##args); getchar();} 71 72#ifndef NULL 73#define NULL 0 74#endif 75 76/* Avoid unwanted userlandish components */ 77#define KERNEL 78#include <sys/errno.h> 79#undef KERNEL 80 81/* special stand error codes */ 82#define EADAPT (ELAST+1) /* bad adaptor */ 83#define ECTLR (ELAST+2) /* bad controller */ 84#define EUNIT (ELAST+3) /* bad unit */ 85#define ESLICE (ELAST+4) /* bad slice */ 86#define EPART (ELAST+5) /* bad partition */ 87#define ERDLAB (ELAST+6) /* can't read disk label */ 88#define EUNLAB (ELAST+7) /* unlabeled disk */ 89#define EOFFSET (ELAST+8) /* relative seek not supported */ 90#define ESALAST (ELAST+8) /* */ 91 92struct open_file; 93 94/* 95 * This structure is used to define file system operations in a file system 96 * independent way. 97 * 98 * XXX note that filesystem providers should export a pointer to their fs_ops 99 * struct, so that consumers can reference this and thus include the 100 * filesystems that they require. 101 */ 102struct fs_ops { 103 const char *fs_name; 104 int (*fo_open)(const char *path, struct open_file *f); 105 int (*fo_close)(struct open_file *f); 106 int (*fo_read)(struct open_file *f, void *buf, 107 size_t size, size_t *resid); 108 int (*fo_write)(struct open_file *f, void *buf, 109 size_t size, size_t *resid); 110 off_t (*fo_seek)(struct open_file *f, off_t offset, int where); 111 int (*fo_stat)(struct open_file *f, struct stat *sb); 112}; 113 114/* 115 * libstand-supplied filesystems 116 */ 117extern struct fs_ops ufs_fsops; 118extern struct fs_ops tftp_fsops; 119extern struct fs_ops nfs_fsops; 120extern struct fs_ops cd9660_fsops; 121extern struct fs_ops zipfs_fsops; 122#ifdef notyet 123extern struct fs_ops dosfs_fsops; 124#endif 125 126/* where values for lseek(2) */ 127#define SEEK_SET 0 /* set file offset to offset */ 128#define SEEK_CUR 1 /* set file offset to current plus offset */ 129#define SEEK_END 2 /* set file offset to EOF plus offset */ 130 131/* 132 * Device switch 133 */ 134struct devsw { 135 const char dv_name[8]; 136 int dv_type; /* opaque type constant, arch-dependant */ 137 int (*dv_init)(void); /* early probe call */ 138 int (*dv_strategy)(void *devdata, int rw, daddr_t blk, size_t size, void *buf, size_t *rsize); 139 int (*dv_open)(struct open_file *f, ...); 140 int (*dv_close)(struct open_file *f); 141 int (*dv_ioctl)(struct open_file *f, u_long cmd, void *data); 142}; 143 144extern int errno; 145 146struct open_file { 147 int f_flags; /* see F_* below */ 148 struct devsw *f_dev; /* pointer to device operations */ 149 void *f_devdata; /* device specific data */ 150 struct fs_ops *f_ops; /* pointer to file system operations */ 151 void *f_fsdata; /* file system specific data */ 152 off_t f_offset; /* current file offset (F_RAW) */ 153}; 154 155#define SOPEN_MAX 8 156extern struct open_file files[]; 157 158/* f_flags values */ 159#define F_READ 0x0001 /* file opened for reading */ 160#define F_WRITE 0x0002 /* file opened for writing */ 161#define F_RAW 0x0004 /* raw device open - no file system */ 162#define F_NODEV 0x0008 /* network open - no device */ 163 164#define isupper(c) ((c) >= 'A' && (c) <= 'Z') 165#define islower(c) ((c) >= 'a' && (c) <= 'z') 166#define isspace(c) ((c) == ' ' || (c) == '\t') 167#define isdigit(c) ((c) >= '0' && (c) <= '9') 168#define isxdigit(c) (isdigit(c) || ((c) >= 'a' && (c) <= 'f') || ((c) >= 'A' && (c) <= 'F')) 169#define isascii(c) ((c) >= 0 || (c <= 0x7f)) 170#define isalpha(c) (isupper(c) || (islower(c))) 171#define toupper(c) ((c) - 'a' + 'A') 172#define tolower(c) ((c) - 'A' + 'a') 173 174/* sbrk emulation */ 175extern void setheap(void *base, void *top); 176extern char *sbrk(int incr); 177 178/* Matt Dillon's zalloc/zmalloc */ 179extern void *malloc(size_t bytes); 180extern void free(void *ptr); 181/*#define free(p) {CHK("free %p", p); free(p);} */ /* use for catching guard violations */ 182extern void *calloc(size_t n1, size_t n2); 183extern void *realloc(void *ptr, size_t size); 184extern void *reallocf(void *ptr, size_t size); 185extern void mallocstats(void); 186 187/* disklabel support (undocumented, may be junk) */ 188struct disklabel; 189extern char *getdisklabel(const char *, struct disklabel *); 190extern int dkcksum(struct disklabel *); 191 192extern int printf(const char *fmt, ...); 193extern void vprintf(const char *fmt, _BSD_VA_LIST_); 194extern int sprintf(char *buf, const char *cfmt, ...); 195 196extern void twiddle(void); 197 198extern void ngets(char *, int); 199#define gets(x) ngets((x), 0) 200extern int fgetstr(char *buf, int size, int fd); 201 202extern int open(const char *, int); 203#define O_RDONLY 0x0 204#define O_WRONLY 0x1 /* writing not (yet?) supported */ 205#define O_RDWR 0x2 206extern int close(int); 207extern void closeall(void); 208extern ssize_t read(int, void *, size_t); 209extern ssize_t write(int, void *, size_t); 210extern off_t lseek(int, off_t, int); 211extern int stat(const char *, struct stat *); 212 213extern void srandom(u_long seed); 214extern u_long random(void); 215 216/* imports from stdlib, locally modified */ 217extern long strtol(const char *, char **, int); 218extern char *optarg; /* getopt(3) external variables */ 219extern int optind, opterr, optopt; 220extern int getopt(int, char * const [], const char *); 221 222/* pager.c */ 223extern void pager_open(void); 224extern void pager_close(void); 225extern int pager_output(const char *lines); 226extern int pager_file(const char *fname); 227 228/* environment.c */ 229#define EV_DYNAMIC (1<<0) /* value was dynamically allocated, free if changed/unset */ 230#define EV_VOLATILE (1<<1) /* value is volatile, make a copy of it */ 231#define EV_NOHOOK (1<<2) /* don't call hook when setting */ 232 233struct env_var; 234typedef char *(ev_format_t)(struct env_var *ev); 235typedef int (ev_sethook_t)(struct env_var *ev, int flags, void *value); 236typedef int (ev_unsethook_t)(struct env_var *ev); 237 238struct env_var 239{ 240 char *ev_name; 241 int ev_flags; 242 void *ev_value; 243 ev_sethook_t *ev_sethook; 244 ev_unsethook_t *ev_unsethook; 245 struct env_var *ev_next, *ev_prev; 246}; 247extern struct env_var *environ; 248 249extern struct env_var *env_getenv(const char *name); 250extern int env_setenv(const char *name, int flags, void *value, 251 ev_sethook_t sethook, ev_unsethook_t unsethook); 252extern char *getenv(const char *name); 253extern int setenv(const char *name, char *value, int overwrite); 254extern int putenv(const char *string); 255extern int unsetenv(const char *name); 256 257extern ev_sethook_t env_noset; /* refuse set operation */ 258extern ev_unsethook_t env_nounset; /* refuse unset operation */ 259 260/* BCD conversions (undocumented) */ 261extern u_char const bcd2bin_data[]; 262extern u_char const bin2bcd_data[]; 263extern char const hex2ascii_data[]; 264 265#define bcd2bin(bcd) (bcd2bin_data[bcd]) 266#define bin2bcd(bin) (bin2bcd_data[bin]) 267#define hex2ascii(hex) (hex2ascii_data[hex]) 268 269/* min/max (undocumented) */ 270static __inline int imax(int a, int b) { return (a > b ? a : b); } 271static __inline int imin(int a, int b) { return (a < b ? a : b); } 272static __inline long lmax(long a, long b) { return (a > b ? a : b); } 273static __inline long lmin(long a, long b) { return (a < b ? a : b); } 274static __inline u_int max(u_int a, u_int b) { return (a > b ? a : b); } 275static __inline u_int min(u_int a, u_int b) { return (a < b ? a : b); } 276static __inline quad_t qmax(quad_t a, quad_t b) { return (a > b ? a : b); } 277static __inline quad_t qmin(quad_t a, quad_t b) { return (a < b ? a : b); } 278static __inline u_long ulmax(u_long a, u_long b) { return (a > b ? a : b); } 279static __inline u_long ulmin(u_long a, u_long b) { return (a < b ? a : b); } 280 281/* swaps (undocumented, useful?) */ 282#ifdef __i386__ 283extern u_int32_t bswap32(u_int32_t x); 284extern u_int64_t bswap64(u_int32_t x); 285#endif 286 287/* null functions for device/filesystem switches (undocumented) */ 288extern int nodev(void); 289extern int noioctl(struct open_file *, u_long, void *); 290extern void nullsys(void); 291 292extern int null_open(const char *path, struct open_file *f); 293extern int null_close(struct open_file *f); 294extern ssize_t null_read(struct open_file *f, void *buf, size_t size, size_t *resid); 295extern ssize_t null_write(struct open_file *f, void *buf, size_t size, size_t *resid); 296extern off_t null_seek(struct open_file *f, off_t offset, int where); 297extern int null_stat(struct open_file *f, struct stat *sb); 298 299/* 300 * Machine dependent functions and data, must be provided or stubbed by 301 * the consumer 302 */ 303extern int getchar(void); 304extern int ischar(void); 305extern void putchar(int); 306extern int devopen(struct open_file *, const char *, char **); 307extern int devclose(struct open_file *f); 308extern void panic(const char *, ...) __dead2; 309extern struct fs_ops *file_system[]; 310extern struct devsw *devsw[]; 311 312