[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <498271DF.6090406@nerdgrounds.com>
Date: Thu, 29 Jan 2009 19:19:59 -0800
From: Jonathan Campbell <jon@...dgrounds.com>
To: "H. Peter Anvin" <hpa@...or.com>
CC: "Peter W. Morreale" <pmorreale@...ell.com>,
devel@...verdev.osuosl.org,
Linux Kernel List <linux-kernel@...r.kernel.org>
Subject: Re: Vramfs: filesystem driver to utilize extra RAM on VGA devices
I don't really see the similarity between the MTD subsystem and dividing
vram up by files. Video cards don't have "erase blocks". And MTD is not
a filesystem. And the onboard memory mtd driver (map system RAM) only
handles one fixed region determined at load time.
Vramfs on the other hand determines what resources to use at mount time.
It supports multiple mounts, one per PCI device, if you want the
combined VRAM of two VGA cards in your system.
I don't think vramfs would fit well into the MTD subsystem.
> Jonathan Campbell wrote:
>
>> Every VGA device connected to the PCI bus has resources that are known
>> to the Linux kernel. One of the memory resources is the video RAM
>> (always the largest prefetchable resource listed), with the base and
>> length known to the PCI subsystem. So, all vramfs needs on mount is the
>> PCI device, and the mountpoint, and it can dole it out to userspace.
>> Reading and writing is handled with ioremap(). mmap() is handled by
>> directly mmaping() that VRAM into user-space (just like /dev/fb0). Files
>> are recorded in system memory as a list of entities with a starting
>> block and length, so no fragmentation is possible.
>>
>> No communication with the GPU is needed to do this, it's possible to use
>> VRAM this way even on devices that nobody in the system knows how to
>> talk to.
>>
>
> There still seems to be quite a bit of overlap between this and the MTD
> subsystem...
>
> -hpa
>
>
--
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