* [PATCH v2] z3fold: fix the potential encode bug in encod_handle @ 2016-10-13 4:02 zhongjiang 2016-10-17 1:58 ` zhong jiang 0 siblings, 1 reply; 7+ messages in thread From: zhongjiang @ 2016-10-13 4:02 UTC (permalink / raw) To: vitalywool, david, sjenning, ddstreet, akpm, mhocko, vbabka Cc: linux-kernel, linux-mm From: zhong jiang <zhongjiang@huawei.com> At present, zhdr->first_num plus bud can exceed the BUDDY_MASK in encode_handle, it will lead to the the caller handle_to_buddy return the error value. The patch fix the issue by changing the BUDDY_MASK to PAGE_MASK, it will be consistent with handle_to_z3fold_header. At the same time, change the BUDDY_MASK to PAGE_MASK in handle_to_buddy is better. Signed-off-by: zhong jiang <zhongjiang@huawei.com> --- mm/z3fold.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/mm/z3fold.c b/mm/z3fold.c index 8f9e89c..e8fc216 100644 --- a/mm/z3fold.c +++ b/mm/z3fold.c @@ -169,7 +169,7 @@ static unsigned long encode_handle(struct z3fold_header *zhdr, enum buddy bud) handle = (unsigned long)zhdr; if (bud != HEADLESS) - handle += (bud + zhdr->first_num) & BUDDY_MASK; + handle += (bud + zhdr->first_num) & PAGE_MASK; return handle; } @@ -183,7 +183,7 @@ static struct z3fold_header *handle_to_z3fold_header(unsigned long handle) static enum buddy handle_to_buddy(unsigned long handle) { struct z3fold_header *zhdr = handle_to_z3fold_header(handle); - return (handle - zhdr->first_num) & BUDDY_MASK; + return (handle - zhdr->first_num) & PAGE_MASK; } /* -- 1.8.3.1 -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH v2] z3fold: fix the potential encode bug in encod_handle 2016-10-13 4:02 [PATCH v2] z3fold: fix the potential encode bug in encod_handle zhongjiang @ 2016-10-17 1:58 ` zhong jiang 2016-10-17 12:03 ` Vitaly Wool 0 siblings, 1 reply; 7+ messages in thread From: zhong jiang @ 2016-10-17 1:58 UTC (permalink / raw) To: vitalywool, david, sjenning, ddstreet, akpm, mhocko, vbabka Cc: linux-kernel, linux-mm Hi, Vitaly About the following patch, is it right? Thanks zhongjiang On 2016/10/13 12:02, zhongjiang wrote: > From: zhong jiang <zhongjiang@huawei.com> > > At present, zhdr->first_num plus bud can exceed the BUDDY_MASK > in encode_handle, it will lead to the the caller handle_to_buddy > return the error value. > > The patch fix the issue by changing the BUDDY_MASK to PAGE_MASK, > it will be consistent with handle_to_z3fold_header. At the same time, > change the BUDDY_MASK to PAGE_MASK in handle_to_buddy is better. > > Signed-off-by: zhong jiang <zhongjiang@huawei.com> > --- > mm/z3fold.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > diff --git a/mm/z3fold.c b/mm/z3fold.c > index 8f9e89c..e8fc216 100644 > --- a/mm/z3fold.c > +++ b/mm/z3fold.c > @@ -169,7 +169,7 @@ static unsigned long encode_handle(struct z3fold_header *zhdr, enum buddy bud) > > handle = (unsigned long)zhdr; > if (bud != HEADLESS) > - handle += (bud + zhdr->first_num) & BUDDY_MASK; > + handle += (bud + zhdr->first_num) & PAGE_MASK; > return handle; > } > > @@ -183,7 +183,7 @@ static struct z3fold_header *handle_to_z3fold_header(unsigned long handle) > static enum buddy handle_to_buddy(unsigned long handle) > { > struct z3fold_header *zhdr = handle_to_z3fold_header(handle); > - return (handle - zhdr->first_num) & BUDDY_MASK; > + return (handle - zhdr->first_num) & PAGE_MASK; > } > > /* -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2] z3fold: fix the potential encode bug in encod_handle 2016-10-17 1:58 ` zhong jiang @ 2016-10-17 12:03 ` Vitaly Wool 2016-10-17 12:48 ` zhong jiang 2016-10-17 13:38 ` zhong jiang 0 siblings, 2 replies; 7+ messages in thread From: Vitaly Wool @ 2016-10-17 12:03 UTC (permalink / raw) To: zhong jiang Cc: Dave Chinner, Seth Jennings, Dan Streetman, Andrew Morton, Michal Hocko, Vlastimil Babka, LKML, Linux-MM Hi Zhong Jiang, On Mon, Oct 17, 2016 at 3:58 AM, zhong jiang <zhongjiang@huawei.com> wrote: > Hi, Vitaly > > About the following patch, is it right? > > Thanks > zhongjiang > On 2016/10/13 12:02, zhongjiang wrote: >> From: zhong jiang <zhongjiang@huawei.com> >> >> At present, zhdr->first_num plus bud can exceed the BUDDY_MASK >> in encode_handle, it will lead to the the caller handle_to_buddy >> return the error value. >> >> The patch fix the issue by changing the BUDDY_MASK to PAGE_MASK, >> it will be consistent with handle_to_z3fold_header. At the same time, >> change the BUDDY_MASK to PAGE_MASK in handle_to_buddy is better. are you seeing problems with the existing code? first_num should wrap around BUDDY_MASK and this should be ok because it is way bigger than the number of buddies. ~vitaly -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2] z3fold: fix the potential encode bug in encod_handle 2016-10-17 12:03 ` Vitaly Wool @ 2016-10-17 12:48 ` zhong jiang 2016-10-17 15:30 ` Dan Streetman 2016-10-17 13:38 ` zhong jiang 1 sibling, 1 reply; 7+ messages in thread From: zhong jiang @ 2016-10-17 12:48 UTC (permalink / raw) To: Vitaly Wool Cc: Dave Chinner, Seth Jennings, Dan Streetman, Andrew Morton, Michal Hocko, Vlastimil Babka, LKML, Linux-MM On 2016/10/17 20:03, Vitaly Wool wrote: > Hi Zhong Jiang, > > On Mon, Oct 17, 2016 at 3:58 AM, zhong jiang <zhongjiang@huawei.com> wrote: >> Hi, Vitaly >> >> About the following patch, is it right? >> >> Thanks >> zhongjiang >> On 2016/10/13 12:02, zhongjiang wrote: >>> From: zhong jiang <zhongjiang@huawei.com> >>> >>> At present, zhdr->first_num plus bud can exceed the BUDDY_MASK >>> in encode_handle, it will lead to the the caller handle_to_buddy >>> return the error value. >>> >>> The patch fix the issue by changing the BUDDY_MASK to PAGE_MASK, >>> it will be consistent with handle_to_z3fold_header. At the same time, >>> change the BUDDY_MASK to PAGE_MASK in handle_to_buddy is better. > are you seeing problems with the existing code? first_num should wrap around > BUDDY_MASK and this should be ok because it is way bigger than the number > of buddies. > > ~vitaly > > . > first_num plus buddies can exceed the BUDDY_MASK. is it right? (first_num + buddies) & BUDDY_MASK may be a smaller value than first_num. but (handle - zhdr->first_num) & BUDDY_MASK will return incorrect value in handle_to_buddy. Thanks zhongjiang -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2] z3fold: fix the potential encode bug in encod_handle 2016-10-17 12:48 ` zhong jiang @ 2016-10-17 15:30 ` Dan Streetman 2016-10-18 1:53 ` zhong jiang 0 siblings, 1 reply; 7+ messages in thread From: Dan Streetman @ 2016-10-17 15:30 UTC (permalink / raw) To: zhong jiang Cc: Vitaly Wool, Dave Chinner, Seth Jennings, Andrew Morton, Michal Hocko, Vlastimil Babka, LKML, Linux-MM On Mon, Oct 17, 2016 at 8:48 AM, zhong jiang <zhongjiang@huawei.com> wrote: > > On 2016/10/17 20:03, Vitaly Wool wrote: > > Hi Zhong Jiang, > > > > On Mon, Oct 17, 2016 at 3:58 AM, zhong jiang <zhongjiang@huawei.com> wrote: > >> Hi, Vitaly > >> > >> About the following patch, is it right? > >> > >> Thanks > >> zhongjiang > >> On 2016/10/13 12:02, zhongjiang wrote: > >>> From: zhong jiang <zhongjiang@huawei.com> > >>> > >>> At present, zhdr->first_num plus bud can exceed the BUDDY_MASK > >>> in encode_handle, it will lead to the the caller handle_to_buddy > >>> return the error value. > >>> > >>> The patch fix the issue by changing the BUDDY_MASK to PAGE_MASK, > >>> it will be consistent with handle_to_z3fold_header. At the same time, > >>> change the BUDDY_MASK to PAGE_MASK in handle_to_buddy is better. > > are you seeing problems with the existing code? first_num should wrap around > > BUDDY_MASK and this should be ok because it is way bigger than the number > > of buddies. > > > > ~vitaly > > > > . > > > first_num plus buddies can exceed the BUDDY_MASK. is it right? yes. > > (first_num + buddies) & BUDDY_MASK may be a smaller value than first_num. yes, but that doesn't matter; the value stored in the handle is never accessed directly. > > but (handle - zhdr->first_num) & BUDDY_MASK will return incorrect value > in handle_to_buddy. the subtraction and masking will result in the correct buddy number, even if (handle & BUDDY_MASK) < zhdr->first_num. However, I agree it's nonobvious, and tying the first_num size to NCHUNKS_ORDER is confusing - the number of chunks is completely unrelated to the number of buddies. Possibly a better way to handle first_num is to limit it to the order of enum buddy to the actual range of possible buddy indexes, which is 0x3, i.e.: #define BUDDY_MASK (0x3) and unsigned short first_num:2; with that and a small bit of explanation in the encode_handle or handle_to_buddy comments, it should be clear how the first_num and buddy numbering work, including that overflow/underflow are ok (due to the masking)... > > Thanks > zhongjiang > > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2] z3fold: fix the potential encode bug in encod_handle 2016-10-17 15:30 ` Dan Streetman @ 2016-10-18 1:53 ` zhong jiang 0 siblings, 0 replies; 7+ messages in thread From: zhong jiang @ 2016-10-18 1:53 UTC (permalink / raw) To: Dan Streetman Cc: Vitaly Wool, Dave Chinner, Seth Jennings, Andrew Morton, Michal Hocko, Vlastimil Babka, LKML, Linux-MM On 2016/10/17 23:30, Dan Streetman wrote: > On Mon, Oct 17, 2016 at 8:48 AM, zhong jiang <zhongjiang@huawei.com> wrote: >> On 2016/10/17 20:03, Vitaly Wool wrote: >>> Hi Zhong Jiang, >>> >>> On Mon, Oct 17, 2016 at 3:58 AM, zhong jiang <zhongjiang@huawei.com> wrote: >>>> Hi, Vitaly >>>> >>>> About the following patch, is it right? >>>> >>>> Thanks >>>> zhongjiang >>>> On 2016/10/13 12:02, zhongjiang wrote: >>>>> From: zhong jiang <zhongjiang@huawei.com> >>>>> >>>>> At present, zhdr->first_num plus bud can exceed the BUDDY_MASK >>>>> in encode_handle, it will lead to the the caller handle_to_buddy >>>>> return the error value. >>>>> >>>>> The patch fix the issue by changing the BUDDY_MASK to PAGE_MASK, >>>>> it will be consistent with handle_to_z3fold_header. At the same time, >>>>> change the BUDDY_MASK to PAGE_MASK in handle_to_buddy is better. >>> are you seeing problems with the existing code? first_num should wrap around >>> BUDDY_MASK and this should be ok because it is way bigger than the number >>> of buddies. >>> >>> ~vitaly >>> >>> . >>> >> first_num plus buddies can exceed the BUDDY_MASK. is it right? > yes. > >> (first_num + buddies) & BUDDY_MASK may be a smaller value than first_num. > yes, but that doesn't matter; the value stored in the handle is never > accessed directly. > >> but (handle - zhdr->first_num) & BUDDY_MASK will return incorrect value >> in handle_to_buddy. > the subtraction and masking will result in the correct buddy number, > even if (handle & BUDDY_MASK) < zhdr->first_num. yes, I see. it is hard to read. > However, I agree it's nonobvious, and tying the first_num size to > NCHUNKS_ORDER is confusing - the number of chunks is completely > unrelated to the number of buddies. yes. indeed. > Possibly a better way to handle first_num is to limit it to the order > of enum buddy to the actual range of possible buddy indexes, which is > 0x3, i.e.: > > #define BUDDY_MASK (0x3) > > and > > unsigned short first_num:2; > > with that and a small bit of explanation in the encode_handle or > handle_to_buddy comments, it should be clear how the first_num and > buddy numbering work, including that overflow/underflow are ok (due to > the masking)... yes, It is better and clearer. Thanks for your relpy and advice. I will resend the patch. >> Thanks >> zhongjiang >> >> > . > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v2] z3fold: fix the potential encode bug in encod_handle 2016-10-17 12:03 ` Vitaly Wool 2016-10-17 12:48 ` zhong jiang @ 2016-10-17 13:38 ` zhong jiang 1 sibling, 0 replies; 7+ messages in thread From: zhong jiang @ 2016-10-17 13:38 UTC (permalink / raw) To: Vitaly Wool Cc: Dave Chinner, Seth Jennings, Dan Streetman, Andrew Morton, Michal Hocko, Vlastimil Babka, LKML, Linux-MM On 2016/10/17 20:03, Vitaly Wool wrote: > Hi Zhong Jiang, > > On Mon, Oct 17, 2016 at 3:58 AM, zhong jiang <zhongjiang@huawei.com> wrote: >> Hi, Vitaly >> >> About the following patch, is it right? >> >> Thanks >> zhongjiang >> On 2016/10/13 12:02, zhongjiang wrote: >>> From: zhong jiang <zhongjiang@huawei.com> >>> >>> At present, zhdr->first_num plus bud can exceed the BUDDY_MASK >>> in encode_handle, it will lead to the the caller handle_to_buddy >>> return the error value. >>> >>> The patch fix the issue by changing the BUDDY_MASK to PAGE_MASK, >>> it will be consistent with handle_to_z3fold_header. At the same time, >>> change the BUDDY_MASK to PAGE_MASK in handle_to_buddy is better. > are you seeing problems with the existing code? first_num should wrap around > BUDDY_MASK and this should be ok because it is way bigger than the number > of buddies. > > ~vitaly > > . > I am curious about the z3fold implement, Thus, I am reviewing the code. Thanks zhongjiang -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2016-10-18 1:57 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2016-10-13 4:02 [PATCH v2] z3fold: fix the potential encode bug in encod_handle zhongjiang 2016-10-17 1:58 ` zhong jiang 2016-10-17 12:03 ` Vitaly Wool 2016-10-17 12:48 ` zhong jiang 2016-10-17 15:30 ` Dan Streetman 2016-10-18 1:53 ` zhong jiang 2016-10-17 13:38 ` zhong jiang
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).