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