From 6625d44d90e2595c830275d585072e6c89f31bbb Mon Sep 17 00:00:00 2001 From: riastradh Date: Wed, 12 Aug 2015 14:52:35 +0000 Subject: [PATCH] Need wapbl transaction around ffs_blkfree_cg. Fixes wapbl+discard. --- sys/ufs/ffs/ffs_alloc.c | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/sys/ufs/ffs/ffs_alloc.c b/sys/ufs/ffs/ffs_alloc.c index 8764b2331679..f81a345f985c 100644 --- a/sys/ufs/ffs/ffs_alloc.c +++ b/sys/ufs/ffs/ffs_alloc.c @@ -1,4 +1,4 @@ -/* $NetBSD: ffs_alloc.c,v 1.150 2015/08/08 08:18:52 mlelstv Exp $ */ +/* $NetBSD: ffs_alloc.c,v 1.151 2015/08/12 14:52:35 riastradh Exp $ */ /*- * Copyright (c) 2008, 2009 The NetBSD Foundation, Inc. @@ -70,7 +70,7 @@ */ #include -__KERNEL_RCSID(0, "$NetBSD: ffs_alloc.c,v 1.150 2015/08/08 08:18:52 mlelstv Exp $"); +__KERNEL_RCSID(0, "$NetBSD: ffs_alloc.c,v 1.151 2015/08/12 14:52:35 riastradh Exp $"); #if defined(_KERNEL_OPT) #include "opt_ffs.h" @@ -1553,12 +1553,21 @@ struct discarddata { static void ffs_blkfree_td(struct fs *fs, struct discardopdata *td) { + struct mount *mp = spec_node_getmountedfs(td->devvp); long todo; + int error; while (td->size) { todo = min(td->size, ffs_lfragtosize(fs, (fs->fs_frag - ffs_fragnum(fs, td->bno)))); + error = UFS_WAPBL_BEGIN(mp); + if (error) { + printf("ffs: failed to begin wapbl transaction" + " for discard: %d\n", error); + break; + } ffs_blkfree_cg(fs, td->devvp, td->bno, todo); + UFS_WAPBL_END(mp); td->bno += ffs_numfrags(fs, todo); td->size -= todo; }