From: Bill O'Donnell <bodonnel@redhat.com>
To: "Darrick J. Wong" <djwong@kernel.org>
Cc: cem@kernel.org, linux-xfs@vger.kernel.org
Subject: Re: [PATCH 2/3] xfs_repair: sync bulkload data structures with kernel newbt code
Date: Thu, 14 Mar 2024 11:35:29 -0500 [thread overview]
Message-ID: <ZfMnUfcxF0641dqF@redhat.com> (raw)
In-Reply-To: <171029434355.2065697.8914601331036024173.stgit@frogsfrogsfrogs>
On Tue, Mar 12, 2024 at 07:14:24PM -0700, Darrick J. Wong wrote:
> From: Darrick J. Wong <djwong@kernel.org>
>
> A lot of the code in repair/bulkload.c was backwardsported from new code
> that eventually turned into newbt.c in online repair. Since the offline
> repair version got merged upstream years before the online repair code,
> we now need to bring the offline version up to date with the kernel
> again.
>
> Right now, the bulkload.c code is just a fancy way to track space
> extents that are fed to it by its callers. The only caller, of course,
> is phase 5, which builds new btrees in AG space that wasn't claimed by
> any other data structure. Hence there's no need to allocate
> reservations out of the bnobt or put them back there.
>
> However, the next patch adds the ability to generate new file-based
> btrees. For that we need to reorganize the code to allocate and free
> space for new file-based btrees. Let's just crib from the kernel
> version. Make each bulkload space reservation hold a reference to an AG
> and track the space reservation in terms of per-AG extents instead of
> fsblock extents.
>
> Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Bill O'Donnell <bodonnel@redhat.com>
> ---
> libxfs/libxfs_api_defs.h | 1 +
> repair/agbtree.c | 22 +++++++++++-----
> repair/bulkload.c | 63 +++++++++++++++++++++++++++++++++-------------
> repair/bulkload.h | 12 +++++----
> repair/phase5.c | 2 +
> 5 files changed, 69 insertions(+), 31 deletions(-)
>
>
> diff --git a/libxfs/libxfs_api_defs.h b/libxfs/libxfs_api_defs.h
> index 36afc5d0234d..28960317ab6b 100644
> --- a/libxfs/libxfs_api_defs.h
> +++ b/libxfs/libxfs_api_defs.h
> @@ -149,6 +149,7 @@
> #define xfs_log_sb libxfs_log_sb
> #define xfs_mode_to_ftype libxfs_mode_to_ftype
> #define xfs_perag_get libxfs_perag_get
> +#define xfs_perag_hold libxfs_perag_hold
> #define xfs_perag_put libxfs_perag_put
> #define xfs_prealloc_blocks libxfs_prealloc_blocks
>
> diff --git a/repair/agbtree.c b/repair/agbtree.c
> index e014e216e0a5..c6f0512fe7de 100644
> --- a/repair/agbtree.c
> +++ b/repair/agbtree.c
> @@ -77,13 +77,17 @@ reserve_agblocks(
> uint32_t nr_blocks)
> {
> struct extent_tree_node *ext_ptr;
> + struct xfs_perag *pag;
> uint32_t blocks_allocated = 0;
> uint32_t len;
> int error;
>
> + pag = libxfs_perag_get(mp, agno);
> + if (!pag)
> + do_error(_("could not open perag structure for agno 0x%x\n"),
> + agno);
> +
> while (blocks_allocated < nr_blocks) {
> - xfs_fsblock_t fsbno;
> -
> /*
> * Grab the smallest extent and use it up, then get the
> * next smallest. This mimics the init_*_cursor code.
> @@ -94,8 +98,8 @@ reserve_agblocks(
>
> /* Use up the extent we've got. */
> len = min(ext_ptr->ex_blockcount, nr_blocks - blocks_allocated);
> - fsbno = XFS_AGB_TO_FSB(mp, agno, ext_ptr->ex_startblock);
> - error = bulkload_add_blocks(&btr->newbt, fsbno, len);
> + error = bulkload_add_extent(&btr->newbt, pag,
> + ext_ptr->ex_startblock, len);
> if (error)
> do_error(_("could not set up btree reservation: %s\n"),
> strerror(-error));
> @@ -113,6 +117,7 @@ reserve_agblocks(
> fprintf(stderr, "blocks_allocated = %d\n",
> blocks_allocated);
> #endif
> + libxfs_perag_put(pag);
> return blocks_allocated == nr_blocks;
> }
>
> @@ -155,18 +160,21 @@ finish_rebuild(
> int error;
>
> for_each_bulkload_reservation(&btr->newbt, resv, n) {
> + xfs_fsblock_t fsbno;
> +
> if (resv->used == resv->len)
> continue;
>
> - error = bitmap_set(lost_blocks, resv->fsbno + resv->used,
> - resv->len - resv->used);
> + fsbno = XFS_AGB_TO_FSB(mp, resv->pag->pag_agno,
> + resv->agbno + resv->used);
> + error = bitmap_set(lost_blocks, fsbno, resv->len - resv->used);
> if (error)
> do_error(
> _("Insufficient memory saving lost blocks, err=%d.\n"), error);
> resv->used = resv->len;
> }
>
> - bulkload_destroy(&btr->newbt, 0);
> + bulkload_commit(&btr->newbt);
> }
>
> /*
> diff --git a/repair/bulkload.c b/repair/bulkload.c
> index 0117f69416cf..18158c397f56 100644
> --- a/repair/bulkload.c
> +++ b/repair/bulkload.c
> @@ -23,39 +23,64 @@ bulkload_init_ag(
> }
>
> /* Designate specific blocks to be used to build our new btree. */
> -int
> +static int
> bulkload_add_blocks(
> - struct bulkload *bkl,
> - xfs_fsblock_t fsbno,
> - xfs_extlen_t len)
> + struct bulkload *bkl,
> + struct xfs_perag *pag,
> + const struct xfs_alloc_arg *args)
> {
> - struct bulkload_resv *resv;
> + struct xfs_mount *mp = bkl->sc->mp;
> + struct bulkload_resv *resv;
>
> - resv = kmem_alloc(sizeof(struct bulkload_resv), KM_MAYFAIL);
> + resv = kmalloc(sizeof(struct bulkload_resv), GFP_KERNEL);
> if (!resv)
> return ENOMEM;
>
> INIT_LIST_HEAD(&resv->list);
> - resv->fsbno = fsbno;
> - resv->len = len;
> + resv->agbno = XFS_FSB_TO_AGBNO(mp, args->fsbno);
> + resv->len = args->len;
> resv->used = 0;
> + resv->pag = libxfs_perag_hold(pag);
> +
> list_add_tail(&resv->list, &bkl->resv_list);
> - bkl->nr_reserved += len;
> -
> + bkl->nr_reserved += args->len;
> return 0;
> }
>
> +/*
> + * Add an extent to the new btree reservation pool. Callers are required to
> + * reap this reservation manually if the repair is cancelled. @pag must be a
> + * passive reference.
> + */
> +int
> +bulkload_add_extent(
> + struct bulkload *bkl,
> + struct xfs_perag *pag,
> + xfs_agblock_t agbno,
> + xfs_extlen_t len)
> +{
> + struct xfs_mount *mp = bkl->sc->mp;
> + struct xfs_alloc_arg args = {
> + .tp = NULL, /* no autoreap */
> + .oinfo = bkl->oinfo,
> + .fsbno = XFS_AGB_TO_FSB(mp, pag->pag_agno, agbno),
> + .len = len,
> + .resv = XFS_AG_RESV_NONE,
> + };
> +
> + return bulkload_add_blocks(bkl, pag, &args);
> +}
> +
> /* Free all the accounting info and disk space we reserved for a new btree. */
> void
> -bulkload_destroy(
> - struct bulkload *bkl,
> - int error)
> +bulkload_commit(
> + struct bulkload *bkl)
> {
> struct bulkload_resv *resv, *n;
>
> list_for_each_entry_safe(resv, n, &bkl->resv_list, list) {
> list_del(&resv->list);
> - kmem_free(resv);
> + kfree(resv);
> }
> }
>
> @@ -67,7 +92,8 @@ bulkload_claim_block(
> union xfs_btree_ptr *ptr)
> {
> struct bulkload_resv *resv;
> - xfs_fsblock_t fsb;
> + struct xfs_mount *mp = cur->bc_mp;
> + xfs_agblock_t agbno;
>
> /*
> * The first item in the list should always have a free block unless
> @@ -84,7 +110,7 @@ bulkload_claim_block(
> * decreasing order, which hopefully results in leaf blocks ending up
> * together.
> */
> - fsb = resv->fsbno + resv->used;
> + agbno = resv->agbno + resv->used;
> resv->used++;
>
> /* If we used all the blocks in this reservation, move it to the end. */
> @@ -92,9 +118,10 @@ bulkload_claim_block(
> list_move_tail(&resv->list, &bkl->resv_list);
>
> if (cur->bc_flags & XFS_BTREE_LONG_PTRS)
> - ptr->l = cpu_to_be64(fsb);
> + ptr->l = cpu_to_be64(XFS_AGB_TO_FSB(mp, resv->pag->pag_agno,
> + agbno));
> else
> - ptr->s = cpu_to_be32(XFS_FSB_TO_AGBNO(cur->bc_mp, fsb));
> + ptr->s = cpu_to_be32(agbno);
> return 0;
> }
>
> diff --git a/repair/bulkload.h b/repair/bulkload.h
> index a84e99b8c892..f4790e3b3de6 100644
> --- a/repair/bulkload.h
> +++ b/repair/bulkload.h
> @@ -17,8 +17,10 @@ struct bulkload_resv {
> /* Link to list of extents that we've reserved. */
> struct list_head list;
>
> - /* FSB of the block we reserved. */
> - xfs_fsblock_t fsbno;
> + struct xfs_perag *pag;
> +
> + /* AG block of the block we reserved. */
> + xfs_agblock_t agbno;
>
> /* Length of the reservation. */
> xfs_extlen_t len;
> @@ -51,11 +53,11 @@ struct bulkload {
>
> void bulkload_init_ag(struct bulkload *bkl, struct repair_ctx *sc,
> const struct xfs_owner_info *oinfo);
> -int bulkload_add_blocks(struct bulkload *bkl, xfs_fsblock_t fsbno,
> - xfs_extlen_t len);
> -void bulkload_destroy(struct bulkload *bkl, int error);
> int bulkload_claim_block(struct xfs_btree_cur *cur, struct bulkload *bkl,
> union xfs_btree_ptr *ptr);
> +int bulkload_add_extent(struct bulkload *bkl, struct xfs_perag *pag,
> + xfs_agblock_t agbno, xfs_extlen_t len);
> +void bulkload_commit(struct bulkload *bkl);
> void bulkload_estimate_ag_slack(struct repair_ctx *sc,
> struct xfs_btree_bload *bload, unsigned int free);
>
> diff --git a/repair/phase5.c b/repair/phase5.c
> index d6b8168ea776..b0e208f95af5 100644
> --- a/repair/phase5.c
> +++ b/repair/phase5.c
> @@ -194,7 +194,7 @@ fill_agfl(
> for_each_bulkload_reservation(&btr->newbt, resv, n) {
> xfs_agblock_t bno;
>
> - bno = XFS_FSB_TO_AGBNO(mp, resv->fsbno + resv->used);
> + bno = resv->agbno + resv->used;
> while (resv->used < resv->len &&
> *agfl_idx < libxfs_agfl_size(mp)) {
> agfl_bnos[(*agfl_idx)++] = cpu_to_be32(bno++);
>
>
next prev parent reply other threads:[~2024-03-14 16:35 UTC|newest]
Thread overview: 180+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-03-13 1:41 [PATCHBOMB] xfsprogs: everything headed towards 6.8 Darrick J. Wong
2024-03-13 1:47 ` [PATCHSET 01/10] xfsprogs: convert utilities to use new rt helpers Darrick J. Wong
2024-03-13 1:49 ` [PATCH 01/13] libxfs: fix incorrect porting to 6.7 Darrick J. Wong
2024-03-13 21:58 ` Christoph Hellwig
2024-03-13 1:50 ` [PATCH 02/13] mkfs: fix log sunit rounding when external logs are in use Darrick J. Wong
2024-03-13 21:59 ` Christoph Hellwig
2024-03-14 23:43 ` Darrick J. Wong
2024-03-13 1:50 ` [PATCH 03/13] xfs_repair: fix confusing rt space units in the duplicate detection code Darrick J. Wong
2024-03-13 22:00 ` Christoph Hellwig
2024-03-13 1:50 ` [PATCH 04/13] libxfs: create a helper to compute leftovers of realtime extents Darrick J. Wong
2024-03-13 22:00 ` Christoph Hellwig
2024-03-13 1:50 ` [PATCH 05/13] libxfs: use helpers to convert rt block numbers to rt extent numbers Darrick J. Wong
2024-03-13 22:00 ` Christoph Hellwig
2024-03-13 1:51 ` [PATCH 06/13] xfs_repair: convert utility to use new rt extent helpers and types Darrick J. Wong
2024-03-13 22:01 ` Christoph Hellwig
2024-03-13 1:51 ` [PATCH 07/13] mkfs: " Darrick J. Wong
2024-03-13 22:01 ` Christoph Hellwig
2024-03-13 1:51 ` [PATCH 08/13] xfs_{db,repair}: convert open-coded xfs_rtword_t pointer accesses to helper Darrick J. Wong
2024-03-13 22:01 ` Christoph Hellwig
2024-03-13 1:52 ` [PATCH 09/13] xfs_repair: convert helpers for rtbitmap block/wordcount computations Darrick J. Wong
2024-03-13 22:01 ` Christoph Hellwig
2024-03-13 1:52 ` [PATCH 10/13] xfs_{db,repair}: use accessor functions for bitmap words Darrick J. Wong
2024-03-13 22:02 ` Christoph Hellwig
2024-03-13 1:52 ` [PATCH 11/13] xfs_{db,repair}: use helpers for rtsummary block/wordcount computations Darrick J. Wong
2024-03-13 22:02 ` Christoph Hellwig
2024-03-13 1:52 ` [PATCH 12/13] xfs_{db,repair}: use accessor functions for summary info words Darrick J. Wong
2024-03-13 22:02 ` Christoph Hellwig
2024-03-13 1:53 ` [PATCH 13/13] xfs_{db,repair}: use m_blockwsize instead of sb_blocksize for rt blocks Darrick J. Wong
2024-03-13 22:03 ` Christoph Hellwig
2024-03-13 17:20 ` [PATCHSET 01/10] xfsprogs: convert utilities to use new rt helpers Bill O'Donnell
2024-03-13 1:47 ` [PATCHSET 02/10] libxfs: sync with 6.8 Darrick J. Wong
2024-03-13 1:53 ` [PATCH 01/67] xfs: use xfs_defer_pending objects to recover intent items Darrick J. Wong
2024-03-13 1:53 ` [PATCH 02/67] xfs: recreate work items when recovering " Darrick J. Wong
2024-03-13 1:53 ` [PATCH 03/67] xfs: use xfs_defer_finish_one to finish recovered work items Darrick J. Wong
2024-03-13 1:54 ` [PATCH 04/67] xfs: move ->iop_recover to xfs_defer_op_type Darrick J. Wong
2024-03-13 1:54 ` [PATCH 05/67] xfs: hoist intent done flag setting to ->finish_item callsite Darrick J. Wong
2024-03-13 1:54 ` [PATCH 06/67] xfs: hoist ->create_intent boilerplate to its callsite Darrick J. Wong
2024-03-13 1:54 ` [PATCH 07/67] xfs: use xfs_defer_create_done for the relogging operation Darrick J. Wong
2024-03-13 1:55 ` [PATCH 08/67] xfs: clean out XFS_LI_DIRTY setting boilerplate from ->iop_relog Darrick J. Wong
2024-03-13 1:55 ` [PATCH 09/67] xfs: hoist xfs_trans_add_item calls to defer ops functions Darrick J. Wong
2024-03-13 1:55 ` [PATCH 10/67] xfs: move ->iop_relog to struct xfs_defer_op_type Darrick J. Wong
2024-03-13 1:55 ` [PATCH 11/67] xfs: make rextslog computation consistent with mkfs Darrick J. Wong
2024-03-13 1:56 ` [PATCH 12/67] xfs: fix 32-bit truncation in xfs_compute_rextslog Darrick J. Wong
2024-03-13 1:56 ` [PATCH 13/67] xfs: don't allow overly small or large realtime volumes Darrick J. Wong
2024-03-13 1:56 ` [PATCH 14/67] xfs: elide ->create_done calls for unlogged deferred work Darrick J. Wong
2024-03-13 1:56 ` [PATCH 15/67] xfs: don't append work items to logged xfs_defer_pending objects Darrick J. Wong
2024-03-13 1:57 ` [PATCH 16/67] xfs: allow pausing of pending deferred work items Darrick J. Wong
2024-03-13 1:57 ` [PATCH 17/67] xfs: remove __xfs_free_extent_later Darrick J. Wong
2024-03-13 1:57 ` [PATCH 18/67] xfs: automatic freeing of freshly allocated unwritten space Darrick J. Wong
2024-03-13 1:57 ` [PATCH 19/67] xfs: remove unused fields from struct xbtree_ifakeroot Darrick J. Wong
2024-03-13 1:58 ` [PATCH 20/67] xfs: force small EFIs for reaping btree extents Darrick J. Wong
2024-03-13 1:58 ` [PATCH 21/67] xfs: ensure logflagsp is initialized in xfs_bmap_del_extent_real Darrick J. Wong
2024-03-13 1:58 ` [PATCH 22/67] xfs: update dir3 leaf block metadata after swap Darrick J. Wong
2024-03-13 1:59 ` [PATCH 23/67] xfs: extract xfs_da_buf_copy() helper function Darrick J. Wong
2024-03-13 1:59 ` [PATCH 24/67] xfs: move xfs_ondisk.h to libxfs/ Darrick J. Wong
2024-03-13 1:59 ` [PATCH 25/67] xfs: consolidate the xfs_attr_defer_* helpers Darrick J. Wong
2024-03-13 1:59 ` [PATCH 26/67] xfs: store an ops pointer in struct xfs_defer_pending Darrick J. Wong
2024-03-13 2:00 ` [PATCH 27/67] xfs: pass the defer ops instead of type to xfs_defer_start_recovery Darrick J. Wong
2024-03-13 2:00 ` [PATCH 28/67] xfs: pass the defer ops directly to xfs_defer_add Darrick J. Wong
2024-03-13 2:00 ` [PATCH 29/67] xfs: force all buffers to be written during btree bulk load Darrick J. Wong
2024-03-13 2:00 ` [PATCH 30/67] xfs: set XBF_DONE on newly formatted btree block that are ready for writing Darrick J. Wong
2024-03-13 2:01 ` [PATCH 31/67] xfs: read leaf blocks when computing keys for bulkloading into node blocks Darrick J. Wong
2024-03-13 2:01 ` [PATCH 32/67] xfs: move btree bulkload record initialization to ->get_record implementations Darrick J. Wong
2024-03-13 2:01 ` [PATCH 33/67] xfs: constrain dirty buffers while formatting a staged btree Darrick J. Wong
2024-03-13 2:01 ` [PATCH 34/67] xfs: repair free space btrees Darrick J. Wong
2024-03-13 2:02 ` [PATCH 35/67] xfs: repair inode btrees Darrick J. Wong
2024-03-13 2:02 ` [PATCH 36/67] xfs: repair refcount btrees Darrick J. Wong
2024-03-13 2:02 ` [PATCH 37/67] xfs: dont cast to char * for XFS_DFORK_*PTR macros Darrick J. Wong
2024-03-13 2:02 ` [PATCH 38/67] xfs: set inode sick state flags when we zap either ondisk fork Darrick J. Wong
2024-03-13 2:03 ` [PATCH 39/67] xfs: zap broken inode forks Darrick J. Wong
2024-03-13 2:03 ` [PATCH 40/67] xfs: repair inode fork block mapping data structures Darrick J. Wong
2024-03-13 2:03 ` [PATCH 41/67] xfs: create a ranged query function for refcount btrees Darrick J. Wong
2024-03-13 2:03 ` [PATCH 42/67] xfs: create a new inode fork block unmap helper Darrick J. Wong
2024-03-13 2:04 ` [PATCH 43/67] xfs: improve dquot iteration for scrub Darrick J. Wong
2024-03-13 2:04 ` [PATCH 44/67] xfs: add lock protection when remove perag from radix tree Darrick J. Wong
2024-03-13 2:04 ` [PATCH 45/67] xfs: fix perag leak when growfs fails Darrick J. Wong
2024-03-13 2:05 ` [PATCH 46/67] xfs: remove the xfs_alloc_arg argument to xfs_bmap_btalloc_accounting Darrick J. Wong
2024-03-13 2:05 ` [PATCH 47/67] xfs: also use xfs_bmap_btalloc_accounting for RT allocations Darrick J. Wong
2024-03-13 2:05 ` [PATCH 48/67] xfs: return -ENOSPC from xfs_rtallocate_* Darrick J. Wong
2024-03-13 2:05 ` [PATCH 49/67] xfs: indicate if xfs_bmap_adjacent changed ap->blkno Darrick J. Wong
2024-03-13 2:06 ` [PATCH 50/67] xfs: move xfs_rtget_summary to xfs_rtbitmap.c Darrick J. Wong
2024-03-13 2:06 ` [PATCH 51/67] xfs: split xfs_rtmodify_summary_int Darrick J. Wong
2024-03-13 2:06 ` [PATCH 52/67] xfs: remove rt-wrappers from xfs_format.h Darrick J. Wong
2024-03-13 2:06 ` [PATCH 53/67] xfs: remove XFS_RTMIN/XFS_RTMAX Darrick J. Wong
2024-03-13 2:07 ` [PATCH 54/67] xfs: make if_data a void pointer Darrick J. Wong
2024-03-13 2:07 ` [PATCH 55/67] xfs: return if_data from xfs_idata_realloc Darrick J. Wong
2024-03-13 2:07 ` [PATCH 56/67] xfs: move the xfs_attr_sf_lookup tracepoint Darrick J. Wong
2024-03-13 2:07 ` [PATCH 57/67] xfs: simplify xfs_attr_sf_findname Darrick J. Wong
2024-03-13 2:08 ` [PATCH 58/67] xfs: remove xfs_attr_shortform_lookup Darrick J. Wong
2024-03-13 2:08 ` [PATCH 59/67] xfs: use xfs_attr_sf_findname in xfs_attr_shortform_getvalue Darrick J. Wong
2024-03-13 2:08 ` [PATCH 60/67] xfs: remove struct xfs_attr_shortform Darrick J. Wong
2024-03-13 2:08 ` [PATCH 61/67] xfs: remove xfs_attr_sf_hdr_t Darrick J. Wong
2024-03-13 2:09 ` [PATCH 62/67] xfs: turn the XFS_DA_OP_REPLACE checks in xfs_attr_shortform_addname into asserts Darrick J. Wong
2024-03-13 2:09 ` [PATCH 63/67] xfs: fix a use after free in xfs_defer_finish_recovery Darrick J. Wong
2024-03-13 2:09 ` [PATCH 64/67] xfs: use the op name in trace_xlog_intent_recovery_failed Darrick J. Wong
2024-03-13 2:09 ` [PATCH 65/67] xfs: fix backwards logic in xfs_bmap_alloc_account Darrick J. Wong
2024-03-13 2:10 ` [PATCH 66/67] xfs: reset XFS_ATTR_INCOMPLETE filter on node removal Darrick J. Wong
2024-03-13 2:10 ` [PATCH 67/67] xfs: remove conditional building of rt geometry validator functions Darrick J. Wong
2024-03-13 17:43 ` [PATCHSET 02/10] libxfs: sync with 6.8 Bill O'Donnell
2024-03-13 1:47 ` [PATCHSET 03/10] xfs_repair: faster btree bulkloading Darrick J. Wong
2024-03-13 2:10 ` [PATCH 1/2] xfs_repair: adjust btree bulkloading slack computations to match online repair Darrick J. Wong
2024-03-13 17:48 ` Bill O'Donnell
2024-03-13 22:04 ` Christoph Hellwig
2024-03-13 2:11 ` [PATCH 2/2] xfs_repair: bulk load records into new btree blocks Darrick J. Wong
2024-03-13 17:49 ` Bill O'Donnell
2024-03-13 22:04 ` Christoph Hellwig
2024-03-13 1:48 ` [PATCHSET 04/10] xfsprogs: bug fixes for 6.8 Darrick J. Wong
2024-03-13 2:11 ` [PATCH 1/1] xfs_repair: double-check with shortform attr verifiers Darrick J. Wong
2024-03-13 17:52 ` Bill O'Donnell
2024-03-13 22:05 ` Christoph Hellwig
2024-03-13 1:48 ` [PATCHSET V2 05/10] xfsprogs: fix log sector size detection Darrick J. Wong
2024-03-13 2:11 ` [PATCH 1/5] libxfs: remove the unused fs_topology_t typedef Darrick J. Wong
2024-03-13 2:11 ` [PATCH 2/5] libxfs: refactor the fs_topology structure Darrick J. Wong
2024-03-13 2:12 ` [PATCH 3/5] libxfs: remove the S_ISREG check from blkid_get_topology Darrick J. Wong
2024-03-13 2:12 ` [PATCH 4/5] libxfs: also query log device topology in get_topology Darrick J. Wong
2024-03-13 2:12 ` [PATCH 5/5] mkfs: use a sensible log sector size default Darrick J. Wong
2024-03-13 17:54 ` [PATCHSET V2 05/10] xfsprogs: fix log sector size detection Bill O'Donnell
2024-03-13 22:06 ` Christoph Hellwig
2024-03-13 1:48 ` [PATCHSET 06/10] mkfs: scale shards on ssds Darrick J. Wong
2024-03-13 2:12 ` [PATCH 1/2] mkfs: allow sizing allocation groups for concurrency Darrick J. Wong
2024-03-13 2:13 ` [PATCH 2/2] mkfs: allow sizing internal logs " Darrick J. Wong
2024-03-13 18:17 ` [PATCHSET 06/10] mkfs: scale shards on ssds Bill O'Donnell
2024-03-13 1:48 ` [PATCHSET v29.4 07/10] xfs_scrub: scan metadata files in parallel Darrick J. Wong
2024-03-13 2:13 ` [PATCH 1/3] libfrog: rename XFROG_SCRUB_TYPE_* to XFROG_SCRUB_GROUP_* Darrick J. Wong
2024-03-13 2:13 ` [PATCH 2/3] libfrog: promote XFROG_SCRUB_DESCR_SUMMARY to a scrub type Darrick J. Wong
2024-03-13 2:13 ` [PATCH 3/3] xfs_scrub: scan whole-fs metadata files in parallel Darrick J. Wong
2024-03-13 18:19 ` [PATCHSET v29.4 07/10] xfs_scrub: scan " Bill O'Donnell
2024-03-13 1:49 ` [PATCHSET v29.4 08/10] xfs_repair: rebuild inode fork mappings Darrick J. Wong
2024-03-13 2:14 ` [PATCH 1/3] xfs_repair: push inode buf and dinode pointers all the way to inode fork processing Darrick J. Wong
2024-03-13 21:58 ` Bill O'Donnell
2024-03-13 22:10 ` Christoph Hellwig
2024-03-13 2:14 ` [PATCH 2/3] xfs_repair: sync bulkload data structures with kernel newbt code Darrick J. Wong
2024-03-13 22:11 ` Christoph Hellwig
2024-03-14 16:35 ` Bill O'Donnell [this message]
2024-03-13 2:14 ` [PATCH 3/3] xfs_repair: rebuild block mappings from rmapbt data Darrick J. Wong
2024-03-14 1:59 ` Christoph Hellwig
2024-03-14 23:56 ` Darrick J. Wong
2024-03-17 21:10 ` Christoph Hellwig
2024-03-14 17:13 ` Bill O'Donnell
2024-03-18 18:27 ` [PATCH v24.5.1 " Darrick J. Wong
2024-03-13 1:49 ` [PATCHSET 09/10] xfs_repair: support more than 4 billion records Darrick J. Wong
2024-03-13 2:14 ` [PATCH 1/8] xfs_db: add a bmbt inflation command Darrick J. Wong
2024-03-14 2:01 ` Christoph Hellwig
2024-03-14 23:57 ` Darrick J. Wong
2024-03-18 18:32 ` [PATCH v24.5.1 " Darrick J. Wong
2024-03-13 2:15 ` [PATCH 2/8] xfs_repair: slab and bag structs need to track more than 2^32 items Darrick J. Wong
2024-03-14 2:02 ` Christoph Hellwig
2024-03-13 2:15 ` [PATCH 3/8] xfs_repair: support more than 2^32 rmapbt records per AG Darrick J. Wong
2024-03-14 2:02 ` Christoph Hellwig
2024-03-13 2:15 ` [PATCH 4/8] xfs_repair: support more than 2^32 owners per physical block Darrick J. Wong
2024-03-14 2:03 ` Christoph Hellwig
2024-03-14 23:59 ` Darrick J. Wong
2024-03-18 18:32 ` [PATCH v24.5.1 " Darrick J. Wong
2024-03-13 2:15 ` [PATCH 5/8] xfs_repair: clean up lock resources Darrick J. Wong
2024-03-14 2:03 ` Christoph Hellwig
2024-03-13 2:16 ` [PATCH 6/8] xfs_repair: constrain attr fork extent count Darrick J. Wong
2024-03-14 2:03 ` Christoph Hellwig
2024-03-13 2:16 ` [PATCH 7/8] xfs_repair: don't create block maps for data files Darrick J. Wong
2024-03-14 2:05 ` Christoph Hellwig
2024-03-15 0:02 ` Darrick J. Wong
2024-03-17 21:11 ` Christoph Hellwig
2024-03-18 18:33 ` [PATCH v24.5.1 " Darrick J. Wong
2024-03-13 2:16 ` [PATCH 8/8] xfs_repair: support more than INT_MAX block maps Darrick J. Wong
2024-03-14 2:06 ` Christoph Hellwig
2024-03-15 0:03 ` Darrick J. Wong
2024-03-13 1:49 ` [PATCHSET v29.4 10/10] libxfs: prepare to sync with 6.9 Darrick J. Wong
2024-03-13 2:17 ` [PATCH 1/3] libxfs: actually set m_fsname Darrick J. Wong
2024-03-14 2:07 ` Christoph Hellwig
2024-03-13 2:17 ` [PATCH 2/3] libxfs: clean up xfs_da_unmount usage Darrick J. Wong
2024-03-14 2:08 ` Christoph Hellwig
2024-03-13 2:17 ` [PATCH 3/3] libfrog: create a new scrub group for things requiring full inode scans Darrick J. Wong
2024-03-14 2:08 ` Christoph Hellwig
2024-03-18 21:30 ` [PATCHSET v29.4] xfsprogs: various bug fixes for 6.8 Darrick J. Wong
2024-03-18 21:30 ` [PATCH 1/4] xfs_db: fix alignment checks in getbitval Darrick J. Wong
2024-03-18 21:30 ` [PATCH 2/4] xfs_scrub: fix threadcount estimates for phase 6 Darrick J. Wong
2024-03-18 21:30 ` [PATCH 3/4] xfs_scrub: don't fail while reporting media scan errors Darrick J. Wong
2024-03-18 21:31 ` [PATCH 4/4] xfs_io: add linux madvise advice codes Darrick J. Wong
-- strict thread matches above, loose matches on Subject: below --
2024-04-17 21:17 [PATCHSET v30.3 10/11] xfs_repair: rebuild inode fork mappings Darrick J. Wong
2024-04-17 21:44 ` [PATCH 2/3] xfs_repair: sync bulkload data structures with kernel newbt code Darrick J. Wong
2024-03-26 2:56 [PATCHSET v29.4 08/18] xfs_repair: rebuild inode fork mappings Darrick J. Wong
2024-03-26 3:25 ` [PATCH 2/3] xfs_repair: sync bulkload data structures with kernel newbt code Darrick J. Wong
2023-12-31 19:41 [PATCHSET v29.0 06/40] xfs_repair: rebuild inode fork mappings Darrick J. Wong
2023-12-31 22:08 ` [PATCH 2/3] xfs_repair: sync bulkload data structures with kernel newbt code Darrick J. Wong
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ZfMnUfcxF0641dqF@redhat.com \
--to=bodonnel@redhat.com \
--cc=cem@kernel.org \
--cc=djwong@kernel.org \
--cc=linux-xfs@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).