* Copyright (c) 1980 Regents of the University of California.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* 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
static char sccsid
[] = "@(#)mkheaders.c 5.7 (Berkeley) 7/1/91";
* Make all the .h files for the optional entries
register struct file_list
*fl
;
for (fl
= ftab
; fl
!= 0; fl
= fl
->f_next
)
do_count(fl
->f_needs
, fl
->f_needs
, 1);
* count all the devices of a certain type and recurse to count
* whatever the device is connected to
do_count(dev
, hname
, search
)
register char *dev
, *hname
;
register struct device
*dp
, *mp
;
for (count
= 0,dp
= dtab
; dp
!= 0; dp
= dp
->d_next
)
if (dp
->d_unit
!= -1 && eq(dp
->d_name
, dev
)) {
if (dp
->d_type
== PSEUDO_DEVICE
) {
dp
->d_slave
!= UNKNOWN
? dp
->d_slave
: 1;
* Allow holes in unit numbering,
* assumption is unit numbering starts
if (dp
->d_unit
+ 1 > count
)
if (mp
!= 0 && mp
!= TO_NEXUS
&&
mp
->d_conn
!= 0 && mp
->d_conn
!= TO_NEXUS
) {
do_count(mp
->d_name
, hname
, 0);
do_header(dev
, hname
, count
);
do_header(dev
, hname
, count
)
char *file
, *name
, *inw
, *toheader(), *tomacro();
struct file_list
*fl
, *fl_head
;
fprintf(outf
, "#define %s %d\n", name
, count
);
if ((inw
= get_word(inf
)) == 0 || inw
== (char *)EOF
)
if ((inw
= get_word(inf
)) == 0 || inw
== (char *)EOF
)
if (cp
== 0 || cp
== (char *)EOF
)
fl
= (struct file_list
*) malloc(sizeof *fl
);
for (fl
= fl_head
; fl
;) {
struct file_list
*fln
= fl
->f_next
;
fl
= (struct file_list
*) malloc(sizeof *fl
);
for (fl
= fl_head
; fl
;) {
struct file_list
*fln
= fl
->f_next
;
fprintf(outf
, "#define %s %u\n",
fl
->f_fn
, count
? fl
->f_type
: 0);
* convert a dev name to a .h file name
(void) strcpy(hbuf
, path(dev
));
(void) strcat(hbuf
, ".h");
* convert a dev name to a macro name