From: Manfred Spraul <manfred@colorfullife.com>
To: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: linux-kernel mailing list <linux-kernel@vger.kernel.org>
Subject: Re: [BUG] slab debug vs. L1 alignement
Date: Sat, 16 Aug 2003 12:09:50 +0200 [thread overview]
Message-ID: <3F3E02EE.8080909@colorfullife.com> (raw)
In-Reply-To: <1061026667.881.100.camel@gaston>
Benjamin Herrenschmidt wrote:
>>>Yes, I understand that, but that is wrong for GFP_DMA imho. Also,
>>>SLAB_MUST_HWCACHE_ALIGN just disables redzoning, which is not smart,
>>>I'd rather allocate more and keep both redzoning and cache alignement,
>>>that would help catch some of those subtle problems when a chip DMA
>>>engine plays funny tricks.
>>>
>>>
>>>
>>I don't want to upgrade SLAB_HWCACHE_ALIGN to SLAB_MUST_HWCACHE_ALIGN
>>depending on GFP_DMA: IIRC one arch (ppc64?) marks everything as
>>GFP_DMA, because all memory is DMA capable.
>>
>>
>
>Same for ppc32. Anyway, I don't like MUST_HWCACHE_ALIGN because it
>just disables redzoning, I'd rather allocate more and do both redzoning
>and cache alignement.
>
>
I have a patch that creates helper functions that make that simple. The
patch is stuck right now, because it exposes a bug in the i386 debug
register handling. I'll add it redzoning with MUST_HWCACHE_ALIGN after
that one is in.
>Anyway, I _still_ think it's stupid to return non-aligned buffers, both
>for performances, and because that prevents from dealing with such cases,
>typically the SCSI layer assumes alignement here among others...
>
>
I don't care about performance with slab debugging on. kmalloc(4096,)
usually takes ~40 cpu ticks on i386. With debugging on, it includes a
memset and an open coded memcmp - my guess is a few thousand cpu ticks,
and that's intentional. Do not enable it on production systems.
>Regarding O_DIRECT with an unaligned pointer, I haven't looked at this
>case yet, I suppose it will be broken in a whole lot of cases.
>
>
Hmm. That means slab debugging did it's job: The driver contains the
wrong assumption that all pointers are cache line aligned. Without slab
debugging, this would result in rare data corruptions in O_DIRECT apps.
With slab debugging on, it's exposed immediately.
--
Manfred
next prev parent reply other threads:[~2003-08-16 10:09 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-08-15 21:50 [BUG] slab debug vs. L1 alignement Manfred Spraul
2003-08-15 23:41 ` Benjamin Herrenschmidt
2003-08-16 1:47 ` Manfred Spraul
2003-08-16 9:37 ` Benjamin Herrenschmidt
2003-08-16 10:09 ` Manfred Spraul [this message]
2003-08-16 10:43 ` Benjamin Herrenschmidt
2003-08-16 11:21 ` Kai Makisara
2003-08-16 11:36 ` Benjamin Herrenschmidt
2003-08-16 14:39 ` Kai Makisara
-- strict thread matches above, loose matches on Subject: below --
2003-08-17 17:27 James Bottomley
2003-08-18 20:29 ` Kai Makisara
2003-09-30 18:40 ` Manfred Spraul
[not found] <kUMe.2pd.9@gated-at.bofh.it>
[not found] ` <kWuz.41M.5@gated-at.bofh.it>
[not found] ` <kYwo.5Xr.1@gated-at.bofh.it>
[not found] ` <l5HD.4tl.21@gated-at.bofh.it>
[not found] ` <l6kd.53T.1@gated-at.bofh.it>
2003-08-16 12:00 ` Arnd Bergmann
2003-08-16 12:18 ` Manfred Spraul
2003-08-15 14:00 Benjamin Herrenschmidt
2003-08-15 18:51 ` Philippe Elie
2003-08-15 16:54 ` Benjamin Herrenschmidt
2003-08-15 21:16 ` Andrew Morton
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3F3E02EE.8080909@colorfullife.com \
--to=manfred@colorfullife.com \
--cc=benh@kernel.crashing.org \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox