shrink bootblocks by splitting libsa contents into more files. from
authorderaadt <deraadt@openbsd.org>
Thu, 7 Dec 1995 03:27:38 +0000 (03:27 +0000)
committerderaadt <deraadt@openbsd.org>
Thu, 7 Dec 1995 03:27:38 +0000 (03:27 +0000)
waldi@moacs.indiv.nl.net, netbsd pr#1817

13 files changed:
sys/lib/libsa/Makefile
sys/lib/libsa/bcopy.c
sys/lib/libsa/close.c
sys/lib/libsa/closeall.c [new file with mode: 0644]
sys/lib/libsa/disklabel.c
sys/lib/libsa/dkcksum.c [new file with mode: 0644]
sys/lib/libsa/fstat.c [new file with mode: 0644]
sys/lib/libsa/nullfs.c [new file with mode: 0644]
sys/lib/libsa/open.c
sys/lib/libsa/stand.h
sys/lib/libsa/stat.c
sys/lib/libsa/strerror.c
sys/lib/libsa/ufs.c

index 7cd73ed..f6a56fa 100644 (file)
@@ -15,8 +15,8 @@ SRCS+=        alloc.c bcopy.c exit.c exec.c getfile.c gets.c globals.c \
        printf.c strerror.c
 
 # io routines
-SRCS+= close.c dev.c disklabel.c ioctl.c lseek.c open.c read.c \
-       stat.c write.c
+SRCS+= close.c closeall.c dev.c disklabel.c dkcksum.c ioctl.c \
+       lseek.c open.c nullfs.c read.c stat.c fstat.c write.c
 
 .if !defined(NO_NET)
 # network routines
index 3cf8610..3b670da 100644 (file)
@@ -36,6 +36,7 @@
  */
 
 #include <sys/types.h>
+#include "stand.h"
 
 /*
  * This is designed to be small, not fast.
index ffcef14..388309b 100644 (file)
@@ -92,14 +92,3 @@ close(fd)
        }
        return (0);
 }
-
-
-void
-closeall()
-{
-       int i;
-
-        for (i = 0; i < SOPEN_MAX; i++)
-            if (files[i].f_flags != 0)
-                (void)close(i);
-}
diff --git a/sys/lib/libsa/closeall.c b/sys/lib/libsa/closeall.c
new file mode 100644 (file)
index 0000000..b55e4d8
--- /dev/null
@@ -0,0 +1,77 @@
+/*     $NetBSD: close.c,v 1.5 1995/09/06 19:53:29 pk Exp $     */
+
+/*-
+ * Copyright (c) 1993
+ *     The Regents of the University of California.  All rights reserved.
+ *
+ * This code is derived from software contributed to Berkeley by
+ * The Mach Operating System project at Carnegie-Mellon University.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed by the University of
+ *     California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ *     @(#)close.c     8.1 (Berkeley) 6/11/93
+ *  
+ *
+ * Copyright (c) 1989, 1990, 1991 Carnegie Mellon University
+ * All Rights Reserved.
+ *
+ * Author: Alessandro Forin
+ * 
+ * Permission to use, copy, modify and distribute this software and its
+ * documentation is hereby granted, provided that both the copyright
+ * notice and this permission notice appear in all copies of the
+ * software, derivative works or modified versions, and any portions
+ * thereof, and that both notices appear in supporting documentation.
+ * 
+ * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
+ * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
+ * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
+ * 
+ * Carnegie Mellon requests users of this software to return to
+ * 
+ *  Software Distribution Coordinator  or  Software.Distribution@CS.CMU.EDU
+ *  School of Computer Science
+ *  Carnegie Mellon University
+ *  Pittsburgh PA 15213-3890
+ * 
+ * any improvements or extensions that they make and grant Carnegie the
+ * rights to redistribute these changes.
+ */
+
+#include "stand.h"
+
+void
+closeall()
+{
+       int i;
+
+        for (i = 0; i < SOPEN_MAX; i++)
+            if (files[i].f_flags != 0)
+                (void)close(i);
+}
index 5c1a519..81b655d 100644 (file)
@@ -37,9 +37,8 @@
 
 #include <sys/param.h>
 #include <sys/disklabel.h>
+#include "stand.h"
 
-int dkcksum __P((struct disklabel *));
-    
 char *
 getdisklabel(buf, lp)
        const char *buf;
@@ -65,20 +64,3 @@ getdisklabel(buf, lp)
        }
        return (msg);
 }
-
-/*
- * Compute checksum for disk label.
- */
-int
-dkcksum(lp)
-       register struct disklabel *lp;
-{
-       register u_short *start, *end;
-       register u_short sum = 0;
-
-       start = (u_short *)lp;
-       end = (u_short *)&lp->d_partitions[lp->d_npartitions];
-       while (start < end)
-               sum ^= *start++;
-       return (sum);
-}
diff --git a/sys/lib/libsa/dkcksum.c b/sys/lib/libsa/dkcksum.c
new file mode 100644 (file)
index 0000000..75986af
--- /dev/null
@@ -0,0 +1,57 @@
+/*     $NetBSD: disklabel.c,v 1.3 1994/10/26 05:44:42 cgd Exp $        */
+
+/*-
+ * Copyright (c) 1993
+ *     The Regents of the University of California.  All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed by the University of
+ *     California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ *     @(#)disklabel.c 8.1 (Berkeley) 6/11/93
+ */
+
+#include <sys/param.h>
+#include <sys/disklabel.h>
+#include "stand.h"
+
+/*
+ * Compute checksum for disk label.
+ */
+int
+dkcksum(lp)
+       register struct disklabel *lp;
+{
+       register u_short *start, *end;
+       register u_short sum = 0;
+
+       start = (u_short *)lp;
+       end = (u_short *)&lp->d_partitions[lp->d_npartitions];
+       while (start < end)
+               sum ^= *start++;
+       return (sum);
+}
diff --git a/sys/lib/libsa/fstat.c b/sys/lib/libsa/fstat.c
new file mode 100644 (file)
index 0000000..76b999d
--- /dev/null
@@ -0,0 +1,60 @@
+/*     $NetBSD: stat.c,v 1.3 1994/10/26 05:45:07 cgd Exp $     */
+
+/*-
+ * Copyright (c) 1993
+ *     The Regents of the University of California.  All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed by the University of
+ *     California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ *     @(#)stat.c      8.1 (Berkeley) 6/11/93
+ */
+
+#include "stand.h"
+
+int
+fstat(fd, sb)
+       int fd;
+       struct stat *sb;
+{
+       register struct open_file *f = &files[fd];
+
+       if ((unsigned)fd >= SOPEN_MAX || f->f_flags == 0) {
+               errno = EBADF;
+               return (-1);
+       }
+
+       /* operation not defined on raw devices */
+       if (f->f_flags & F_RAW) {
+               errno = EOPNOTSUPP;
+               return (-1);
+       }
+
+       errno = (f->f_ops->stat)(f, sb);
+       return (0);
+}
diff --git a/sys/lib/libsa/nullfs.c b/sys/lib/libsa/nullfs.c
new file mode 100644 (file)
index 0000000..f69de86
--- /dev/null
@@ -0,0 +1,105 @@
+/*     $NetBSD: open.c,v 1.9 1995/09/19 09:16:52 thorpej Exp $ */
+
+/*-
+ * Copyright (c) 1993
+ *     The Regents of the University of California.  All rights reserved.
+ *
+ * This code is derived from software contributed to Berkeley by
+ * The Mach Operating System project at Carnegie-Mellon University.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ * 3. All advertising materials mentioning features or use of this software
+ *    must display the following acknowledgement:
+ *     This product includes software developed by the University of
+ *     California, Berkeley and its contributors.
+ * 4. Neither the name of the University nor the names of its contributors
+ *    may be used to endorse or promote products derived from this software
+ *    without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ *     @(#)open.c      8.1 (Berkeley) 6/11/93
+ *  
+ *
+ * Copyright (c) 1989, 1990, 1991 Carnegie Mellon University
+ * All Rights Reserved.
+ *
+ * Author: Alessandro Forin
+ * 
+ * Permission to use, copy, modify and distribute this software and its
+ * documentation is hereby granted, provided that both the copyright
+ * notice and this permission notice appear in all copies of the
+ * software, derivative works or modified versions, and any portions
+ * thereof, and that both notices appear in supporting documentation.
+ * 
+ * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
+ * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
+ * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
+ * 
+ * Carnegie Mellon requests users of this software to return to
+ * 
+ *  Software Distribution Coordinator  or  Software.Distribution@CS.CMU.EDU
+ *  School of Computer Science
+ *  Carnegie Mellon University
+ *  Pittsburgh PA 15213-3890
+ * 
+ * any improvements or extensions that they make and grant Carnegie the
+ * rights to redistribute these changes.
+ */
+
+#include "stand.h"
+
+/*
+ * Null filesystem
+ */
+int    null_open (char *path, struct open_file *f)
+{
+       errno  = EIO;
+       return -1;
+}
+
+int    null_close(struct open_file *f)
+{
+       return 0;
+}
+
+ssize_t        null_read (struct open_file *f, void *buf, size_t size, size_t *resid)
+{
+       errno = EIO;
+       return -1;
+}
+
+ssize_t        null_write (struct open_file *f, void *buf, size_t size, size_t *resid)
+{
+       errno = EIO;
+       return -1;
+}
+
+off_t  null_seek (struct open_file *f, off_t offset, int where)
+{
+       errno = EIO;
+       return -1;
+}
+
+int    null_stat (struct open_file *f, struct stat *sb)
+{
+       errno = EIO;
+       return -1;
+}
index 982f4ea..8532db7 100644 (file)
  */
 
 #include "stand.h"
+
+#ifndef atari
 struct open_file files[SOPEN_MAX];
+#endif
 
 /*
  *     File primitives proper
@@ -123,42 +126,3 @@ err:
        errno = error;
        return (-1);
 }
-
-/*
- * Null filesystem
- */
-int    null_open (char *path, struct open_file *f)
-{
-       errno  = EIO;
-       return -1;
-}
-
-int    null_close(struct open_file *f)
-{
-       return 0;
-}
-
-ssize_t        null_read (struct open_file *f, void *buf, size_t size, size_t *resid)
-{
-       errno = EIO;
-       return -1;
-}
-
-ssize_t        null_write (struct open_file *f, void *buf, size_t size, size_t *resid)
-{
-       errno = EIO;
-       return -1;
-}
-
-off_t  null_seek (struct open_file *f, off_t offset, int where)
-{
-       errno = EIO;
-       return -1;
-}
-
-int    null_stat (struct open_file *f, struct stat *sb)
-{
-       errno = EIO;
-       return -1;
-}
-
index f537d2d..f987bc8 100644 (file)
@@ -63,6 +63,7 @@ struct fs_ops {
 };
 
 extern struct fs_ops file_system[];
+extern int nfsys;
 
 /* where values for lseek(2) */
 #define        SEEK_SET        0       /* set file offset to offset */
@@ -93,7 +94,6 @@ struct open_file {
 
 #define        SOPEN_MAX       4
 extern struct open_file files[];
-extern int nfsys;
 
 /* f_flags values */
 #define        F_READ          0x0001  /* file opened for reading */
@@ -111,18 +111,19 @@ void      *alloc __P((unsigned int));
 void   free __P((void *, unsigned int));
 struct disklabel;
 char   *getdisklabel __P((const char *, struct disklabel *));
+int    dkcksum __P((struct disklabel *));
 
 void   printf __P((const char *, ...));
 void   sprintf __P((char *, const char *, ...));
 void   twiddle __P((void));
 void   gets __P((char *));
 __dead void    panic __P((const char *, ...)) __attribute__((noreturn));
-__dead void _rtt __P((void)) __attribute__((noreturn));
+__dead void    _rtt __P((void)) __attribute__((noreturn));
 void   bcopy __P((const void *, void *, size_t));
-int    getchar __P((void));
 void   exec __P((char *, char *, int));
 int    open __P((const char *, int));
 int    close __P((int));
+void   closeall __P((void));
 ssize_t        read __P((int, void *, size_t));
 ssize_t        write __P((int, void *, size_t));
     
index 9e2cbca..6177f1c 100644 (file)
 
 #include "stand.h"
 
-int
-fstat(fd, sb)
-       int fd;
-       struct stat *sb;
-{
-       register struct open_file *f = &files[fd];
-
-       if ((unsigned)fd >= SOPEN_MAX || f->f_flags == 0) {
-               errno = EBADF;
-               return (-1);
-       }
-
-       /* operation not defined on raw devices */
-       if (f->f_flags & F_RAW) {
-               errno = EOPNOTSUPP;
-               return (-1);
-       }
-
-       errno = (f->f_ops->stat)(f, sb);
-       return (0);
-}
-
 int
 stat(str, sb)
        const char *str;
index e84c0ea..a9fdbaf 100644 (file)
@@ -37,9 +37,6 @@
 #include "saerrno.h"
 #include "stand.h"
 
-size_t strlen __P((const char *));                             /* XXX */
-char   *strcpy __P((char *, const char *));                    /* XXX */
-
 char *
 strerror(err)
        int err;
index 1f9c608..ccba954 100644 (file)
@@ -147,7 +147,7 @@ read_inode(inumber, f)
        }
 out:
        free(buf, fs->fs_bsize);
-       return (0);      
+       return (rc);     
 }
 
 /*