2 * Copyright (c) 1980, 1986 The Regents of the University of California.
5 * Redistribution and use in source and binary forms are permitted
6 * provided that the above copyright notice and this paragraph are
7 * duplicated in all such forms and that any documentation,
8 * advertising materials, and other materials related to such
9 * distribution and use acknowledge that the software was developed
10 * by the University of California, Berkeley. The name of the
11 * University may not be used to endorse or promote products derived
12 * from this software without specific prior written permission.
13 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
14 * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
15 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
18 #include <afsconfig.h>
19 #include <afs/param.h>
27 #include <sys/vnode.h>
28 #include <sys/mount.h>
29 #include <ufs/inode.h>
36 #else /* AFS_OSF_ENV */
37 #ifdef AFS_VFSINCL_ENV
38 #include <sys/vnode.h>
40 #include <sys/fs/ufs_inode.h>
41 #include <sys/fs/ufs_fs.h>
43 #include <sys/fs/ufs_fsdir.h>
45 #include <sys/fs/ufs_mount.h>
47 #include <ufs/inode.h>
50 #else /* AFS_VFSINCL_ENV */
51 #include <sys/inode.h>
53 #define LONGFILENAMES 1
54 #include <sys/sysmacros.h>
58 #endif /* AFS_VFSINCL_ENV */
59 #endif /* AFS_OSF_ENV */
64 static struct dups
*duphead
;
73 memset(&idesc
, 0, sizeof(struct inodesc
));
75 idesc
.id_func
= pass1bcheck
;
78 for (c
= 0; c
< sblock
.fs_ncg
; c
++) {
79 for (i
= 0; i
< sblock
.fs_ipg
; i
++, inumber
++) {
80 if (inumber
< ROOTINO
)
85 idesc
.id_number
= inumber
;
87 idesc
.id_fix
= DONTKNOW
;
89 #if defined(ACLS) && defined(AFS_HPUX_ENV)
90 if (((statemap
[inumber
] & STATE
) != USTATE
) &&
92 if (statemap
[inumber
] != USTATE
&&
94 (ckinode(dp
, &idesc
) & STOP
))
101 struct inodesc
*idesc
;
104 int nfrags
, res
= KEEPON
;
105 daddr_t blkno
= idesc
->id_blkno
;
107 for (nfrags
= idesc
->id_numfrags
; nfrags
> 0; blkno
++, nfrags
--) {
108 if (chkrange(blkno
, 1))
110 for (dlp
= duphead
; dlp
; dlp
= dlp
->next
) {
111 if (dlp
->dup
== blkno
) {
112 blkerror(idesc
->id_number
, "DUP", blkno
);
113 dlp
->dup
= duphead
->dup
;
114 duphead
->dup
= blkno
;
115 duphead
= duphead
->next
;
120 if (muldup
== 0 || duphead
== muldup
->next
)