Subject: Re: dev/ofw/ofdisk.c
To: Tim Rightnour <root@garbled.net>
From: Frank Wille <frank@phoenix.owl.de>
List: port-ofppc
Date: 10/15/2007 21:12:42
Tim Rightnour wrote:
> [...] until ppcoea-rennovation is merged (which should be soon)
Very good! I nearly wanted to ask... :)
> it would be helpful to know which tree you are referring to.
I'm usually working with current source, and ppcoea-renovation "mapped in"
at sys/arch.
> I've let the HEAD rot because I'm focusing all of my
> efforts on the rennovation branch.
But it should really be merged back as soon as possible. The current source
in ofppc is useless.
> I do realize that the current ppcoea-rennovation code for ofppc is not
> 100% ideal.
But it is a good start. It is important that something happens at all!
> There are certainly lots of things in there that can and
> should be done better, however, I just didn't have the hardware to play
> around with it.
You can use me any time for Pegasos2 and Efika. I will also get a PowerMac
this week (to have a OFW machine which really works with NetBSD ;).
> I'm not married to most of the ways I set things up in
> there, but my general philosophy on ofppc on the rennovation branch is
> thus:
>
> 1) We should be talking directly to hardware to use it. We shouldn't be
> sending bytes through the RTAS or OFW to write to the disks.
Absolutely! The OFW-device approach has proven to be worthless several times.
You cannot seriously work with such a system.
> 2) We should be using the RTAS/OFW/whatever at all times to *find*
> devices, and when appropriate, use it to set them up. I think this is
> primarily true for devices that are at the top of a tree.. such as PCI
> bridges. I think we should find the bridge with OFW, and then use standard
> PCI routines to talk to the bridge to find it's children. (those routines
> however, can certainly involve RTAS/OFW calls as much as they need, I
> simply mean we shouldn't just walk the ofw tree looking for pci children,
> because we will likely miss nonstandard cards)
I can only agree, and I guess nobody here will disagree.
I worked on the PCI-bridge code for the Pegasos2 yesterday, and while
implementing direct access to the Marvell registers, like the OpenBSD port
did, I realized that it makes no sense. The code would be plain ugly, and the
Marvell would need to be mapped at a different location than the io or mem
space of the bridge.
I really would like a PCI-config method like Jochen has done! What do you
think about it?
--
_ Frank Wille (frank@phoenix.owl.de)
_ // http://sun.hasenbraten.de/~frank/
\X/ Phx @ #AmigaGer