2020-04-09 17:12:58 +02:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
|
|
|
|
|
*
|
2021-04-22 01:24:48 -07:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2020-04-09 17:12:58 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <AK/StringView.h>
|
|
|
|
|
#include <Kernel/VM/MemoryManager.h>
|
|
|
|
|
|
|
|
|
|
namespace Kernel {
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
struct TypedMapping {
|
|
|
|
|
const T* ptr() const { return reinterpret_cast<const T*>(region->vaddr().offset(offset).as_ptr()); }
|
|
|
|
|
T* ptr() { return reinterpret_cast<T*>(region->vaddr().offset(offset).as_ptr()); }
|
|
|
|
|
const T* operator->() const { return ptr(); }
|
2020-05-23 15:57:19 +02:00
|
|
|
T* operator->() { return ptr(); }
|
2020-04-09 17:12:58 +02:00
|
|
|
const T& operator*() const { return *ptr(); }
|
|
|
|
|
T& operator*() { return *ptr(); }
|
|
|
|
|
OwnPtr<Region> region;
|
|
|
|
|
size_t offset { 0 };
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
2021-03-06 19:33:25 -08:00
|
|
|
static TypedMapping<T> map_typed(PhysicalAddress paddr, size_t length, Region::Access access = Region::Access::Read)
|
2020-04-09 17:12:58 +02:00
|
|
|
{
|
|
|
|
|
TypedMapping<T> table;
|
2021-02-14 09:57:19 +01:00
|
|
|
table.region = MM.allocate_kernel_region(paddr.page_base(), page_round_up(length), {}, access);
|
2020-04-09 17:12:58 +02:00
|
|
|
table.offset = paddr.offset_in_page();
|
|
|
|
|
return table;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
static TypedMapping<T> map_typed(PhysicalAddress paddr)
|
|
|
|
|
{
|
|
|
|
|
return map_typed<T>(paddr, sizeof(T));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
static TypedMapping<T> map_typed_writable(PhysicalAddress paddr)
|
|
|
|
|
{
|
|
|
|
|
return map_typed<T>(paddr, sizeof(T), Region::Access::Read | Region::Access::Write);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|