Persistent L2ARC minor fixes

Minor fixes on persistent L2ARC improving code readability and fixing 
a typo in zdb.c when byte-swapping a log block. It also improves the 
pesist_l2arc_007_pos.ksh test by giving it more time to retrieve log 
blocks on the cache device.

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Reviewed-by: Adam D. Moss <c@yotes.com>
Signed-off-by: George Amanakis <gamanakis@gmail.com>
Closes #10210
This commit is contained in:
George Amanakis 2020-04-17 12:27:40 -04:00 committed by GitHub
parent a7929f3137
commit 9249f1272e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 9 additions and 12 deletions

View File

@ -3606,8 +3606,7 @@ dump_l2arc_log_blocks(int fd, l2arc_dev_hdr_phys_t l2dhdr)
} }
if (this_lb.lb_magic == BSWAP_64(L2ARC_LOG_BLK_MAGIC)) if (this_lb.lb_magic == BSWAP_64(L2ARC_LOG_BLK_MAGIC))
byteswap_uint64_array(&this_lb, psize); byteswap_uint64_array(&this_lb, sizeof (this_lb));
if (this_lb.lb_magic != L2ARC_LOG_BLK_MAGIC) { if (this_lb.lb_magic != L2ARC_LOG_BLK_MAGIC) {
(void) printf("Invalid log block magic\n\n"); (void) printf("Invalid log block magic\n\n");
break; break;

View File

@ -9578,6 +9578,7 @@ l2arc_log_blk_read(l2arc_dev_t *dev,
int err = 0; int err = 0;
zio_cksum_t cksum; zio_cksum_t cksum;
abd_t *abd = NULL; abd_t *abd = NULL;
uint64_t psize;
ASSERT(this_lbp != NULL && next_lbp != NULL); ASSERT(this_lbp != NULL && next_lbp != NULL);
ASSERT(this_lb != NULL && next_lb != NULL); ASSERT(this_lb != NULL && next_lb != NULL);
@ -9616,8 +9617,8 @@ l2arc_log_blk_read(l2arc_dev_t *dev,
} }
/* Make sure the buffer checks out */ /* Make sure the buffer checks out */
fletcher_4_native(this_lb, psize = L2BLK_GET_PSIZE((this_lbp)->lbp_prop);
L2BLK_GET_PSIZE((this_lbp)->lbp_prop), NULL, &cksum); fletcher_4_native(this_lb, psize, NULL, &cksum);
if (!ZIO_CHECKSUM_EQUAL(cksum, this_lbp->lbp_cksum)) { if (!ZIO_CHECKSUM_EQUAL(cksum, this_lbp->lbp_cksum)) {
ARCSTAT_BUMP(arcstat_l2_rebuild_abort_cksum_lb_errors); ARCSTAT_BUMP(arcstat_l2_rebuild_abort_cksum_lb_errors);
zfs_dbgmsg("L2ARC log block cksum failed, offset: %llu, " zfs_dbgmsg("L2ARC log block cksum failed, offset: %llu, "
@ -9633,14 +9634,11 @@ l2arc_log_blk_read(l2arc_dev_t *dev,
case ZIO_COMPRESS_OFF: case ZIO_COMPRESS_OFF:
break; break;
case ZIO_COMPRESS_LZ4: case ZIO_COMPRESS_LZ4:
abd = abd_alloc_for_io(L2BLK_GET_PSIZE( abd = abd_alloc_for_io(psize, B_TRUE);
(this_lbp)->lbp_prop), B_TRUE); abd_copy_from_buf_off(abd, this_lb, 0, psize);
abd_copy_from_buf_off(abd, this_lb, 0,
L2BLK_GET_PSIZE((this_lbp)->lbp_prop));
if ((err = zio_decompress_data( if ((err = zio_decompress_data(
L2BLK_GET_COMPRESS((this_lbp)->lbp_prop), L2BLK_GET_COMPRESS((this_lbp)->lbp_prop),
abd, this_lb, L2BLK_GET_PSIZE((this_lbp)->lbp_prop), abd, this_lb, psize, sizeof (*this_lb))) != 0) {
sizeof (*this_lb))) != 0) {
err = SET_ERROR(EINVAL); err = SET_ERROR(EINVAL);
goto cleanup; goto cleanup;
} }

View File

@ -72,7 +72,7 @@ log_must fio $FIO_SCRIPTS/random_reads.fio
log_must zpool offline $TESTPOOL $VDEV_CACHE log_must zpool offline $TESTPOOL $VDEV_CACHE
sleep 5 sleep 10
typeset l2_rebuild_log_blk_start=$(get_arcstat l2_rebuild_log_blks) typeset l2_rebuild_log_blk_start=$(get_arcstat l2_rebuild_log_blks)
@ -81,7 +81,7 @@ typeset l2_dh_log_blk=$(zdb -l $VDEV_CACHE | grep log_blk_count | \
log_must zpool online $TESTPOOL $VDEV_CACHE log_must zpool online $TESTPOOL $VDEV_CACHE
sleep 5 sleep 10
typeset l2_rebuild_log_blk_end=$(get_arcstat l2_rebuild_log_blks) typeset l2_rebuild_log_blk_end=$(get_arcstat l2_rebuild_log_blks)