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