| To: | Atsushi Nemoto <anemo@mba.ocn.ne.jp> |
|---|---|
| Subject: | Re: flush_kernel_dcache_page() not needed ? |
| From: | Franck Bui-Huu <vagabon.xyz@gmail.com> |
| Date: | Tue, 04 Sep 2007 14:46:54 +0200 |
| Cc: | linux-mips@linux-mips.org |
| Dkim-signature: | a=rsa-sha1; c=relaxed/relaxed; d=gmail.com; s=beta; h=domainkey-signature:received:received:message-id:date:from:user-agent:mime-version:to:cc:subject:references:in-reply-to:content-type:content-transfer-encoding; b=PLmKz/QyMIPfLenvOFbMWe3R8LNRdIU6wpwzqHwumqDQO86LLvz8ukkP8InmNHPn1NrofOkzSNfAqQeMBO3quZpGLtJssg5E9RVazNLaiLFO4bN/+PS2lFNXqc67CQi77gzmhTlLFX52Z8yfpxYKYxjRuae9z4IwGCVzQaZmKqs= |
| Domainkey-signature: | a=rsa-sha1; c=nofws; d=gmail.com; s=beta; h=received:message-id:date:from:user-agent:mime-version:to:cc:subject:references:in-reply-to:content-type:content-transfer-encoding; b=OnIU74j3M6zx2b68QV2lARv39PwHYYsY+1M4HvHdAs0sggZoXDX8QpPXWMDMxIKecJk4M9J1ue75mpIo4QqJAzxy74Z5qQvY/ydsRs74RAUbF5PIbLfaPj76JzBmv7zQK65pDDUDODsejKSsKG5eEFkXD+YBssNLKEd03tOMS2Y= |
| In-reply-to: | <20070904.005400.52128244.anemo@mba.ocn.ne.jp> |
| Original-recipient: | rfc822;linux-mips@linux-mips.org |
| References: | <46D8089F.3010109@gmail.com> <20070903.225239.61509667.anemo@mba.ocn.ne.jp> <46DC29F0.3060200@gmail.com> <20070904.005400.52128244.anemo@mba.ocn.ne.jp> |
| Sender: | linux-mips-bounce@linux-mips.org |
| User-agent: | Thunderbird 2.0.0.5 (X11/20070719) |
Atsushi Nemoto wrote:
> Indeed. But copy_strings() is not rare case (called on each execve),
> so there might be some constraints which make us free from the
> aliasing problem.
The point is that this _generic_ function has been created so we need
to understand if MIPS architecture needs to implement it or not,
whatever its current usages. This was actually what I was trying to
understand with this thread.
Whatever the constraints, they don't seem to be intended at all since
flush_kernel_dcache_page() is called... So even if the current code is
working fine, it seems very fragile _if_ MIPS needs to implement this
cache helper.
> I'll look at it further, but any testcase are welcome.
One thing you might want to try is:
$ echo 0 > /proc/sys/kernel/randomize_va_space
and see if your system still works fine. This command should avoid a
data cache flush when moving the stack around. See shift_arg_pages().
With this, maybe you could give this testcase a try:
$ /bin/echo "`seq 10000`" > seq.txt
and see if seq.txt is correct. This command should pass to echo (not
the bash builtin one) a long argument that should fill your
dcache.
That said the execve syscall code is quite 'hairy' and it may not be
suprising that after this syscall the dcache has been completly
flushed and thus make the problem disappear.
Franck
|
| <Prev in Thread] | Current Thread | [Next in Thread> |
|---|---|---|
| ||
| Previous by Date: | Re: [PATCH] malta4kec hang in calibrate_delay fix, Ralf Baechle |
|---|---|
| Next by Date: | Re: [PATCH] malta4kec hang in calibrate_delay fix, Thiemo Seufer |
| Previous by Thread: | Re: flush_kernel_dcache_page() not needed ?, Atsushi Nemoto |
| Next by Thread: | Re: flush_kernel_dcache_page() not needed ?, Atsushi Nemoto |
| Indexes: | [Date] [Thread] [Top] [All Lists] |