2019-04-06 14:29:29 +02:00
|
|
|
#pragma once
|
|
|
|
|
2019-07-03 21:17:35 +02:00
|
|
|
#include <AK/Types.h>
|
|
|
|
|
2019-04-06 14:29:29 +02:00
|
|
|
class PhysicalAddress {
|
|
|
|
public:
|
2019-05-28 11:53:16 +02:00
|
|
|
PhysicalAddress() {}
|
2019-07-03 21:17:35 +02:00
|
|
|
explicit PhysicalAddress(u32 address)
|
2019-05-28 11:53:16 +02:00
|
|
|
: m_address(address)
|
|
|
|
{
|
|
|
|
}
|
2019-04-06 14:29:29 +02:00
|
|
|
|
2019-07-03 21:17:35 +02:00
|
|
|
PhysicalAddress offset(u32 o) const { return PhysicalAddress(m_address + o); }
|
|
|
|
u32 get() const { return m_address; }
|
|
|
|
void set(u32 address) { m_address = address; }
|
|
|
|
void mask(u32 m) { m_address &= m; }
|
2019-04-06 14:29:29 +02:00
|
|
|
|
|
|
|
bool is_null() const { return m_address == 0; }
|
|
|
|
|
2019-07-03 21:17:35 +02:00
|
|
|
u8* as_ptr() { return reinterpret_cast<u8*>(m_address); }
|
|
|
|
const u8* as_ptr() const { return reinterpret_cast<const u8*>(m_address); }
|
2019-04-06 14:29:29 +02:00
|
|
|
|
2019-07-03 21:17:35 +02:00
|
|
|
u32 page_base() const { return m_address & 0xfffff000; }
|
2019-04-06 14:29:29 +02:00
|
|
|
|
|
|
|
bool operator==(const PhysicalAddress& other) const { return m_address == other.m_address; }
|
2019-06-11 21:12:17 +10:00
|
|
|
bool operator!=(const PhysicalAddress& other) const { return m_address != other.m_address; }
|
|
|
|
bool operator>(const PhysicalAddress& other) const { return m_address > other.m_address; }
|
|
|
|
bool operator>=(const PhysicalAddress& other) const { return m_address >= other.m_address; }
|
|
|
|
bool operator<(const PhysicalAddress& other) const { return m_address < other.m_address; }
|
|
|
|
bool operator<=(const PhysicalAddress& other) const { return m_address <= other.m_address; }
|
2019-04-06 14:29:29 +02:00
|
|
|
|
|
|
|
private:
|
2019-07-03 21:17:35 +02:00
|
|
|
u32 m_address { 0 };
|
2019-04-06 14:29:29 +02:00
|
|
|
};
|