Who uses memory originally from IO device

Adam Lackorzynski adam at os.inf.tu-dresden.de
Wed Jul 9 00:39:17 CEST 2014


Hi,

On Tue Jul 08, 2014 at 11:20:20 +0200, Martin Schröder wrote:
> Am 07.07.2014 23:54, schrieb Adam Lackorzynski:
> >>
> >>After some debugging it am convinced that MOE is not using or blocking this
> >>OCRAM at address 0x0.
> >>
> >>But what is the reason that io cannot allocate the requested memory and maps
> >>instead something of the same size?
> >
> >There's some unfortunate behavior of io that could be the cause here.
> >Could you add 0xc000 as a third flag to the MMIO specification to mark
> >this as a fixed resource? We've changed the behavior internally already.
> 
> 
> yesterday I tracked this down to
> 
> phys_space.cc:25: Phys_space::Phys_space()
> {
>   _set.insert(Phys_region(4 << 22, Phys_region::Addr(~0)));
> 
> Everything below 0x01000000 gets shifted up. After replacing the "4 << 2" by
> "0x0" the resource allocation works fine and as expected.

Aiee, ok...

> Your suggestion 0xc000 is also working. The only cosmetic defect that io
> reports twice the line
> "io      | WARNING: phys mmio resource allocation failed".

Ok.


Adam
-- 
Adam                 adam at os.inf.tu-dresden.de
  Lackorzynski         http://os.inf.tu-dresden.de/~adam/




More information about the l4-hackers mailing list