mirror of
https://github.com/ksherlock/mpw.git
synced 2025-01-23 12:32:12 +00:00
move around memory allocation
This commit is contained in:
parent
a0e05db127
commit
f97b6eae24
64
loader.cpp
64
loader.cpp
@ -10,18 +10,27 @@
|
|||||||
#include <CoreServices/CoreServices.h>
|
#include <CoreServices/CoreServices.h>
|
||||||
|
|
||||||
|
|
||||||
uint8_t *memory;
|
uint8_t *Memory;
|
||||||
uint32_t HighWater = 2048;
|
uint32_t HighWater = 0x1000;
|
||||||
|
uint32_t MemorySize;
|
||||||
|
|
||||||
uint32_t EmulatedNewPtr(uint32_t size)
|
uint32_t EmulatedNewPtr(uint32_t size)
|
||||||
{
|
{
|
||||||
if (size & 0x01) size++;
|
if (size & 0x01) size++;
|
||||||
|
|
||||||
|
if (HighWater + size > MemorySize)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "Insufficient Memory!\n");
|
||||||
|
exit(EX_CONFIG);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
uint32_t address = HighWater;
|
uint32_t address = HighWater;
|
||||||
|
|
||||||
|
|
||||||
HighWater += size;
|
HighWater += size;
|
||||||
|
|
||||||
std::memset(memory + HighWater, 0, size);
|
std::memset(Memory + HighWater, 0, size);
|
||||||
|
|
||||||
return address;
|
return address;
|
||||||
}
|
}
|
||||||
@ -29,6 +38,7 @@ uint32_t EmulatedNewPtr(uint32_t size)
|
|||||||
uint8_t ReadByte(const void *data, uint32_t offset)
|
uint8_t ReadByte(const void *data, uint32_t offset)
|
||||||
{
|
{
|
||||||
offset &= 0xffffff;
|
offset &= 0xffffff;
|
||||||
|
if (offset >= MemorySize) return 0;
|
||||||
return ((uint8_t *)data)[offset];
|
return ((uint8_t *)data)[offset];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,6 +57,7 @@ uint32_t ReadLong(const void *data, uint32_t offset)
|
|||||||
void WriteByte(void *data, uint32_t offset, uint8_t value)
|
void WriteByte(void *data, uint32_t offset, uint8_t value)
|
||||||
{
|
{
|
||||||
offset &= 0xffffff;
|
offset &= 0xffffff;
|
||||||
|
if (offset >= MemorySize) return;
|
||||||
((uint8_t *)data)[offset] = value;
|
((uint8_t *)data)[offset] = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,6 +65,8 @@ void WriteWord(void *data, uint32_t offset, uint16_t value)
|
|||||||
{
|
{
|
||||||
offset &= 0xffffff;
|
offset &= 0xffffff;
|
||||||
|
|
||||||
|
if (offset + 1 >= MemorySize) return;
|
||||||
|
|
||||||
((uint8_t *)data)[offset++] = value >> 8;
|
((uint8_t *)data)[offset++] = value >> 8;
|
||||||
((uint8_t *)data)[offset++] = value;
|
((uint8_t *)data)[offset++] = value;
|
||||||
}
|
}
|
||||||
@ -62,6 +75,8 @@ void WriteLong(void *data, uint32_t offset, uint32_t value)
|
|||||||
{
|
{
|
||||||
offset &= 0xffffff;
|
offset &= 0xffffff;
|
||||||
|
|
||||||
|
if (offset + 3 >= MemorySize) return;
|
||||||
|
|
||||||
((uint8_t *)data)[offset++] = value >> 24;
|
((uint8_t *)data)[offset++] = value >> 24;
|
||||||
((uint8_t *)data)[offset++] = value >> 16;
|
((uint8_t *)data)[offset++] = value >> 16;
|
||||||
((uint8_t *)data)[offset++] = value >> 8;
|
((uint8_t *)data)[offset++] = value >> 8;
|
||||||
@ -96,7 +111,6 @@ uint32_t load(const char *file)
|
|||||||
|
|
||||||
std::vector< std::pair<uint32_t, uint32_t> > segments; // segment, address
|
std::vector< std::pair<uint32_t, uint32_t> > segments; // segment, address
|
||||||
|
|
||||||
memory = new uint8_t[16 * 1024 * 1024];
|
|
||||||
|
|
||||||
uint32_t a5 = 0;
|
uint32_t a5 = 0;
|
||||||
|
|
||||||
@ -151,17 +165,20 @@ uint32_t load(const char *file)
|
|||||||
address = EmulatedNewPtr(a5size);
|
address = EmulatedNewPtr(a5size);
|
||||||
|
|
||||||
a5 = address + below;
|
a5 = address + below;
|
||||||
std::memcpy(memory + a5 + jtOffset, data + 16 , jtSize);
|
std::memcpy(Memory + a5 + jtOffset, data + 16 , jtSize);
|
||||||
|
|
||||||
segments[resID] = std::make_pair(address, a5size);
|
segments[resID] = std::make_pair(address, a5size);
|
||||||
|
|
||||||
jtStart = a5 + jtOffset;
|
jtStart = a5 + jtOffset;
|
||||||
jtEnd = jtStart + jtSize;
|
jtEnd = jtStart + jtSize;
|
||||||
|
|
||||||
|
// 0x0934 - CurJTOffset (16-bit)
|
||||||
|
WriteWord(Memory, 0x934, jtOffset);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
address = EmulatedNewPtr(size);
|
address = EmulatedNewPtr(size);
|
||||||
std::memcpy(memory + address, data, size);
|
std::memcpy(Memory + address, data, size);
|
||||||
|
|
||||||
segments[resID] = std::make_pair(address, size);
|
segments[resID] = std::make_pair(address, size);
|
||||||
}
|
}
|
||||||
@ -174,11 +191,11 @@ uint32_t load(const char *file)
|
|||||||
|
|
||||||
for (; jtStart < jtEnd; jtStart += 8)
|
for (; jtStart < jtEnd; jtStart += 8)
|
||||||
{
|
{
|
||||||
uint16_t offset = ReadWord(memory, jtStart);
|
uint16_t offset = ReadWord(Memory, jtStart);
|
||||||
uint16_t seg = ReadWord(memory, jtStart + 4);
|
uint16_t seg = ReadWord(Memory, jtStart + 4);
|
||||||
|
|
||||||
assert(ReadWord(memory, jtStart + 2) == 0x3F3C);
|
assert(ReadWord(Memory, jtStart + 2) == 0x3F3C);
|
||||||
assert(ReadWord(memory, jtStart + 6) == 0xA9F0);
|
assert(ReadWord(Memory, jtStart + 6) == 0xA9F0);
|
||||||
|
|
||||||
assert(seg < segments.size());
|
assert(seg < segments.size());
|
||||||
|
|
||||||
@ -190,8 +207,8 @@ uint32_t load(const char *file)
|
|||||||
uint32_t address = p.first + offset + 4;
|
uint32_t address = p.first + offset + 4;
|
||||||
|
|
||||||
// JMP absolute long
|
// JMP absolute long
|
||||||
WriteWord(memory, jtStart + 2, 0x4EF9);
|
WriteWord(Memory, jtStart + 2, 0x4EF9);
|
||||||
WriteLong(memory, jtStart + 4, address);
|
WriteLong(Memory, jtStart + 4, address);
|
||||||
}
|
}
|
||||||
|
|
||||||
// set pc to jump table entry 0.
|
// set pc to jump table entry 0.
|
||||||
@ -210,7 +227,7 @@ void InitializeMPW(int argc, char **argv)
|
|||||||
memcpy(str32 + 1, argv[0], l);
|
memcpy(str32 + 1, argv[0], l);
|
||||||
while (l < 32) str32[l++] = 0;
|
while (l < 32) str32[l++] = 0;
|
||||||
|
|
||||||
memcpy(memory + 0x910, str32, 32);
|
memcpy(Memory + 0x910, str32, 32);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -230,7 +247,7 @@ void InitializeMPW(int argc, char **argv)
|
|||||||
uint32_t address;
|
uint32_t address;
|
||||||
length = strlen(argv[i]);
|
length = strlen(argv[i]);
|
||||||
address = EmulatedNewPtr(length + 1);
|
address = EmulatedNewPtr(length + 1);
|
||||||
memcpy(memory + address, argv[i], length + 1);
|
memcpy(Memory + address, argv[i], length + 1);
|
||||||
|
|
||||||
argvSpine.push_back(address);
|
argvSpine.push_back(address);
|
||||||
}
|
}
|
||||||
@ -240,20 +257,20 @@ void InitializeMPW(int argc, char **argv)
|
|||||||
uint32_t address = argvAddress;
|
uint32_t address = argvAddress;
|
||||||
for (uint32_t x : argvSpine)
|
for (uint32_t x : argvSpine)
|
||||||
{
|
{
|
||||||
WriteLong(memory, address, x);
|
WriteLong(Memory, address, x);
|
||||||
address += 4;
|
address += 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// same thing for envp... but \0 instead of =
|
// same thing for envp... but \0 instead of =
|
||||||
|
|
||||||
uint32_t address = EmulatedNewPtr(8 + 10);
|
uint32_t address = EmulatedNewPtr(8 + 10);
|
||||||
WriteLong(memory, 0x0316, address);
|
WriteLong(Memory, 0x0316, address);
|
||||||
WriteLong(memory, address, 0x4d50474d); // MPGM - magic
|
WriteLong(Memory, address, 0x4d50474d); // MPGM - magic
|
||||||
WriteLong(memory, address + 4, address + 8); // block ptr
|
WriteLong(Memory, address + 4, address + 8); // block ptr
|
||||||
WriteWord(memory, address + 8, 0x5348); // SH - more magic
|
WriteWord(Memory, address + 8, 0x5348); // SH - more magic
|
||||||
WriteWord(memory, address + 10, argc);
|
WriteWord(Memory, address + 10, argc);
|
||||||
WriteWord(memory, address + 14, argvAddress);
|
WriteWord(Memory, address + 14, argvAddress);
|
||||||
WriteWord(memory, address + 18, envpAddress);
|
WriteWord(Memory, address + 18, envpAddress);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -379,6 +396,9 @@ int main(int argc, char **argv)
|
|||||||
exit(EX_USAGE);
|
exit(EX_USAGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Memory = new uint8_t[Flags.ram];
|
||||||
|
|
||||||
|
|
||||||
load(argv[0]);
|
load(argv[0]);
|
||||||
|
|
||||||
InitializeMPW(argc, argv);
|
InitializeMPW(argc, argv);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user