On Friday, February 6, 2009 4:56 am Hugh Dickins wrote: > On Fri, 6 Feb 2009, Benjamin Herrenschmidt wrote: > > On Thu, 2009-02-05 at 14:33 -0800, Jesse Barnes wrote: > > > One option there would be to provide the file but just use anonymous > > > memory to back it. X will happily think it's messing with legacy VGA > > > memory, but it shouldn't matter that it's not actually affecting hw. > > > > What about this (untested) patch ? > > > > powerpc/pci: mmap anonymous memory when legacy_mem doesn't exist > > > > The new legacy_mem file in sysfs is causing problems with X on machines > > that don't support legacy memory access. The way I initially implemented > > it, we would fail with -ENXIO when trying to mmap it, thus exposing to > > X that we do support the API but there is no legacy memory. > > > > Unfortunately, X poor error handling is causing it to fail to start when > > it gets this error. > > > > This implements a workaround hack that instead maps anonymous memory > > instead (using shmem if VM_SHARED is set, just like /dev/zero does). > > > > Signed-off-by: Benjamin Herrenschmidt <benh@xxxxxxxxxxxxxxxxxxx> > > --- > > Beautiful idea, works very nicely for me. > Put a dummy in the baby's mouth to stop it crying. > > I still don't understand the point of this legacy_mem file at all, > and why X should want to mmap it, if it works so well when it's > thus divorced from reality. But I won't worry my pretty little > head over it any further - please don't waste your time trying > to explain it to me! Hugh, did you get a chance to try my X patch (w/o Ben's patch applied)? If it also works, we should apply it to X too, if only to make porting to future platforms a little easier. Since you probably don't want to know, you can skip this paragraph as it describes the motivation behind the legacy_mem file. :) The motivation for it was to support machines with multihead video card configurations, but which could also support multiple legacy port I/O and memory spaces (e.g. on a per PCI domain basis). It allows X to run option ROMs on multiple devices simultaneously, and can also help with hardware that can't route legacy space from a given host bus to arbitrary system addresses. When we put this in initially, Ben knew there were some platforms where legacy memory simply wasn't available, but we figured that shouldn't be a problem, since X didn't really *need* that space to function (most ROMs just put splash screens there). Unfortunately in the interim, X made the lack of an mmap'able legacy_mem file into a fatal error. In the past, doing Linux bringup on a platform with a complex I/O topology (sparc, ia64, alpha, etc.) usually meant doing X bring up as well, often by adding new interfaces or hacks to X. With the legacy_mem and io files, there's a chance that X won't have to be modified at bring up time, so in that sense the APIs are a step forward. However that also means your platform has to support the APIs in a way consistent with how X uses them, as you discovered. :) -- Jesse Barnes, Intel Open Source Technology Center -- To unsubscribe from this list: send the line "unsubscribe kernel-testers" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html