move around memory allocation

This commit is contained in:
Kelvin Sherlock 2013-02-05 22:59:04 -05:00
parent a0e05db127
commit f97b6eae24

View File

@ -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);