* [PATCH] xfs_db: clean up the salvage read callsites in set_cur()
@ 2020-03-24 21:09 Darrick J. Wong
2020-03-24 23:20 ` Dave Chinner
2020-03-25 7:13 ` Christoph Hellwig
0 siblings, 2 replies; 3+ messages in thread
From: Darrick J. Wong @ 2020-03-24 21:09 UTC (permalink / raw)
To: xfs; +Cc: Eric Sandeen
From: Darrick J. Wong <darrick.wong@oracle.com>
Clean up the LIBXFS_READBUF_SALVAGE call sites in set_cur so that we
use the return value directly instead of scraping it out later.
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
---
db/io.c | 16 +++++++++-------
1 file changed, 9 insertions(+), 7 deletions(-)
diff --git a/db/io.c b/db/io.c
index 384e4c0f..6628d061 100644
--- a/db/io.c
+++ b/db/io.c
@@ -516,6 +516,7 @@ set_cur(
xfs_ino_t ino;
uint16_t mode;
const struct xfs_buf_ops *ops = type ? type->bops : NULL;
+ int error;
if (iocur_sp < 0) {
dbprintf(_("set_cur no stack element to set\n"));
@@ -542,20 +543,21 @@ set_cur(
if (!iocur_top->bbmap)
return;
memcpy(iocur_top->bbmap, bbmap, sizeof(struct bbmap));
- libxfs_buf_read_map(mp->m_ddev_targp, bbmap->b, bbmap->nmaps,
- LIBXFS_READBUF_SALVAGE, &bp, ops);
+ error = -libxfs_buf_read_map(mp->m_ddev_targp, bbmap->b,
+ bbmap->nmaps, LIBXFS_READBUF_SALVAGE, &bp,
+ ops);
} else {
- libxfs_buf_read(mp->m_ddev_targp, blknum, len,
+ error = -libxfs_buf_read(mp->m_ddev_targp, blknum, len,
LIBXFS_READBUF_SALVAGE, &bp, ops);
iocur_top->bbmap = NULL;
}
/*
- * Keep the buffer even if the verifier says it is corrupted.
- * We're a diagnostic tool, after all.
+ * Salvage mode means that we still get a buffer even if the verifier
+ * says the metadata is corrupt. Therefore, the only errors we should
+ * get are for IO errors or runtime errors.
*/
- if (!bp || (bp->b_error && bp->b_error != -EFSCORRUPTED &&
- bp->b_error != -EFSBADCRC))
+ if (error)
return;
iocur_top->buf = bp->b_addr;
iocur_top->bp = bp;
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] xfs_db: clean up the salvage read callsites in set_cur()
2020-03-24 21:09 [PATCH] xfs_db: clean up the salvage read callsites in set_cur() Darrick J. Wong
@ 2020-03-24 23:20 ` Dave Chinner
2020-03-25 7:13 ` Christoph Hellwig
1 sibling, 0 replies; 3+ messages in thread
From: Dave Chinner @ 2020-03-24 23:20 UTC (permalink / raw)
To: Darrick J. Wong; +Cc: xfs, Eric Sandeen
On Tue, Mar 24, 2020 at 02:09:56PM -0700, Darrick J. Wong wrote:
> From: Darrick J. Wong <darrick.wong@oracle.com>
>
> Clean up the LIBXFS_READBUF_SALVAGE call sites in set_cur so that we
> use the return value directly instead of scraping it out later.
>
> Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Makes sense.
Reviewed-by: Dave Chinner <dchinner@redhat.com>
--
Dave Chinner
david@fromorbit.com
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] xfs_db: clean up the salvage read callsites in set_cur()
2020-03-24 21:09 [PATCH] xfs_db: clean up the salvage read callsites in set_cur() Darrick J. Wong
2020-03-24 23:20 ` Dave Chinner
@ 2020-03-25 7:13 ` Christoph Hellwig
1 sibling, 0 replies; 3+ messages in thread
From: Christoph Hellwig @ 2020-03-25 7:13 UTC (permalink / raw)
To: Darrick J. Wong; +Cc: xfs, Eric Sandeen
On Tue, Mar 24, 2020 at 02:09:56PM -0700, Darrick J. Wong wrote:
> From: Darrick J. Wong <darrick.wong@oracle.com>
>
> Clean up the LIBXFS_READBUF_SALVAGE call sites in set_cur so that we
> use the return value directly instead of scraping it out later.
>
> Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Looks good,
Reviewed-by: Christoph Hellwig <hch@lst.de>
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2020-03-25 7:13 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-03-24 21:09 [PATCH] xfs_db: clean up the salvage read callsites in set_cur() Darrick J. Wong
2020-03-24 23:20 ` Dave Chinner
2020-03-25 7:13 ` Christoph Hellwig
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).