[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <200811181553.mAIFr5RT057348@fcbayern.americas.sgi.com>
Date: Tue, 18 Nov 2008 09:53:04 -0600 (CST)
From: John Keller <jpk@....com>
To: tony.luck@...el.com (Luck, Tony)
Cc: jpk@....com (John Keller), bwalle@...e.de (Bernhard Walle),
linux-ia64@...r.kernel.org (linux-ia64@...r.kernel.org),
linux-kernel@...r.kernel.org (linux-kernel@...r.kernel.org)
Subject: Re: [PATCH] ia64: SN specific version of dma_get_required_mask()
>
> > This patch addresses a problem on SN Altix systems with < 4GB, where
> > device drivers using the dma_get_required_mask() API would be told
> > to use 32 bit DMA, when 64 bit is more efficient.
>
> Even if someone did configure an Altix with < 4GB (which seems a very
> unlikely occurance) all of that 4G would be located above 4GB (lowest
> physical address on Altix is something like 384 TB, isn't it?)
>
> Did we really make some dma mask decisions based on the amount
> of memory rather than its location? If we do, then perhaps we
> should fix this in a generic place, not in sn2 specific code.
>
> -Tony
>
This is the generic routine for all archs and platforms...
drivers/base/platform.c
#ifndef ARCH_HAS_DMA_GET_REQUIRED_MASK
u64 dma_get_required_mask(struct device *dev)
{
u32 low_totalram = ((max_pfn - 1) << PAGE_SHIFT);
u32 high_totalram = ((max_pfn - 1) >> (32 - PAGE_SHIFT));
u64 mask;
if (!high_totalram) {
/* convert to mask just covering totalram */
low_totalram = (1 << (fls(low_totalram) - 1));
low_totalram += low_totalram - 1;
mask = low_totalram;
} else {
high_totalram = (1 << (fls(high_totalram) - 1));
high_totalram += high_totalram - 1;
mask = (((u64)high_totalram) << 32) + 0xffffffff;
}
return mask;
}
EXPORT_SYMBOL_GPL(dma_get_required_mask);
#endif
John
----
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists