Re: [PATCH 1 of 3] Introduce __memcpy_toio32
From: Matt Mackall
Date: Wed Dec 28 2005 - 01:23:01 EST
On Tue, Dec 27, 2005 at 10:03:32PM -0800, David Wagner wrote:
>
> In article <20051228035231.GA3356@xxxxxxxxx> you write:
> >> +void fastcall __memcpy_toio32(volatile void __iomem *d, const void
> >*s, size_t count)
> >> +{
> >> + volatile u32 __iomem *dst = d;
> >> + const u32 *src = s;
> >> +
> >> + while (--count >= 0) {
> >> + __raw_writel(*src++, dst++);
> >> +}
> >
> >Suspicious use of volatile - writel is doing the actual write, this
> >function never does a dereference. As you've already got private
> >copies of the pointers already in s and d, it's perfectily reasonable
> >and idiomatic to do:
> >
> > while (--count >= 0)
> > __raw_writel(*s++, d++);
>
> I don't think *s++ or d++ is going to be accepted by the compiler,
> given that s and d are both "void *"'s. The posted code casts to
> "u32 *", which should make the dereference and autoincrement work
> correctly.
>
> [Not posted to linux-kernel, in case I'm totally confused.]
No, you're absolutely right. It's idiomatic for things like strcpy,
where the type is known, but not for memcpy.
However, it just so happens that GCC will happily treat math on void
pointers as if they were char pointers. So this in fact will
compile without errors:
void cpy(void *a, void *b, int count)
{
while (count--)
copybyte(a++, b++);
}
Linus thinks this is a feature but I don't, so I'm not recommending
it. In fact, given the whole point of this function is to copy dwords,
not bytes, this GCCism fails us for type-safety.
At any rate, the dereference on s above _is_ a compile error - it's void
type.
[cc:ed back to lkml to keep me honest]
--
Mathematics is the supreme nostalgia of our time.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/