xref: /openbsd-src/sbin/fsck_ffs/pass3.c (revision 78eb0b7e750a8abce6d5bf75f3980c4936ee0c1c)
1*78eb0b7eSderaadt /*	$OpenBSD: pass3.c,v 1.18 2015/01/20 18:22:21 deraadt Exp $	*/
2df930be7Sderaadt /*	$NetBSD: pass3.c,v 1.8 1995/03/18 14:55:54 cgd Exp $	*/
3df930be7Sderaadt 
4df930be7Sderaadt /*
5df930be7Sderaadt  * Copyright (c) 1980, 1986, 1993
6df930be7Sderaadt  *	The Regents of the University of California.  All rights reserved.
7df930be7Sderaadt  *
8df930be7Sderaadt  * Redistribution and use in source and binary forms, with or without
9df930be7Sderaadt  * modification, are permitted provided that the following conditions
10df930be7Sderaadt  * are met:
11df930be7Sderaadt  * 1. Redistributions of source code must retain the above copyright
12df930be7Sderaadt  *    notice, this list of conditions and the following disclaimer.
13df930be7Sderaadt  * 2. Redistributions in binary form must reproduce the above copyright
14df930be7Sderaadt  *    notice, this list of conditions and the following disclaimer in the
15df930be7Sderaadt  *    documentation and/or other materials provided with the distribution.
161ef0d710Smillert  * 3. Neither the name of the University nor the names of its contributors
17df930be7Sderaadt  *    may be used to endorse or promote products derived from this software
18df930be7Sderaadt  *    without specific prior written permission.
19df930be7Sderaadt  *
20df930be7Sderaadt  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
21df930be7Sderaadt  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22df930be7Sderaadt  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23df930be7Sderaadt  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24df930be7Sderaadt  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25df930be7Sderaadt  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26df930be7Sderaadt  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27df930be7Sderaadt  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28df930be7Sderaadt  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29df930be7Sderaadt  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30df930be7Sderaadt  * SUCH DAMAGE.
31df930be7Sderaadt  */
32df930be7Sderaadt 
33df930be7Sderaadt #include <sys/time.h>
34df930be7Sderaadt #include <ufs/ufs/dinode.h>
35df930be7Sderaadt #include <ufs/ffs/fs.h>
36af9e537cSd #include <stdio.h>
37df930be7Sderaadt #include "fsck.h"
38df930be7Sderaadt #include "extern.h"
39df930be7Sderaadt 
40af9e537cSd static int info_pos;
41af9e537cSd 
42af9e537cSd static int
pass3_info(char * buf,size_t buflen)43379d1969Sderaadt pass3_info(char *buf, size_t buflen)
44af9e537cSd {
45379d1969Sderaadt 	return (snprintf(buf, buflen, "phase 3, directory %d/%ld",
46f3039facSmillert 	    info_pos, inplast) > 0);
47af9e537cSd }
48af9e537cSd 
49df930be7Sderaadt void
pass3(void)5060d6b16fSgluk pass3(void)
51df930be7Sderaadt {
52e073c79dSmpech 	struct inoinfo **inpp, *inp, *pinp;
53df930be7Sderaadt 	ino_t orphan;
54df930be7Sderaadt 	int loopcnt;
55df930be7Sderaadt 
56af9e537cSd 	info_fn = pass3_info;
57df930be7Sderaadt 	for (inpp = &inpsort[inplast - 1]; inpp >= inpsort; inpp--) {
58af9e537cSd 		info_pos++;
59df930be7Sderaadt 		inp = *inpp;
60df930be7Sderaadt 		if (inp->i_number == ROOTINO ||
614aab0ea5Sotto 		    (inp->i_parent != 0 && GET_ISTATE(inp->i_number) != DSTATE))
62df930be7Sderaadt 			continue;
634aab0ea5Sotto 		if (GET_ISTATE(inp->i_number) == DCLEAR)
64df930be7Sderaadt 			continue;
65df930be7Sderaadt 		for (loopcnt = 0; ; loopcnt++) {
66df930be7Sderaadt 			orphan = inp->i_number;
67df930be7Sderaadt 			if (inp->i_parent == 0 ||
684aab0ea5Sotto 			    GET_ISTATE(inp->i_parent) != DSTATE ||
69df930be7Sderaadt 			    loopcnt > numdirs)
70df930be7Sderaadt 				break;
71df930be7Sderaadt 			inp = getinoinfo(inp->i_parent);
72df930be7Sderaadt 		}
731fb4224cSgluk 		if (linkup(orphan, inp->i_dotdot)) {
74df930be7Sderaadt 			inp->i_parent = inp->i_dotdot = lfdir;
754d91232bSotto 			ILNCOUNT(lfdir)--;
761fb4224cSgluk 			pinp = getinoinfo(inp->i_parent);
771fb4224cSgluk 			inp->i_sibling = pinp->i_child;
781fb4224cSgluk 			pinp->i_child = inp;
794aab0ea5Sotto 			SET_ISTATE(orphan, GET_ISTATE(inp->i_parent));
801fb4224cSgluk 		}
811fb4224cSgluk 		propagate(orphan);
82df930be7Sderaadt 	}
83af9e537cSd 	info_fn = NULL;
84df930be7Sderaadt }
85