155859Sbostic /*- 2*61433Sbostic * Copyright (c) 1992, 1993 3*61433Sbostic * The Regents of the University of California. All rights reserved. 455859Sbostic * 555859Sbostic * %sccs.include.redist.c% 655859Sbostic */ 755859Sbostic 855859Sbostic #ifndef lint 9*61433Sbostic static char sccsid[] = "@(#)print.c 8.1 (Berkeley) 06/04/93"; 1055859Sbostic #endif /* not lint */ 1155859Sbostic 1255859Sbostic #include <sys/param.h> 1355859Sbostic #include <sys/ucred.h> 1455859Sbostic #include <sys/mount.h> 1555859Sbostic #include <sys/time.h> 1655859Sbostic 1755859Sbostic #include <ufs/ufs/dinode.h> 1855859Sbostic #include <ufs/lfs/lfs.h> 1955859Sbostic 2055859Sbostic #include <stdlib.h> 2155859Sbostic #include <stdio.h> 2255859Sbostic #include "clean.h" 2355859Sbostic 2455859Sbostic /* 2555859Sbostic * Print out a summary block; return number of blocks in segment; 0 2655859Sbostic * for empty segment or corrupt segment. 2755859Sbostic * Returns a pointer to the array of inode addresses. 2855859Sbostic */ 2955859Sbostic int 3055859Sbostic dump_summary(lfsp, sp, flags, iaddrp) 3155859Sbostic struct lfs *lfsp; 3255859Sbostic SEGSUM *sp; 3355859Sbostic u_long flags; 3455859Sbostic daddr_t **iaddrp; 3555859Sbostic { 3655859Sbostic int i, j, numblocks; 3755859Sbostic daddr_t *dp; 3855859Sbostic 3955859Sbostic FINFO *fp; 4055859Sbostic int ck; 4155859Sbostic 4255859Sbostic if (sp->ss_sumsum != (ck = cksum(&sp->ss_datasum, 4355859Sbostic LFS_SUMMARY_SIZE - sizeof(sp->ss_sumsum)))) 4455859Sbostic return(-1); 4555859Sbostic 4655859Sbostic if (flags & DUMP_SUM_HEADER) { 4755859Sbostic (void)printf(" %s0x%X\t%s%d\t%s%d\n %s0x%X\t%s0x%X", 4855859Sbostic "next ", sp->ss_next, 4955859Sbostic "nfinfo ", sp->ss_nfinfo, 5055859Sbostic "ninos ", sp->ss_ninos, 5155859Sbostic "sumsum ", sp->ss_sumsum, 5255859Sbostic "datasum ", sp->ss_datasum ); 5355859Sbostic (void)printf("\tcreate %s", ctime((time_t *)&sp->ss_create)); 5455859Sbostic } 5555859Sbostic 5655859Sbostic numblocks = (sp->ss_ninos + INOPB(lfsp) - 1) / INOPB(lfsp); 5755859Sbostic 5855859Sbostic /* Dump out inode disk addresses */ 5955859Sbostic if (flags & DUMP_INODE_ADDRS) 6055859Sbostic printf(" Inode addresses:"); 6155859Sbostic 6255859Sbostic dp = (daddr_t *)((caddr_t)sp + LFS_SUMMARY_SIZE); 6355859Sbostic for (--dp, i = 0; i < sp->ss_ninos; --dp) 6455859Sbostic if (flags & DUMP_INODE_ADDRS) { 6555859Sbostic (void)printf("\t0x%lx", *dp); 6655859Sbostic if (++i % 7 == 0) 6755859Sbostic (void)printf("\n"); 6855859Sbostic } else 6955859Sbostic ++i; 7055859Sbostic if (iaddrp) 7155859Sbostic *iaddrp = ++dp; 7255859Sbostic if (flags & DUMP_INODE_ADDRS) 7355859Sbostic printf("\n"); 7455859Sbostic 7555859Sbostic for (fp = (FINFO *)(sp + 1), i = 0; i < sp->ss_nfinfo; ++i) { 7655859Sbostic numblocks += fp->fi_nblocks; 7755859Sbostic if (flags & DUMP_FINFOS) { 7855859Sbostic (void)printf(" %s%d version %d nblocks %d\n", 7955859Sbostic "FINFO for inode: ", fp->fi_ino, 8055859Sbostic fp->fi_version, fp->fi_nblocks); 8155859Sbostic dp = &(fp->fi_blocks[0]); 8255859Sbostic for (j = 0; j < fp->fi_nblocks; j++, dp++) { 8355859Sbostic (void)printf("\t%d", *dp); 8455859Sbostic if ((j % 8) == 7) 8555859Sbostic (void)printf("\n"); 8655859Sbostic } 8755859Sbostic if ((j % 8) != 0) 8855859Sbostic (void)printf("\n"); 8955859Sbostic fp = (FINFO *)dp; 9055859Sbostic } else { 9155859Sbostic fp = (FINFO *)(&fp->fi_blocks[fp->fi_nblocks]); 9255859Sbostic } 9355859Sbostic } 9455859Sbostic return (numblocks); 9555859Sbostic } 9655859Sbostic 9755859Sbostic #ifdef VERBOSE 9855859Sbostic void 9955859Sbostic dump_cleaner_info(ipage) 10055859Sbostic void *ipage; 10155859Sbostic { 10255859Sbostic CLEANERINFO *cip; 10355859Sbostic 10455859Sbostic cip = (CLEANERINFO *)ipage; 10555859Sbostic (void)printf("segments clean\t%d\tsegments dirty\t%d\n\n", 10655859Sbostic cip->clean, cip->dirty); 10755859Sbostic } 10855859Sbostic 10955859Sbostic void 11055859Sbostic dump_super(lfsp) 11155859Sbostic struct lfs *lfsp; 11255859Sbostic { 11355859Sbostic int i; 11455859Sbostic 11555859Sbostic (void)printf("%s0x%X\t%s0x%X\t%s%d\t%s%d\n", 11655859Sbostic "magic ", lfsp->lfs_magic, 11755859Sbostic "version ", lfsp->lfs_version, 11855859Sbostic "size ", lfsp->lfs_size, 11955859Sbostic "ssize ", lfsp->lfs_ssize); 12055859Sbostic (void)printf("%s%d\t\t%s%d\t%s%d\t%s%d\n", 12155859Sbostic "dsize ", lfsp->lfs_dsize, 12255859Sbostic "bsize ", lfsp->lfs_bsize, 12355859Sbostic "fsize ", lfsp->lfs_fsize, 12455859Sbostic "frag ", lfsp->lfs_frag); 12555859Sbostic 12655859Sbostic (void)printf("%s%d\t\t%s%d\t%s%d\t%s%d\n", 12755859Sbostic "minfree ", lfsp->lfs_minfree, 12855859Sbostic "inopb ", lfsp->lfs_inopb, 12955859Sbostic "ifpb ", lfsp->lfs_ifpb, 13055859Sbostic "nindir ", lfsp->lfs_nindir); 13155859Sbostic 13255859Sbostic (void)printf("%s%d\t\t%s%d\t%s%d\t%s%d\n", 13355859Sbostic "nseg ", lfsp->lfs_nseg, 13455859Sbostic "nspf ", lfsp->lfs_nspf, 13555859Sbostic "cleansz ", lfsp->lfs_cleansz, 13655859Sbostic "segtabsz ", lfsp->lfs_segtabsz); 13755859Sbostic 13855859Sbostic (void)printf("%s0x%X\t%s%d\t%s0x%X\t%s%d\n", 13955859Sbostic "segmask ", lfsp->lfs_segmask, 14055859Sbostic "segshift ", lfsp->lfs_segshift, 14155859Sbostic "bmask ", lfsp->lfs_bmask, 14255859Sbostic "bshift ", lfsp->lfs_bshift); 14355859Sbostic 14455859Sbostic (void)printf("%s0x%X\t\t%s%d\t%s0x%X\t%s%d\n", 14555859Sbostic "ffmask ", lfsp->lfs_ffmask, 14655859Sbostic "ffshift ", lfsp->lfs_ffshift, 14755859Sbostic "fbmask ", lfsp->lfs_fbmask, 14855859Sbostic "fbshift ", lfsp->lfs_fbshift); 14955859Sbostic 15055859Sbostic (void)printf("%s%d\t\t%s0x%X\t%s0x%qx\n", 15155859Sbostic "fsbtodb ", lfsp->lfs_fsbtodb, 15255859Sbostic "cksum ", lfsp->lfs_cksum, 15355859Sbostic "maxfilesize ", lfsp->lfs_maxfilesize); 15455859Sbostic 15555859Sbostic (void)printf("Superblock disk addresses:\t"); 15655859Sbostic for (i = 0; i < LFS_MAXNUMSB; i++) { 15755859Sbostic (void)printf(" 0x%X", lfsp->lfs_sboffs[i]); 15855859Sbostic if ( i == (LFS_MAXNUMSB >> 1)) 15955859Sbostic (void)printf("\n\t\t\t\t"); 16055859Sbostic } 16155859Sbostic (void)printf("\n"); 16255859Sbostic 16355859Sbostic (void)printf("Checkpoint Info\n"); 16455859Sbostic (void)printf("%s%d\t%s0x%X\t%s%d\n", 16555859Sbostic "free ", lfsp->lfs_free, 16655859Sbostic "idaddr ", lfsp->lfs_idaddr, 16755859Sbostic "ifile ", lfsp->lfs_ifile); 16855932Sbostic (void)printf("%s%d\t%s%d\t%s%d\n", 16955859Sbostic "bfree ", lfsp->lfs_bfree, 17055932Sbostic "avail ", lfsp->lfs_avail, 17155932Sbostic "uinodes ", lfsp->lfs_uinodes); 17255932Sbostic (void)printf("%s%d\t%s0x%X\t%s0x%X\n%s0x%X\t%s0x%X\t", 17355859Sbostic "nfiles ", lfsp->lfs_nfiles, 17455859Sbostic "lastseg ", lfsp->lfs_lastseg, 17555859Sbostic "nextseg ", lfsp->lfs_nextseg, 17655859Sbostic "curseg ", lfsp->lfs_curseg, 17755859Sbostic "offset ", lfsp->lfs_offset); 17855859Sbostic (void)printf("tstamp %s", ctime((time_t *)&lfsp->lfs_tstamp)); 17955859Sbostic (void)printf("\nIn-Memory Information\n"); 18055859Sbostic (void)printf("%s%d\t%s0x%X\t%s%d\t%s%d\t%s%d\n", 18155859Sbostic "seglock ", lfsp->lfs_seglock, 18255859Sbostic "iocount ", lfsp->lfs_iocount, 18355859Sbostic "writer ", lfsp->lfs_writer, 18455859Sbostic "dirops ", lfsp->lfs_dirops, 18555859Sbostic "doifile ", lfsp->lfs_doifile ); 18655932Sbostic (void)printf("%s%d\t%s%d\t%s0x%X\t%s%d\n", 18755932Sbostic "nactive ", lfsp->lfs_nactive, 18855859Sbostic "fmod ", lfsp->lfs_fmod, 18955859Sbostic "clean ", lfsp->lfs_clean, 19055859Sbostic "ronly ", lfsp->lfs_ronly); 19155859Sbostic } 19255859Sbostic #endif /* VERBOSE */ 193