genode/ports-foc/src/lib/l4lx/l4_io.cc
Christian Prochaska b38fee2867 L4Linux stability improvements
- search for alternative virtual address regions upwards, starting from
  the given start address, in the 'l4re_rm_attach()' and
  'Region_manager::reserve_range()' functions

- don't treat memory locations above 0x80000000 in l4linux's virtual
  address space as device memory

- align the start address of the vmalloc area according to the assumption
  in 'devicemaps_init()'

Fixes #414.
2013-03-18 13:06:06 +01:00

129 lines
2.8 KiB
C++

/*
* \brief L4Re functions needed by L4Linux.
* \author Stefan Kalkowski
* \date 2011-04-17
*/
/*
* Copyright (C) 2011-2013 Genode Labs GmbH
*
* This file is part of the Genode OS framework, which is distributed
* under the terms of the GNU General Public License version 2.
*/
/* Genode includes */
#include <base/env.h>
#include <base/printf.h>
#include <io_mem_session/connection.h>
#include <env.h>
namespace Fiasco {
#include <l4/io/io.h>
}
using namespace Fiasco;
static bool DEBUG = false;
extern "C" {
l4io_device_handle_t l4io_get_root_device(void)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
int l4io_iterate_devices(l4io_device_handle_t *devhandle,
l4io_device_t *dev, l4io_resource_handle_t *reshandle)
{
PWRN("%s: Not implemented yet!", __func__);
return 1;
}
int l4io_lookup_resource(l4io_device_handle_t devhandle,
enum l4io_resource_types_t type,
l4io_resource_handle_t *reshandle,
l4io_resource_t *res)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
long l4io_request_ioport(unsigned portnum, unsigned len)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
long l4io_request_iomem_region(l4_addr_t phys, l4_addr_t virt,
unsigned long size, int flags)
{
using namespace Genode;
if(DEBUG)
PDBG("phys=%lx virt=%lx size=%lx flags=%x", phys, virt, size, flags);
Io_mem_connection *iomem = new (env()->heap()) Io_mem_connection(phys, size);
L4lx::Dataspace *ds =
L4lx::Env::env()->dataspaces()->insert("iomem", iomem->dataspace());
if (!L4lx::Env::env()->rm()->attach_at(ds, size, 0, (void*)virt)) {
PERR("Could not reserve IO mem region at %lx", virt);
L4lx::Env::env()->dataspaces()->remove(ds);
destroy(env()->heap(), iomem);
return 1;
}
return 0;
}
long l4io_search_iomem_region(l4_addr_t phys, l4_addr_t size,
l4_addr_t *rstart, l4_addr_t *rsize)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
long l4io_request_iomem(l4_addr_t phys, unsigned long size, int flags,
l4_addr_t *virt)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
long l4io_release_iomem(l4_addr_t virt, unsigned long size)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
long l4io_request_irq(int irqnum, l4_cap_idx_t irqcap)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
long l4io_release_irq(int irqnum, l4_cap_idx_t irq_cap)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
int l4io_has_resource(enum l4io_resource_types_t type,
l4vbus_paddr_t start, l4vbus_paddr_t end)
{
PWRN("%s: Not implemented yet!", __func__);
return 0;
}
}