mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 07:38:10 +00:00
UserspaceEmulator: Add basic TLS (thread-local storage) support
The SoftMMU now receives full X86::LogicalAddress values from SoftCPU. This allows the MMU to reroute TLS accesses to a special memory region. The ELF executable's PT_TLS header tells us how to allocate the TLS. Basically, the GS register points to a magical 4-byte area which has a pointer to the TCB (thread control block). The TCB lives in normal flat memory space and is accessed through the DS register.
This commit is contained in:
parent
df95e25eaa
commit
734f63d522
4 changed files with 77 additions and 50 deletions
|
@ -51,6 +51,7 @@ SoftCPU::SoftCPU(Emulator& emulator)
|
|||
m_segment[(int)X86::SegmentRegister::DS] = 0x20;
|
||||
m_segment[(int)X86::SegmentRegister::ES] = 0x20;
|
||||
m_segment[(int)X86::SegmentRegister::SS] = 0x20;
|
||||
m_segment[(int)X86::SegmentRegister::GS] = 0x28;
|
||||
}
|
||||
|
||||
void SoftCPU::dump() const
|
||||
|
@ -83,59 +84,59 @@ u32 SoftCPU::read32()
|
|||
|
||||
u8 SoftCPU::read_memory8(X86::LogicalAddress address)
|
||||
{
|
||||
ASSERT(address.selector() == 0x18 || address.selector() == 0x20);
|
||||
auto value = m_emulator.mmu().read8(address.offset());
|
||||
ASSERT(address.selector() == 0x18 || address.selector() == 0x20 || address.selector() == 0x28);
|
||||
auto value = m_emulator.mmu().read8(address);
|
||||
#ifdef MEMORY_DEBUG
|
||||
printf("\033[36;1mread_memory8: @%08x -> %02x\033[0m\n", address.offset(), value);
|
||||
printf("\033[36;1mread_memory8: @%08x:%08x -> %02x\033[0m\n", address.selector(), address.offset(), value);
|
||||
#endif
|
||||
return value;
|
||||
}
|
||||
|
||||
u16 SoftCPU::read_memory16(X86::LogicalAddress address)
|
||||
{
|
||||
ASSERT(address.selector() == 0x18 || address.selector() == 0x20);
|
||||
auto value = m_emulator.mmu().read16(address.offset());
|
||||
ASSERT(address.selector() == 0x18 || address.selector() == 0x20 || address.selector() == 0x28);
|
||||
auto value = m_emulator.mmu().read16(address);
|
||||
#ifdef MEMORY_DEBUG
|
||||
printf("\033[36;1mread_memory16: @%08x -> %04x\033[0m\n", address.offset(), value);
|
||||
printf("\033[36;1mread_memory16: @%04x:%08x -> %04x\033[0m\n", address.selector(), address.offset(), value);
|
||||
#endif
|
||||
return value;
|
||||
}
|
||||
|
||||
u32 SoftCPU::read_memory32(X86::LogicalAddress address)
|
||||
{
|
||||
ASSERT(address.selector() == 0x18 || address.selector() == 0x20);
|
||||
auto value = m_emulator.mmu().read32(address.offset());
|
||||
ASSERT(address.selector() == 0x18 || address.selector() == 0x20 || address.selector() == 0x28);
|
||||
auto value = m_emulator.mmu().read32(address);
|
||||
#ifdef MEMORY_DEBUG
|
||||
printf("\033[36;1mread_memory32: @%08x -> %08x\033[0m\n", address.offset(), value);
|
||||
printf("\033[36;1mread_memory32: @%04x:%08x -> %08x\033[0m\n", address.selector(), address.offset(), value);
|
||||
#endif
|
||||
return value;
|
||||
}
|
||||
|
||||
void SoftCPU::write_memory8(X86::LogicalAddress address, u8 value)
|
||||
{
|
||||
ASSERT(address.selector() == 0x20);
|
||||
ASSERT(address.selector() == 0x20 || address.selector() == 0x28);
|
||||
#ifdef MEMORY_DEBUG
|
||||
printf("\033[35;1mwrite_memory8: @%08x <- %02x\033[0m\n", address.offset(), value);
|
||||
printf("\033[35;1mwrite_memory8: @%04x:%08x <- %02x\033[0m\n", address.selector(), address.offset(), value);
|
||||
#endif
|
||||
m_emulator.mmu().write8(address.offset(), value);
|
||||
m_emulator.mmu().write8(address, value);
|
||||
}
|
||||
|
||||
void SoftCPU::write_memory16(X86::LogicalAddress address, u16 value)
|
||||
{
|
||||
ASSERT(address.selector() == 0x20);
|
||||
ASSERT(address.selector() == 0x20 || address.selector() == 0x28);
|
||||
#ifdef MEMORY_DEBUG
|
||||
printf("\033[35;1mwrite_memory16: @%08x <- %04x\033[0m\n", address.offset(), value);
|
||||
printf("\033[35;1mwrite_memory16: @%04x:%08x <- %04x\033[0m\n", address.selector(), address.offset(), value);
|
||||
#endif
|
||||
m_emulator.mmu().write16(address.offset(), value);
|
||||
m_emulator.mmu().write16(address, value);
|
||||
}
|
||||
|
||||
void SoftCPU::write_memory32(X86::LogicalAddress address, u32 value)
|
||||
{
|
||||
ASSERT(address.selector() == 0x20);
|
||||
ASSERT(address.selector() == 0x20 || address.selector() == 0x28);
|
||||
#ifdef MEMORY_DEBUG
|
||||
printf("\033[35;1mwrite_memory32: @%08x <- %08x\033[0m\n", address.offset(), value);
|
||||
printf("\033[35;1mwrite_memory32: @%04x:%08x <- %08x\033[0m\n", address.selector(), address.offset(), value);
|
||||
#endif
|
||||
m_emulator.mmu().write32(address.offset(), value);
|
||||
m_emulator.mmu().write32(address, value);
|
||||
}
|
||||
|
||||
void SoftCPU::push32(u32 value)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue