155859Sbostic /*-
261433Sbostic * Copyright (c) 1992, 1993
361433Sbostic * The Regents of the University of California. All rights reserved.
455859Sbostic *
555859Sbostic * %sccs.include.redist.c%
655859Sbostic */
755859Sbostic
855859Sbostic #ifndef lint
9*69669Smargo static char sccsid[] = "@(#)print.c 8.2 (Berkeley) 05/24/95";
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
dump_summary(lfsp,sp,flags,iaddrp)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
42*69669Smargo if (sp->ss_magic != SS_MAGIC)
43*69669Smargo return(-1);
44*69669Smargo
4555859Sbostic if (sp->ss_sumsum != (ck = cksum(&sp->ss_datasum,
4655859Sbostic LFS_SUMMARY_SIZE - sizeof(sp->ss_sumsum))))
4755859Sbostic return(-1);
4855859Sbostic
49*69669Smargo numblocks = (sp->ss_ninos + INOPB(lfsp) - 1) / INOPB(lfsp);
50*69669Smargo
51*69669Smargo /* Do some basic sanity checking. */
52*69669Smargo if (sp->ss_nfinfo > LFS_SUMMARY_SIZE / sizeof(FINFO) ||
53*69669Smargo numblocks > lfsp->lfs_ssize ||
54*69669Smargo numblocks > LFS_SUMMARY_SIZE / sizeof(daddr_t))
55*69669Smargo return(-1);
56*69669Smargo
5755859Sbostic if (flags & DUMP_SUM_HEADER) {
58*69669Smargo (void)printf(" %s0x%X\t%s%d\t%s%d\n %s0x%X\t%s0x%X\t%s0x%X\n",
5955859Sbostic "next ", sp->ss_next,
6055859Sbostic "nfinfo ", sp->ss_nfinfo,
6155859Sbostic "ninos ", sp->ss_ninos,
6255859Sbostic "sumsum ", sp->ss_sumsum,
63*69669Smargo "datasum ", sp->ss_datasum,
64*69669Smargo "magic ", sp->ss_magic);
65*69669Smargo (void)printf(" create %s", ctime((time_t *)&sp->ss_create));
6655859Sbostic }
6755859Sbostic
6855859Sbostic /* Dump out inode disk addresses */
6955859Sbostic if (flags & DUMP_INODE_ADDRS)
7055859Sbostic printf(" Inode addresses:");
7155859Sbostic
7255859Sbostic dp = (daddr_t *)((caddr_t)sp + LFS_SUMMARY_SIZE);
7355859Sbostic for (--dp, i = 0; i < sp->ss_ninos; --dp)
7455859Sbostic if (flags & DUMP_INODE_ADDRS) {
7555859Sbostic (void)printf("\t0x%lx", *dp);
7655859Sbostic if (++i % 7 == 0)
7755859Sbostic (void)printf("\n");
7855859Sbostic } else
7955859Sbostic ++i;
8055859Sbostic if (iaddrp)
8155859Sbostic *iaddrp = ++dp;
8255859Sbostic if (flags & DUMP_INODE_ADDRS)
8355859Sbostic printf("\n");
8455859Sbostic
8555859Sbostic for (fp = (FINFO *)(sp + 1), i = 0; i < sp->ss_nfinfo; ++i) {
8655859Sbostic numblocks += fp->fi_nblocks;
8755859Sbostic if (flags & DUMP_FINFOS) {
8855859Sbostic (void)printf(" %s%d version %d nblocks %d\n",
8955859Sbostic "FINFO for inode: ", fp->fi_ino,
9055859Sbostic fp->fi_version, fp->fi_nblocks);
9155859Sbostic dp = &(fp->fi_blocks[0]);
9255859Sbostic for (j = 0; j < fp->fi_nblocks; j++, dp++) {
9355859Sbostic (void)printf("\t%d", *dp);
9455859Sbostic if ((j % 8) == 7)
9555859Sbostic (void)printf("\n");
9655859Sbostic }
9755859Sbostic if ((j % 8) != 0)
9855859Sbostic (void)printf("\n");
9955859Sbostic fp = (FINFO *)dp;
10055859Sbostic } else {
10155859Sbostic fp = (FINFO *)(&fp->fi_blocks[fp->fi_nblocks]);
10255859Sbostic }
10355859Sbostic }
10455859Sbostic return (numblocks);
10555859Sbostic }
10655859Sbostic
10755859Sbostic #ifdef VERBOSE
10855859Sbostic void
dump_cleaner_info(ipage)10955859Sbostic dump_cleaner_info(ipage)
11055859Sbostic void *ipage;
11155859Sbostic {
11255859Sbostic CLEANERINFO *cip;
11355859Sbostic
11455859Sbostic cip = (CLEANERINFO *)ipage;
11555859Sbostic (void)printf("segments clean\t%d\tsegments dirty\t%d\n\n",
11655859Sbostic cip->clean, cip->dirty);
11755859Sbostic }
11855859Sbostic
11955859Sbostic void
dump_super(lfsp)12055859Sbostic dump_super(lfsp)
12155859Sbostic struct lfs *lfsp;
12255859Sbostic {
12355859Sbostic int i;
12455859Sbostic
12555859Sbostic (void)printf("%s0x%X\t%s0x%X\t%s%d\t%s%d\n",
12655859Sbostic "magic ", lfsp->lfs_magic,
12755859Sbostic "version ", lfsp->lfs_version,
12855859Sbostic "size ", lfsp->lfs_size,
12955859Sbostic "ssize ", lfsp->lfs_ssize);
13055859Sbostic (void)printf("%s%d\t\t%s%d\t%s%d\t%s%d\n",
13155859Sbostic "dsize ", lfsp->lfs_dsize,
13255859Sbostic "bsize ", lfsp->lfs_bsize,
13355859Sbostic "fsize ", lfsp->lfs_fsize,
13455859Sbostic "frag ", lfsp->lfs_frag);
13555859Sbostic
13655859Sbostic (void)printf("%s%d\t\t%s%d\t%s%d\t%s%d\n",
13755859Sbostic "minfree ", lfsp->lfs_minfree,
13855859Sbostic "inopb ", lfsp->lfs_inopb,
13955859Sbostic "ifpb ", lfsp->lfs_ifpb,
14055859Sbostic "nindir ", lfsp->lfs_nindir);
14155859Sbostic
14255859Sbostic (void)printf("%s%d\t\t%s%d\t%s%d\t%s%d\n",
14355859Sbostic "nseg ", lfsp->lfs_nseg,
14455859Sbostic "nspf ", lfsp->lfs_nspf,
14555859Sbostic "cleansz ", lfsp->lfs_cleansz,
14655859Sbostic "segtabsz ", lfsp->lfs_segtabsz);
14755859Sbostic
148*69669Smargo (void)printf("%s0x%X\t%s%d\t%s0x%qX\t%s%d\n",
14955859Sbostic "segmask ", lfsp->lfs_segmask,
15055859Sbostic "segshift ", lfsp->lfs_segshift,
15155859Sbostic "bmask ", lfsp->lfs_bmask,
15255859Sbostic "bshift ", lfsp->lfs_bshift);
15355859Sbostic
154*69669Smargo (void)printf("%s0x%qX\t\t%s%d\t%s0x%qX\t%s%d\n",
15555859Sbostic "ffmask ", lfsp->lfs_ffmask,
15655859Sbostic "ffshift ", lfsp->lfs_ffshift,
15755859Sbostic "fbmask ", lfsp->lfs_fbmask,
15855859Sbostic "fbshift ", lfsp->lfs_fbshift);
15955859Sbostic
16055859Sbostic (void)printf("%s%d\t\t%s0x%X\t%s0x%qx\n",
16155859Sbostic "fsbtodb ", lfsp->lfs_fsbtodb,
16255859Sbostic "cksum ", lfsp->lfs_cksum,
16355859Sbostic "maxfilesize ", lfsp->lfs_maxfilesize);
16455859Sbostic
16555859Sbostic (void)printf("Superblock disk addresses:\t");
16655859Sbostic for (i = 0; i < LFS_MAXNUMSB; i++) {
16755859Sbostic (void)printf(" 0x%X", lfsp->lfs_sboffs[i]);
16855859Sbostic if ( i == (LFS_MAXNUMSB >> 1))
16955859Sbostic (void)printf("\n\t\t\t\t");
17055859Sbostic }
17155859Sbostic (void)printf("\n");
17255859Sbostic
17355859Sbostic (void)printf("Checkpoint Info\n");
17455859Sbostic (void)printf("%s%d\t%s0x%X\t%s%d\n",
17555859Sbostic "free ", lfsp->lfs_free,
17655859Sbostic "idaddr ", lfsp->lfs_idaddr,
17755859Sbostic "ifile ", lfsp->lfs_ifile);
17855932Sbostic (void)printf("%s%d\t%s%d\t%s%d\n",
17955859Sbostic "bfree ", lfsp->lfs_bfree,
18055932Sbostic "avail ", lfsp->lfs_avail,
18155932Sbostic "uinodes ", lfsp->lfs_uinodes);
18255932Sbostic (void)printf("%s%d\t%s0x%X\t%s0x%X\n%s0x%X\t%s0x%X\t",
18355859Sbostic "nfiles ", lfsp->lfs_nfiles,
18455859Sbostic "lastseg ", lfsp->lfs_lastseg,
18555859Sbostic "nextseg ", lfsp->lfs_nextseg,
18655859Sbostic "curseg ", lfsp->lfs_curseg,
18755859Sbostic "offset ", lfsp->lfs_offset);
18855859Sbostic (void)printf("tstamp %s", ctime((time_t *)&lfsp->lfs_tstamp));
18955859Sbostic (void)printf("\nIn-Memory Information\n");
19055859Sbostic (void)printf("%s%d\t%s0x%X\t%s%d\t%s%d\t%s%d\n",
19155859Sbostic "seglock ", lfsp->lfs_seglock,
19255859Sbostic "iocount ", lfsp->lfs_iocount,
19355859Sbostic "writer ", lfsp->lfs_writer,
19455859Sbostic "dirops ", lfsp->lfs_dirops,
19555859Sbostic "doifile ", lfsp->lfs_doifile );
19655932Sbostic (void)printf("%s%d\t%s%d\t%s0x%X\t%s%d\n",
19755932Sbostic "nactive ", lfsp->lfs_nactive,
19855859Sbostic "fmod ", lfsp->lfs_fmod,
19955859Sbostic "clean ", lfsp->lfs_clean,
20055859Sbostic "ronly ", lfsp->lfs_ronly);
20155859Sbostic }
20255859Sbostic #endif /* VERBOSE */
203