Re: [PATCH] sparc: use asm-generic/scatterlist.h

From: Arnd Bergmann
Date: Mon Mar 01 2010 - 06:30:12 EST


On Monday 01 March 2010, FUJITA Tomonori wrote:
> On Fri, 26 Feb 2010 04:35:36 -0800 (PST)
> David Miller <davem@xxxxxxxxxxxxx> wrote:
>
> You are referring to the following code (I guess that this hack came
> from x86)?
>
> #if __BITS_PER_LONG == 64
> #define sg_dma_len(sg) ((sg)->dma_length)
> #else
> #define sg_dma_len(sg) ((sg)->length)
> #endif /* 64 bit */
>
> if so, seems that you are right. we could simply have:
>
> #define sg_dma_len(sg) ((sg)->dma_length)

I did it the above way so it would work for any architecture that
wants it. IIRC, similar constructs were used in multiple architectures
before, using the __BITS_PER_LONG macro made this portable.

> The current users of asm-generic/scatterlist.h are microblaze, s390,
> score, sh, and x86.
>
> The first three users don't support DMA so sg_dma_len doesn't matter
> for them.
>
> sh and x86_32 use sg->length, x86_64 uses sg->dma_length. However, sh
> and x86_32 sets dma_length in dma_map_sg() so they can use
> sg->dma_length.
>
> I'll clean up this in the next merge window.

Ok, great. I think a good way to clean this up would be to convert
all architectures to use asm-generic/scatterlist.h first, and then
move it to linux/scatterlist once it is architecture intedepent.

Arnd
--
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/