Hi Rich -
On 10/1/13 11:30 AM, Rich Johnston wrote:
> If no extents exist, there is no need to call partial_reg() because
> there is no data to split up.
Does that break something, or is this an optimization?
> Also remove the uneeded check in partial_reg() to detect if this is a
> multistream restore.
Why is it unneeded?
>From a quick read, if partialmax == 0 that measn only 1 drive,
and no streams - so it does seem like partial_reg() would have
no work to do, so I'm a little confused (but I'm also a total
n00b here).
This patch says it fixes multi stream support - what was broken?
Is there a testcase (or should there be) that shows the problem?
I see changes but I don't know enough about xfsdump to know
what's broken & what's being fixed, can you explain a bit more?
Thanks,
-Eric
> Signed-off-by: Rich Johnston <rjohnston@xxxxxxx>
>
> diff --git a/restore/content.c b/restore/content.c
> index 54d933c..ecbcf13 100644
> --- a/restore/content.c
> +++ b/restore/content.c
> @@ -7494,6 +7494,7 @@ restore_extent_group( drive_t *drivep,
> extenthdr_t ehdr;
> off64_t bytesread;
> rv_t rv;
> + uint num_extents = 0; /* number of extents */
>
> /* copy data extents from media to the file
> */
> @@ -7518,6 +7519,7 @@ restore_extent_group( drive_t *drivep,
> if ( ehdr.eh_type == EXTENTHDR_TYPE_LAST ) {
> break;
> }
> + num_extents++;
>
> /* if its an ALIGNment extent, discard the extent.
> */
> @@ -7572,7 +7574,7 @@ restore_extent_group( drive_t *drivep,
> * and certain extended inode flags. Register the portion
> * of the file completed here in the persistent state.
> */
> - if (bstatp->bs_size > restoredsz) {
> + if (num_extents && (bstatp->bs_size > restoredsz)) {
> partial_reg(drivep->d_index,
> bstatp->bs_ino,
> bstatp->bs_size,
> @@ -8959,9 +8961,6 @@ partial_reg( ix_t d_index,
>
> endoffset = offset + sz;
>
> - if ( partialmax == 0 )
> - return;
> -
> pi_lock();
>
> /* Search for a matching inode. Gaps can exist so we must search
>
> _______________________________________________
> xfs mailing list
> xfs@xxxxxxxxxxx
> http://oss.sgi.com/mailman/listinfo/xfs
>
|