PPC beginner questions
David H. Lynch Jr.
dhlii at dlasys.net
Tue Aug 22 18:53:27 EST 2006
Wade Maxfield wrote:
> I'm new to the PPC and I have a few questions. I have written a
> driver in the past for the X86 family, using i/o ports, but it was
> kernel 2.0 and i/o ports are not mmu handled.
> I've been looking through the archive and I am slowly growing more
The PPC MMU is pretty simple compared to the x86.
Basically the MMU unit is a peice of hardware that maps "virtual"
addresses to "physical" addresses.
Its use is enabled/disabled by two bits in the PPC Machine Status
register - 1 for instructions, 1 for data.
The MMU itself is basically a 64 entry lookup table. Virtual address
X corresponds to physical address Y.
When a request is made for an address that is not in the 64 entry
MMU table things become more complex
- an exception is generated and code inside Linux searches its
tables to find the correct entry to stuff into the MMU.
NORMALLY there is no correspondence between physical addresses and
virtual ones. But it is possible (and might be useful for debugging) to
stuff an entry
where physical=virtual. If you look inside head_4xx.S for
CONFIG_SERIAL_TEXT_DEBUG or something like that you should see how to do it.
However manually stuffed entries in the MMU will eventually get
blown away. I spent a week trying to trace a problem caused by that down.
> We are using Xilinx with PPC built in.
> The PPC has a memory management unit. All of the IP we've added is
> mapped to physical addresses.
> 1. Can I access the memory the peripherasl are mapped to directly
> within the driver without going through functions?
> if NOT, then Do I use
> 1. ioremap(),
Once you have done the ioremap(), you can use the address returned
exactly the way you would have used the physical address previously.
> 2. request_mem_region(),
> 3. request_region()
> 4. something else?
> 2. Are there any gotcha's with the ppc 405 that Xilinx uses that I
> should know about?
Are you doing board bringup ?
If you are not bringing up a new board - then the big gotcha's
should already be covered.
If you are doing board bringup - I would recommend following the
existing xilinx packages closely.
> Linuxppc-embedded mailing list
> Linuxppc-embedded at ozlabs.org
Dave Lynch DLA Systems
Software Development: Embedded Linux
717.627.3770 dhlii at dlasys.net http://www.dlasys.net
fax: 1.253.369.9244 Cell: 1.717.587.7774
Over 25 years' experience in platforms, languages, and technologies too numerous to list.
"Any intelligent fool can make things bigger and more complex... It takes a touch of genius - and a lot of courage to move in the opposite direction."
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the Linuxppc-embedded