home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / bsd_srcs / usr.sbin / amd / fsinfo / wr_bparam.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-05-12  |  3.1 KB  |  102 lines

  1. /*
  2.  * Copyright (c) 1989 Jan-Simon Pendry
  3.  * Copyright (c) 1989 Imperial College of Science, Technology & Medicine
  4.  * Copyright (c) 1989 The Regents of the University of California.
  5.  * All rights reserved.
  6.  *
  7.  * This code is derived from software contributed to Berkeley by
  8.  * Jan-Simon Pendry at Imperial College, London.
  9.  *
  10.  * Redistribution and use in source and binary forms, with or without
  11.  * modification, are permitted provided that the following conditions
  12.  * are met:
  13.  * 1. Redistributions of source code must retain the above copyright
  14.  *    notice, this list of conditions and the following disclaimer.
  15.  * 2. Redistributions in binary form must reproduce the above copyright
  16.  *    notice, this list of conditions and the following disclaimer in the
  17.  *    documentation and/or other materials provided with the distribution.
  18.  * 3. All advertising materials mentioning features or use of this software
  19.  *    must display the following acknowledgement:
  20.  *    This product includes software developed by the University of
  21.  *    California, Berkeley and its contributors.
  22.  * 4. Neither the name of the University nor the names of its contributors
  23.  *    may be used to endorse or promote products derived from this software
  24.  *    without specific prior written permission.
  25.  *
  26.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  27.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  28.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  29.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  30.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  31.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  32.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  33.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  34.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  35.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  36.  * SUCH DAMAGE.
  37.  *
  38.  *    @(#)wr_bparam.c    5.3 (Berkeley) 5/12/91
  39.  *
  40.  * $Id: wr_bparam.c,v 5.2.1.3 91/05/07 22:19:10 jsp Alpha $
  41.  *
  42.  */
  43.  
  44. #include "../fsinfo/fsinfo.h"
  45.  
  46. /*
  47.  * Write a host/path in NFS format
  48.  */
  49. static int write_nfsname(ef, fp, hn)
  50. FILE *ef;
  51. fsmount *fp;
  52. char *hn;
  53. {
  54.     int errors = 0;
  55.     char *h = strdup(fp->f_ref->m_dk->d_host->h_hostname);
  56.     domain_strip(h, hn);
  57.     fprintf(ef, "%s:%s", h, fp->f_volname);
  58.     free(h);
  59.     return errors;
  60. }
  61.  
  62. /*
  63.  * Write a bootparams entry for a host
  64.  */
  65. static int write_boot_info(ef, hp)
  66. FILE *ef;
  67. host *hp;
  68. {
  69.     int errors = 0;
  70.     fprintf(ef, "%s\troot=", hp->h_hostname);
  71.     errors += write_nfsname(ef, hp->h_netroot, hp->h_hostname);
  72.     fputs(" swap=", ef);
  73.     errors += write_nfsname(ef, hp->h_netswap, hp->h_hostname);
  74.     fputs("\n", ef);
  75.  
  76.     return 0;
  77. }
  78.  
  79. /*
  80.  * Output a bootparams file
  81.  */
  82. int write_bootparams(q)
  83. qelem *q;
  84. {
  85.     int errors = 0;
  86.  
  87.     if (bootparams_pref) {
  88.         FILE *ef = pref_open(bootparams_pref, "bootparams", info_hdr, "bootparams");
  89.         if (ef) {
  90.             host *hp;
  91.             ITER(hp, host, q)
  92.                 if (hp->h_netroot && hp->h_netswap)
  93.                     errors += write_boot_info(ef, hp);
  94.             errors += pref_close(ef);
  95.         } else {
  96.             errors++;
  97.         }
  98.     }
  99.  
  100.     return errors;
  101. }
  102.