-
Notifications
You must be signed in to change notification settings - Fork 1.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Guarantee PAGESIZE alignment for large zio buffers #6084
Conversation
In current implementation, only zio buffers in 16KB and bigger are guaranteed PAGESIZE alignment. This breaks Lustre since it assumes that 'arc_buf_t::b_data' must be page aligned when zio buffers are greater than or equal to PAGESIZE. This patch will make the zio buffers to be PAGESIZE aligned when the sizes are not less than PAGESIZE. This change may cause a little bit memory waste but that should be fine because after ABD is introduced, zio buffers are used to hold data temporarily and live in memory for a short while. Signed-off-by: Jinshan Xiong <[email protected]> Signed-off-by: Jinshan Xiong <[email protected]>
@jxiong, thanks for your PR! By analyzing the history of the files in this pull request, we identified @behlendorf, @don-brady and @dpquigl to be potential reviewers. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
@jxiong nice find. You may want to add some alignment assertions on the Lustre side to make sure we quickly catch any potential future changes in the area. |
@behlendorf yes I already did it. Thanks for reminding. |
@@ -167,10 +167,10 @@ zio_init(void) | |||
*/ | |||
align = 8 * SPA_MINBLOCKSIZE; | |||
#else | |||
if (size <= 4 * SPA_MINBLOCKSIZE) { | |||
if (size < PAGESIZE) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This will result in 3 additional caches being created for tiny buffers. That's not a problem and likely desirable but worth mentioning.
Will this fix be cherry-picked into the 0.6.5 branch? |
@adilger it's small enough I wouldn't object to cherry-picking it if you need it. |
We're looking at how to handle this in Lustre, and without this fix it adds a constant (additional) memcpy() overhead for accessing small files. IMHO, it is preferable to backport this fix to 0.6.5 and just align the allocation correctly in the first place. That also avoids potential corruption for anyone using Lustre+ZFS 0.6.5.x without the Lustre-side fix. |
I've added to the list of patched to check pick for 0.6.5.10 |
ZFS only guarantees PAGE_SIZE alignment to arc_buf_t only when the block size is not less than (PAGE_SIZE << 2). The patch for ZFS openzfs/zfs#6084 fixes the alignment problem, buf Lustre still needs a fix to handle the problem in case it's running old ZFS release. Signed-off-by: Jinshan Xiong <[email protected]> Change-Id: I6fd17d7b20499ec0406a3e10cebf6882b92a730f Reviewed-on: https://review.whamcloud.com/26895 Tested-by: Jenkins Tested-by: Maloo <[email protected]> Reviewed-by: Alex Zhuravlev <[email protected]> Reviewed-by: Andreas Dilger <[email protected]>
In current implementation, only zio buffers in 16KB and bigger are guaranteed PAGESIZE alignment. This breaks Lustre since it assumes that 'arc_buf_t::b_data' must be page aligned when zio buffers are greater than or equal to PAGESIZE. This patch will make the zio buffers to be PAGESIZE aligned when the sizes are not less than PAGESIZE. This change may cause a little bit memory waste but that should be fine because after ABD is introduced, zio buffers are used to hold data temporarily and live in memory for a short while. Reviewed-by: Don Brady <[email protected]> Reviewed-by: Brian Behlendorf <[email protected]> Signed-off-by: Jinshan Xiong <[email protected]> Signed-off-by: Jinshan Xiong <[email protected]> Closes openzfs#6084
In current implementation, only zio buffers in 16KB and bigger are guaranteed PAGESIZE alignment. This breaks Lustre since it assumes that 'arc_buf_t::b_data' must be page aligned when zio buffers are greater than or equal to PAGESIZE. This patch will make the zio buffers to be PAGESIZE aligned when the sizes are not less than PAGESIZE. This change may cause a little bit memory waste but that should be fine because after ABD is introduced, zio buffers are used to hold data temporarily and live in memory for a short while. Reviewed-by: Don Brady <[email protected]> Reviewed-by: Brian Behlendorf <[email protected]> Signed-off-by: Jinshan Xiong <[email protected]> Signed-off-by: Jinshan Xiong <[email protected]> Closes #6084
In current implementation, only zio buffers in 16KB and bigger are
guaranteed PAGESIZE alignment. This breaks Lustre since it assumes
that 'arc_buf_t::b_data' must be page aligned when zio buffers are
greater than or equal to PAGESIZE.
This patch will make the zio buffers to be PAGESIZE aligned when
the sizes are not less than PAGESIZE.
This change may cause a little bit memory waste but that should be
fine because after ABD is introduced, zio buffers are used to hold
data temporarily and live in memory for a short while.
Signed-off-by: Jinshan Xiong [email protected]
Signed-off-by: Jinshan Xiong [email protected]
Description
Motivation and Context
How Has This Been Tested?
Types of changes
Checklist:
Signed-off-by
.