15e53a4f9SPedro F. Giffuni /*- 25e53a4f9SPedro F. Giffuni * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 35e53a4f9SPedro F. Giffuni * 420938dbfSJuli Mallett * Copyright (c) 2002 Juli Mallett. All rights reserved. 520938dbfSJuli Mallett * 620938dbfSJuli Mallett * This software was written by Juli Mallett <jmallett@FreeBSD.org> for the 720938dbfSJuli Mallett * FreeBSD project. Redistribution and use in source and binary forms, with 820938dbfSJuli Mallett * or without modification, are permitted provided that the following 920938dbfSJuli Mallett * conditions are met: 1020938dbfSJuli Mallett * 1120938dbfSJuli Mallett * 1. Redistribution of source code must retain the above copyright notice, 1220938dbfSJuli Mallett * this list of conditions and the following disclaimer. 1320938dbfSJuli Mallett * 2. Redistribution in binary form must reproduce the above copyright 1420938dbfSJuli Mallett * notice, this list of conditions and the following disclaimer in the 1520938dbfSJuli Mallett * documentation and/or other materials provided with the distribution. 1620938dbfSJuli Mallett * 1720938dbfSJuli Mallett * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 1820938dbfSJuli Mallett * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 1920938dbfSJuli Mallett * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 2020938dbfSJuli Mallett * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, 2120938dbfSJuli Mallett * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 2220938dbfSJuli Mallett * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 2320938dbfSJuli Mallett * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2420938dbfSJuli Mallett * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 2520938dbfSJuli Mallett * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 2620938dbfSJuli Mallett * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 2720938dbfSJuli Mallett * POSSIBILITY OF SUCH DAMAGE. 2820938dbfSJuli Mallett */ 2920938dbfSJuli Mallett 3020938dbfSJuli Mallett #include <sys/cdefs.h> 3120938dbfSJuli Mallett __FBSDID("$FreeBSD$"); 3220938dbfSJuli Mallett 3320938dbfSJuli Mallett #include <sys/param.h> 3420938dbfSJuli Mallett #include <sys/mount.h> 3520938dbfSJuli Mallett #include <sys/disklabel.h> 3620938dbfSJuli Mallett #include <sys/stat.h> 3720938dbfSJuli Mallett 3820938dbfSJuli Mallett #include <ufs/ufs/ufsmount.h> 3920938dbfSJuli Mallett #include <ufs/ufs/dinode.h> 4020938dbfSJuli Mallett #include <ufs/ffs/fs.h> 4120938dbfSJuli Mallett 4220938dbfSJuli Mallett #include <errno.h> 4320938dbfSJuli Mallett #include <fcntl.h> 4420938dbfSJuli Mallett #include <stdio.h> 4520938dbfSJuli Mallett #include <stdlib.h> 4620938dbfSJuli Mallett #include <string.h> 4720938dbfSJuli Mallett #include <unistd.h> 4820938dbfSJuli Mallett 4920938dbfSJuli Mallett #include <libufs.h> 5020938dbfSJuli Mallett 5120938dbfSJuli Mallett int 52*9fc5d538SKirk McKusick getinode(struct uufsd *disk, union dinodep *dp, ino_t inum) 5320938dbfSJuli Mallett { 5420938dbfSJuli Mallett ino_t min, max; 5520938dbfSJuli Mallett caddr_t inoblock; 5620938dbfSJuli Mallett struct fs *fs; 5720938dbfSJuli Mallett 5849b2a686SJuli Mallett ERROR(disk, NULL); 5920938dbfSJuli Mallett 6020938dbfSJuli Mallett fs = &disk->d_fs; 61*9fc5d538SKirk McKusick if (inum >= (ino_t)fs->fs_ipg * fs->fs_ncg) { 620c94b536SKirk McKusick ERROR(disk, "inode number out of range"); 630c94b536SKirk McKusick return (-1); 640c94b536SKirk McKusick } 6520938dbfSJuli Mallett inoblock = disk->d_inoblock; 6620938dbfSJuli Mallett min = disk->d_inomin; 6720938dbfSJuli Mallett max = disk->d_inomax; 6820938dbfSJuli Mallett 6920938dbfSJuli Mallett if (inoblock == NULL) { 7020938dbfSJuli Mallett inoblock = malloc(fs->fs_bsize); 7120938dbfSJuli Mallett if (inoblock == NULL) { 7249b2a686SJuli Mallett ERROR(disk, "unable to allocate inode block"); 731081253fSJuli Mallett return (-1); 7420938dbfSJuli Mallett } 7520938dbfSJuli Mallett disk->d_inoblock = inoblock; 7620938dbfSJuli Mallett } 77*9fc5d538SKirk McKusick if (inum >= min && inum < max) 7820938dbfSJuli Mallett goto gotit; 79*9fc5d538SKirk McKusick bread(disk, fsbtodb(fs, ino_to_fsba(fs, inum)), inoblock, 8020938dbfSJuli Mallett fs->fs_bsize); 81*9fc5d538SKirk McKusick disk->d_inomin = min = inum - (inum % INOPB(fs)); 82cf6c0643SJuli Mallett disk->d_inomax = max = min + INOPB(fs); 8320938dbfSJuli Mallett gotit: switch (disk->d_ufs) { 8420938dbfSJuli Mallett case 1: 85*9fc5d538SKirk McKusick disk->d_dp.dp1 = &((struct ufs1_dinode *)inoblock)[inum - min]; 86*9fc5d538SKirk McKusick if (dp != NULL) 87*9fc5d538SKirk McKusick *dp = disk->d_dp; 881081253fSJuli Mallett return (0); 8920938dbfSJuli Mallett case 2: 90*9fc5d538SKirk McKusick disk->d_dp.dp2 = &((struct ufs2_dinode *)inoblock)[inum - min]; 91*9fc5d538SKirk McKusick if (dp != NULL) 92*9fc5d538SKirk McKusick *dp = disk->d_dp; 931081253fSJuli Mallett return (0); 9420938dbfSJuli Mallett default: 9520938dbfSJuli Mallett break; 9620938dbfSJuli Mallett } 9749b2a686SJuli Mallett ERROR(disk, "unknown UFS filesystem type"); 981081253fSJuli Mallett return (-1); 9920938dbfSJuli Mallett } 100113db2ddSJeff Roberson 101113db2ddSJeff Roberson int 102*9fc5d538SKirk McKusick putinode(struct uufsd *disk) 103113db2ddSJeff Roberson { 104113db2ddSJeff Roberson struct fs *fs; 105113db2ddSJeff Roberson 106113db2ddSJeff Roberson fs = &disk->d_fs; 107113db2ddSJeff Roberson if (disk->d_inoblock == NULL) { 108113db2ddSJeff Roberson ERROR(disk, "No inode block allocated"); 109113db2ddSJeff Roberson return (-1); 110113db2ddSJeff Roberson } 111113db2ddSJeff Roberson if (bwrite(disk, fsbtodb(fs, ino_to_fsba(&disk->d_fs, disk->d_inomin)), 112113db2ddSJeff Roberson disk->d_inoblock, disk->d_fs.fs_bsize) <= 0) 113113db2ddSJeff Roberson return (-1); 114113db2ddSJeff Roberson return (0); 115113db2ddSJeff Roberson } 116