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 38*d485c77fSKonstantin Belousov #include <ufs/ufs/extattr.h> 39*d485c77fSKonstantin Belousov #include <ufs/ufs/quota.h> 4020938dbfSJuli Mallett #include <ufs/ufs/ufsmount.h> 4120938dbfSJuli Mallett #include <ufs/ufs/dinode.h> 4220938dbfSJuli Mallett #include <ufs/ffs/fs.h> 4320938dbfSJuli Mallett 4420938dbfSJuli Mallett #include <errno.h> 4520938dbfSJuli Mallett #include <fcntl.h> 4620938dbfSJuli Mallett #include <stdio.h> 4720938dbfSJuli Mallett #include <stdlib.h> 4820938dbfSJuli Mallett #include <string.h> 4920938dbfSJuli Mallett #include <unistd.h> 5020938dbfSJuli Mallett 5120938dbfSJuli Mallett #include <libufs.h> 5220938dbfSJuli Mallett 5320938dbfSJuli Mallett int 549fc5d538SKirk McKusick getinode(struct uufsd *disk, union dinodep *dp, ino_t inum) 5520938dbfSJuli Mallett { 5620938dbfSJuli Mallett ino_t min, max; 5720938dbfSJuli Mallett caddr_t inoblock; 5820938dbfSJuli Mallett struct fs *fs; 5920938dbfSJuli Mallett 6049b2a686SJuli Mallett ERROR(disk, NULL); 6120938dbfSJuli Mallett 6220938dbfSJuli Mallett fs = &disk->d_fs; 639fc5d538SKirk McKusick if (inum >= (ino_t)fs->fs_ipg * fs->fs_ncg) { 640c94b536SKirk McKusick ERROR(disk, "inode number out of range"); 650c94b536SKirk McKusick return (-1); 660c94b536SKirk McKusick } 6720938dbfSJuli Mallett inoblock = disk->d_inoblock; 6820938dbfSJuli Mallett min = disk->d_inomin; 6920938dbfSJuli Mallett max = disk->d_inomax; 7020938dbfSJuli Mallett 7120938dbfSJuli Mallett if (inoblock == NULL) { 7220938dbfSJuli Mallett inoblock = malloc(fs->fs_bsize); 7320938dbfSJuli Mallett if (inoblock == NULL) { 7449b2a686SJuli Mallett ERROR(disk, "unable to allocate inode block"); 751081253fSJuli Mallett return (-1); 7620938dbfSJuli Mallett } 7720938dbfSJuli Mallett disk->d_inoblock = inoblock; 7820938dbfSJuli Mallett } 799fc5d538SKirk McKusick if (inum >= min && inum < max) 8020938dbfSJuli Mallett goto gotit; 819fc5d538SKirk McKusick bread(disk, fsbtodb(fs, ino_to_fsba(fs, inum)), inoblock, 8220938dbfSJuli Mallett fs->fs_bsize); 839fc5d538SKirk McKusick disk->d_inomin = min = inum - (inum % INOPB(fs)); 84cf6c0643SJuli Mallett disk->d_inomax = max = min + INOPB(fs); 8520938dbfSJuli Mallett gotit: switch (disk->d_ufs) { 8620938dbfSJuli Mallett case 1: 879fc5d538SKirk McKusick disk->d_dp.dp1 = &((struct ufs1_dinode *)inoblock)[inum - min]; 889fc5d538SKirk McKusick if (dp != NULL) 899fc5d538SKirk McKusick *dp = disk->d_dp; 901081253fSJuli Mallett return (0); 9120938dbfSJuli Mallett case 2: 929fc5d538SKirk McKusick disk->d_dp.dp2 = &((struct ufs2_dinode *)inoblock)[inum - min]; 939fc5d538SKirk McKusick if (dp != NULL) 949fc5d538SKirk McKusick *dp = disk->d_dp; 958f829a5cSKirk McKusick if (ffs_verify_dinode_ckhash(fs, disk->d_dp.dp2) == 0) 961081253fSJuli Mallett return (0); 978f829a5cSKirk McKusick ERROR(disk, "check-hash failed for inode read from disk"); 988f829a5cSKirk McKusick return (-1); 9920938dbfSJuli Mallett default: 10020938dbfSJuli Mallett break; 10120938dbfSJuli Mallett } 10249b2a686SJuli Mallett ERROR(disk, "unknown UFS filesystem type"); 1031081253fSJuli Mallett return (-1); 10420938dbfSJuli Mallett } 105113db2ddSJeff Roberson 106113db2ddSJeff Roberson int 1079fc5d538SKirk McKusick putinode(struct uufsd *disk) 108113db2ddSJeff Roberson { 109113db2ddSJeff Roberson struct fs *fs; 110113db2ddSJeff Roberson 111113db2ddSJeff Roberson fs = &disk->d_fs; 112113db2ddSJeff Roberson if (disk->d_inoblock == NULL) { 113113db2ddSJeff Roberson ERROR(disk, "No inode block allocated"); 114113db2ddSJeff Roberson return (-1); 115113db2ddSJeff Roberson } 1168f829a5cSKirk McKusick if (disk->d_ufs == 2) 1178f829a5cSKirk McKusick ffs_update_dinode_ckhash(fs, disk->d_dp.dp2); 118113db2ddSJeff Roberson if (bwrite(disk, fsbtodb(fs, ino_to_fsba(&disk->d_fs, disk->d_inomin)), 119113db2ddSJeff Roberson disk->d_inoblock, disk->d_fs.fs_bsize) <= 0) 120113db2ddSJeff Roberson return (-1); 121113db2ddSJeff Roberson return (0); 122113db2ddSJeff Roberson } 123