mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-11 15:33:04 +00:00
base: Tell a mapping wether it maps IO memory.
This commit is contained in:
parent
cfa0a40d5e
commit
91c27f3f72
@ -37,7 +37,8 @@ namespace Genode {
|
||||
* Constructor
|
||||
*/
|
||||
Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined, unsigned l2size = PAGE_SIZE_LOG2,
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned l2size = PAGE_SIZE_LOG2,
|
||||
bool rw = true)
|
||||
:
|
||||
_from_phys_addr(src_addr),
|
||||
|
@ -41,7 +41,8 @@ namespace Genode {
|
||||
* Constructor
|
||||
*/
|
||||
Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined, unsigned l2size = L4_LOG2_PAGESIZE,
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned l2size = L4_LOG2_PAGESIZE,
|
||||
bool rw = true, bool grant = false)
|
||||
:
|
||||
_dst_addr(dst_addr),
|
||||
|
@ -46,7 +46,8 @@ namespace Genode {
|
||||
* Constructor
|
||||
*/
|
||||
Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined, unsigned l2size = L4_LOG2_PAGESIZE,
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned l2size = L4_LOG2_PAGESIZE,
|
||||
bool rw = true, bool grant = false)
|
||||
: _dst_addr(dst_addr), _src_addr(src_addr),
|
||||
_write_combined(write_combined), _log2size(l2size),
|
||||
|
@ -28,7 +28,8 @@ namespace Genode {
|
||||
* Constructor
|
||||
*/
|
||||
Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined, unsigned l2size = 12, bool rw = true) { }
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned l2size = 12, bool rw = true) { }
|
||||
|
||||
/**
|
||||
* Construct invalid mapping
|
||||
|
@ -32,6 +32,7 @@ namespace Genode
|
||||
addr_t virt_address;
|
||||
addr_t phys_address;
|
||||
bool write_combined;
|
||||
bool io_mem;
|
||||
unsigned size_log2;
|
||||
bool writable;
|
||||
|
||||
@ -39,10 +40,11 @@ namespace Genode
|
||||
* Construct valid mapping
|
||||
*/
|
||||
Mapping(addr_t const va, addr_t const pa, bool const wc,
|
||||
unsigned const sl2 = MIN_MAPPING_SIZE_LOG2, bool w = 1)
|
||||
bool io, unsigned const sl2 = MIN_MAPPING_SIZE_LOG2,
|
||||
bool const w = 1)
|
||||
:
|
||||
virt_address(va), phys_address(pa), write_combined(wc),
|
||||
size_log2(sl2), writable(w)
|
||||
io_mem(io), size_log2(sl2), writable(w)
|
||||
{ }
|
||||
|
||||
/**
|
||||
|
@ -81,7 +81,7 @@ namespace Genode {
|
||||
|
||||
Resolution(addr_t virtual_page_address,
|
||||
addr_t physical_page_address,
|
||||
bool write_combined,
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned size_log2 = DEFAULT_SIZE_LOG2,
|
||||
bool writeable = DEFAULT_WRITEABLE)
|
||||
: _valid(true)
|
||||
|
@ -43,7 +43,8 @@ namespace Genode {
|
||||
* Constructor
|
||||
*/
|
||||
Mapping(addr_t dst_addr, addr_t map_addr,
|
||||
bool write_combined, unsigned size_log2 = PAGE_SIZE_LOG2,
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned size_log2 = PAGE_SIZE_LOG2,
|
||||
bool rw = true)
|
||||
:
|
||||
_dst_addr(dst_addr), _core_local_addr(map_addr),
|
||||
|
@ -40,7 +40,8 @@ namespace Genode {
|
||||
* Constructor
|
||||
*/
|
||||
Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined, unsigned l2size = 12, bool rw = true);
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned l2size = 12, bool rw = true);
|
||||
|
||||
/**
|
||||
* Construct invalid mapping
|
||||
|
@ -62,7 +62,8 @@ static inline Okl4::L4_ThreadId_t thread_get_my_global_id()
|
||||
*************/
|
||||
|
||||
Mapping::Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined, unsigned l2size, bool rw)
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned l2size, bool rw)
|
||||
:
|
||||
_fpage(L4_FpageLog2(dst_addr, l2size)),
|
||||
/*
|
||||
|
@ -50,7 +50,7 @@ namespace Genode {
|
||||
* Constructor
|
||||
*/
|
||||
Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined,
|
||||
bool write_combined, bool io_mem,
|
||||
unsigned l2size = Pistachio::get_page_size_log2(),
|
||||
bool rw = true, bool grant = false);
|
||||
|
||||
|
@ -32,7 +32,8 @@ using namespace Pistachio;
|
||||
*************/
|
||||
|
||||
Mapping::Mapping(addr_t dst_addr, addr_t src_addr,
|
||||
bool write_combined, unsigned l2size, bool rw, bool grant)
|
||||
bool write_combined, bool io_mem, unsigned l2size,
|
||||
bool rw, bool grant)
|
||||
:
|
||||
_write_combined(write_combined)
|
||||
{
|
||||
|
@ -256,6 +256,7 @@ int Rm_client::pager(Ipc_pager &pager)
|
||||
Mapping mapping(dst_fault_area.base(),
|
||||
src_fault_area.base(),
|
||||
src_dataspace->write_combined(),
|
||||
src_dataspace->is_io_mem(),
|
||||
map_size_log2,
|
||||
src_dataspace->writable());
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user