diff options
author | kib <kib@FreeBSD.org> | 2008-09-16 11:19:38 +0000 |
---|---|---|
committer | kib <kib@FreeBSD.org> | 2008-09-16 11:19:38 +0000 |
commit | 0488506405edd848b205c59066a7f0b5d53e55e7 (patch) | |
tree | 5722b46dbcf6b76aa1eb0334df5da361e5c92f37 | |
parent | 039c5da1b25fe16e767d26bf96a871642f599a7f (diff) | |
download | FreeBSD-src-0488506405edd848b205c59066a7f0b5d53e55e7.zip FreeBSD-src-0488506405edd848b205c59066a7f0b5d53e55e7.tar.gz |
Add the ffs structures introspection functions for ddb.
Show the b_dep value for the buffer in the show buffer command.
Add a comand to dump the dirty/clean buffer list for vnode.
Reviewed by: tegge
Tested and used by: pho
MFC after: 1 month
-rw-r--r-- | share/man/man4/ddb.4 | 20 | ||||
-rw-r--r-- | sys/kern/vfs_bio.c | 27 | ||||
-rw-r--r-- | sys/ufs/ffs/ffs_softdep.c | 31 | ||||
-rw-r--r-- | sys/ufs/ffs/ffs_vfsops.c | 35 |
4 files changed, 110 insertions, 3 deletions
diff --git a/share/man/man4/ddb.4 b/share/man/man4/ddb.4 index 69f11ef..838ecff 100644 --- a/share/man/man4/ddb.4 +++ b/share/man/man4/ddb.4 @@ -610,6 +610,13 @@ See the header file for more details on the exact meaning of the structure fields. .\" .Pp +.It Ic show Cm ffs Op Ar addr +Show brief information about ffs mount at the address +.Ar addr , +if argument is given. +Otherwise, provides the summary about each ffs mount. +.\" +.Pp .It Ic show Cm file Ar addr Show information about the file structure .Vt struct file @@ -642,6 +649,14 @@ The second one is the name of the interrupt/trap handler. Those functions are machine dependent. .\" .Pp +.It Ic show Cm inodedeps Op Ar addr +Show brief information about each inodedep structure. +If +.Ar addr +is given, only inodedeps belonging to the fs located at the +supplied address are shown. +.\" +.Pp .It Ic show Cm inpcb Ar addr Show information on IP Control Block .Vt struct in_pcb @@ -1019,6 +1034,11 @@ For the exact interpretation of the output, look at the header file. .\" .Pp +.It Ic show Cm vnodebufs Ar addr +Shows clean/dirty buffer lists of the vnode located at +.Ar addr . +.\" +.Pp .It Ic show Cm watches Displays all watchpoints. Shows watchpoints set with "watch" command. diff --git a/sys/kern/vfs_bio.c b/sys/kern/vfs_bio.c index 1570bd7..239ee5a 100644 --- a/sys/kern/vfs_bio.c +++ b/sys/kern/vfs_bio.c @@ -3903,9 +3903,10 @@ DB_SHOW_COMMAND(buffer, db_show_buffer) db_printf("b_flags = 0x%b\n", (u_int)bp->b_flags, PRINT_BUF_FLAGS); db_printf( "b_error = %d, b_bufsize = %ld, b_bcount = %ld, b_resid = %ld\n" - "b_bufobj = (%p), b_data = %p, b_blkno = %jd\n", + "b_bufobj = (%p), b_data = %p, b_blkno = %jd, b_dep = %p\n", bp->b_error, bp->b_bufsize, bp->b_bcount, bp->b_resid, - bp->b_bufobj, bp->b_data, (intmax_t)bp->b_blkno); + bp->b_bufobj, bp->b_data, (intmax_t)bp->b_blkno, + bp->b_dep.lh_first); if (bp->b_npages) { int i; db_printf("b_npages = %d, pages(OBJ, IDX, PA): ", bp->b_npages); @@ -3935,4 +3936,26 @@ DB_SHOW_COMMAND(lockedbufs, lockedbufs) } } } + +DB_SHOW_COMMAND(vnodebufs, db_show_vnodebufs) +{ + struct vnode *vp; + struct buf *bp; + + if (!have_addr) { + db_printf("usage: show vnodebufs <addr>\n"); + return; + } + vp = (struct vnode *)addr; + db_printf("Clean buffers:\n"); + TAILQ_FOREACH(bp, &vp->v_bufobj.bo_clean.bv_hd, b_bobufs) { + db_show_buffer((uintptr_t)bp, 1, 0, NULL); + db_printf("\n"); + } + db_printf("Dirty buffers:\n"); + TAILQ_FOREACH(bp, &vp->v_bufobj.bo_dirty.bv_hd, b_bobufs) { + db_show_buffer((uintptr_t)bp, 1, 0, NULL); + db_printf("\n"); + } +} #endif /* DDB */ diff --git a/sys/ufs/ffs/ffs_softdep.c b/sys/ufs/ffs/ffs_softdep.c index ae532b6..3c9a906 100644 --- a/sys/ufs/ffs/ffs_softdep.c +++ b/sys/ufs/ffs/ffs_softdep.c @@ -41,6 +41,9 @@ #include <sys/cdefs.h> __FBSDID("$FreeBSD$"); +#include "opt_ffs.h" +#include "opt_ddb.h" + /* * For now we want the safety net that the DEBUG flag provides. */ @@ -77,7 +80,7 @@ __FBSDID("$FreeBSD$"); #include <vm/vm.h> -#include "opt_ffs.h" +#include <ddb/ddb.h> #ifndef SOFTUPDATES @@ -6334,4 +6337,30 @@ softdep_error(func, error) printf("%s: got error %d while accessing filesystem\n", func, error); } +#ifdef DDB + +DB_SHOW_COMMAND(inodedeps, db_show_inodedeps) +{ + struct inodedep_hashhead *inodedephd; + struct inodedep *inodedep; + struct fs *fs; + int cnt; + + fs = have_addr ? (struct fs *)addr : NULL; + for (cnt = 0; cnt < inodedep_hash; cnt++) { + inodedephd = &inodedep_hashtbl[cnt]; + LIST_FOREACH(inodedep, inodedephd, id_hash) { + if (fs != NULL && fs != inodedep->id_fs) + continue; + db_printf("%p fs %p st %x ino %jd inoblk %jd\n", + inodedep, inodedep->id_fs, inodedep->id_state, + (intmax_t)inodedep->id_ino, + (intmax_t)fsbtodb(inodedep->id_fs, + ino_to_fsba(inodedep->id_fs, inodedep->id_ino))); + } + } +} + +#endif /* DDB */ + #endif /* SOFTUPDATES */ diff --git a/sys/ufs/ffs/ffs_vfsops.c b/sys/ufs/ffs/ffs_vfsops.c index 67d4496..93e0b48 100644 --- a/sys/ufs/ffs/ffs_vfsops.c +++ b/sys/ufs/ffs/ffs_vfsops.c @@ -36,6 +36,7 @@ __FBSDID("$FreeBSD$"); #include "opt_quota.h" #include "opt_ufs.h" #include "opt_ffs.h" +#include "opt_ddb.h" #include <sys/param.h> #include <sys/systm.h> @@ -71,6 +72,8 @@ __FBSDID("$FreeBSD$"); #include <geom/geom.h> #include <geom/geom_vfs.h> +#include <ddb/ddb.h> + static uma_zone_t uma_inode, uma_ufs1, uma_ufs2; static int ffs_reload(struct mount *, struct thread *); @@ -1863,3 +1866,35 @@ ffs_geom_strategy(struct bufobj *bo, struct buf *bp) } g_vfs_strategy(bo, bp); } + +#ifdef DDB + +static void +db_print_ffs(struct ufsmount *ump) +{ + db_printf("mp %p %s devvp %p fs %p su_wl %d su_wl_in %d su_deps %d " + "su_req %d\n", + ump->um_mountp, ump->um_mountp->mnt_stat.f_mntonname, + ump->um_devvp, ump->um_fs, ump->softdep_on_worklist, + ump->softdep_on_worklist_inprogress, ump->softdep_deps, + ump->softdep_req); +} + +DB_SHOW_COMMAND(ffs, db_show_ffs) +{ + struct mount *mp; + struct ufsmount *ump; + + if (have_addr) { + ump = VFSTOUFS((struct mount *)addr); + db_print_ffs(ump); + return; + } + + TAILQ_FOREACH(mp, &mountlist, mnt_list) { + if (!strcmp(mp->mnt_stat.f_fstypename, ufs_vfsconf.vfc_name)) + db_print_ffs(VFSTOUFS(mp)); + } +} + +#endif /* DDB */ |