* ARM64 readahead: fault retry breaks mmap file read random detection
@ 2015-09-21 20:39 Mark Salyzyn
2015-09-21 21:09 ` Will Deacon
0 siblings, 1 reply; 5+ messages in thread
From: Mark Salyzyn @ 2015-09-21 20:39 UTC (permalink / raw)
To: linux-arm-kernel
Description from commit 45cac65b0fcd
("readahead: fault retry breaks mmap file read random detection")
.fault now can retry. The retry can break state machine of .fault. In
filemap_fault, if page is miss, ra->mmap_miss is increased. In the second
try, since the page is in page cache now, ra->mmap_miss is decreased. And
these are done in one fault, so we can't detect random mmap file access.
Add a new flag to indicate .fault is tried once. In the second try, skip
ra->mmap_miss decreasing. The filemap_fault state machine is ok with it.
I only tested x86, didn't test other archs, but looks the change for other
archs is obvious, but who knows :)
< snip >
Yup, arm64 needs this too! Random read improves by 250%, sequential
read improves by 40%, and random write by 400% to an eMMC device with
dm crypto wrapped around it.
Signed-off-by: Mark Salyzyn <salyzyn@android.com>
Signed-off-by: Riley Andrews <riandrews@android.com>
Cc: Shaohua Li <shli@kernel.org>
Cc: Shaohua Li <shaohua.li@fusionio.com>
Cc: Rik van Riel <riel@redhat.com>
Cc: Wu Fengguang <fengguang.wu@intel.com>
---
arch/arm64/mm/fault.c | 1 +
1 file changed, 1 insertion(+)
diff --git a/arch/arm64/mm/fault.c b/arch/arm64/mm/fault.c
index aba9ead..9fadf6d 100644
--- a/arch/arm64/mm/fault.c
+++ b/arch/arm64/mm/fault.c
@@ -287,6 +287,7 @@ retry:
* starvation.
*/
mm_flags &= ~FAULT_FLAG_ALLOW_RETRY;
+ mm_flags |= FAULT_FLAG_TRIED;
goto retry;
}
}
--
2.6.0.rc0.131.gf624c3d
^ permalink raw reply related [flat|nested] 5+ messages in thread
* ARM64 readahead: fault retry breaks mmap file read random detection
2015-09-21 20:39 ARM64 readahead: fault retry breaks mmap file read random detection Mark Salyzyn
@ 2015-09-21 21:09 ` Will Deacon
2015-09-21 21:36 ` Mark Salyzyn
0 siblings, 1 reply; 5+ messages in thread
From: Will Deacon @ 2015-09-21 21:09 UTC (permalink / raw)
To: linux-arm-kernel
On Mon, Sep 21, 2015 at 09:39:50PM +0100, Mark Salyzyn wrote:
> Description from commit 45cac65b0fcd
> ("readahead: fault retry breaks mmap file read random detection")
>
> .fault now can retry. The retry can break state machine of .fault. In
> filemap_fault, if page is miss, ra->mmap_miss is increased. In the second
> try, since the page is in page cache now, ra->mmap_miss is decreased. And
> these are done in one fault, so we can't detect random mmap file access.
>
> Add a new flag to indicate .fault is tried once. In the second try, skip
> ra->mmap_miss decreasing. The filemap_fault state machine is ok with it.
>
> I only tested x86, didn't test other archs, but looks the change for other
> archs is obvious, but who knows :)
>
> < snip >
>
> Yup, arm64 needs this too! Random read improves by 250%, sequential
> read improves by 40%, and random write by 400% to an eMMC device with
> dm crypto wrapped around it.
Thanks for this. This must've gone in whilst we were developing the initial
version of the arm64 port and has since gone unnoticed.
I'll queue it on the arm64 fixes branch and send a pull request after
some testing.
Will
^ permalink raw reply [flat|nested] 5+ messages in thread
* ARM64 readahead: fault retry breaks mmap file read random detection
2015-09-21 21:09 ` Will Deacon
@ 2015-09-21 21:36 ` Mark Salyzyn
2015-09-21 23:51 ` Will Deacon
0 siblings, 1 reply; 5+ messages in thread
From: Mark Salyzyn @ 2015-09-21 21:36 UTC (permalink / raw)
To: linux-arm-kernel
On 09/21/2015 02:09 PM, Will Deacon wrote:
> On Mon, Sep 21, 2015 at 09:39:50PM +0100, Mark Salyzyn wrote:
>> Description from commit 45cac65b0fcd
>> ("readahead: fault retry breaks mmap file read random detection")
>> . . .
>> Yup, arm64 needs this too! Random read improves by 250%, sequential
>> read improves by 40%, and random write by 400% to an eMMC device with
>> dm crypto wrapped around it.
> Thanks for this. This must've gone in whilst we were developing the initial
> version of the arm64 port and has since gone unnoticed.
>
> I'll queue it on the arm64 fixes branch and send a pull request after
> some testing.
>
> Will
As noted, this fix may need to be propagated to all the arch-specific
code, I was not in a position to check this out on arm (32 bit) and the
benchmarking code I used did not immediately port to 32-bit.
Sincerely -- Mark Salyzyn
^ permalink raw reply [flat|nested] 5+ messages in thread
* ARM64 readahead: fault retry breaks mmap file read random detection
2015-09-21 21:36 ` Mark Salyzyn
@ 2015-09-21 23:51 ` Will Deacon
2015-09-22 14:15 ` Mark Salyzyn
0 siblings, 1 reply; 5+ messages in thread
From: Will Deacon @ 2015-09-21 23:51 UTC (permalink / raw)
To: linux-arm-kernel
On Mon, Sep 21, 2015 at 10:36:40PM +0100, Mark Salyzyn wrote:
> On 09/21/2015 02:09 PM, Will Deacon wrote:
> > On Mon, Sep 21, 2015 at 09:39:50PM +0100, Mark Salyzyn wrote:
> >> Description from commit 45cac65b0fcd
> >> ("readahead: fault retry breaks mmap file read random detection")
> >> . . .
> >> Yup, arm64 needs this too! Random read improves by 250%, sequential
> >> read improves by 40%, and random write by 400% to an eMMC device with
> >> dm crypto wrapped around it.
> > Thanks for this. This must've gone in whilst we were developing the initial
> > version of the arm64 port and has since gone unnoticed.
> >
> > I'll queue it on the arm64 fixes branch and send a pull request after
> > some testing.
> >
> As noted, this fix may need to be propagated to all the arch-specific
> code, I was not in a position to check this out on arm (32 bit) and the
> benchmarking code I used did not immediately port to 32-bit.
You lost me; which arch-specific code are you referring to? The original
patch (in mainline) touches a whole bunch of architectures.
Will
^ permalink raw reply [flat|nested] 5+ messages in thread
* ARM64 readahead: fault retry breaks mmap file read random detection
2015-09-21 23:51 ` Will Deacon
@ 2015-09-22 14:15 ` Mark Salyzyn
0 siblings, 0 replies; 5+ messages in thread
From: Mark Salyzyn @ 2015-09-22 14:15 UTC (permalink / raw)
To: linux-arm-kernel
On 09/21/2015 04:51 PM, Will Deacon wrote:
> On Mon, Sep 21, 2015 at 10:36:40PM +0100, Mark Salyzyn wrote:
>> On 09/21/2015 02:09 PM, Will Deacon wrote:
>>> On Mon, Sep 21, 2015 at 09:39:50PM +0100, Mark Salyzyn wrote:
>>>> Description from commit 45cac65b0fcd
>>>> ("readahead: fault retry breaks mmap file read random detection")
>>>> . . .
>>>> Yup, arm64 needs this too! Random read improves by 250%, sequential
>>>> read improves by 40%, and random write by 400% to an eMMC device with
>>>> dm crypto wrapped around it.
>>> Thanks for this. This must've gone in whilst we were developing the initial
>>> version of the arm64 port and has since gone unnoticed.
>>>
>>> I'll queue it on the arm64 fixes branch and send a pull request after
>>> some testing.
>>>
>> As noted, this fix may need to be propagated to all the arch-specific
>> code, I was not in a position to check this out on arm (32 bit) and the
>> benchmarking code I used did not immediately port to 32-bit.
> You lost me; which arch-specific code are you referring to? The original
> patch (in mainline) touches a whole bunch of architectures.
>
> Will
I see I am mistaken, arm64 was the _only_ one I see that is missing ...
<grin>
Sincerely -- Mark Salyzyn
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2015-09-22 14:15 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-09-21 20:39 ARM64 readahead: fault retry breaks mmap file read random detection Mark Salyzyn
2015-09-21 21:09 ` Will Deacon
2015-09-21 21:36 ` Mark Salyzyn
2015-09-21 23:51 ` Will Deacon
2015-09-22 14:15 ` Mark Salyzyn
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).