mpw/toolbox/stackframe.h

67 lines
1.4 KiB
C
Raw Normal View History

2013-02-15 05:00:15 +00:00
#ifndef __StackFrame_h__
#define __StackFrame_h__
#include <cstdint>
//
template<unsigned N>
void ToolReturn(uint32_t sp, uint32_t value)
{
if (sp == -1) sp = cpuGetAReg(7);
2013-02-15 05:00:15 +00:00
static_assert(N == 2 || N == 4, "Invalid Return Size");
if (N == 4)
{
memoryWriteLong(value, sp);
}
if (N == 2)
{
memoryWriteWord(value, sp);
}
}
// pre-define these templates to prevent instantiation errors.
template<int Bytes, int Offset, typename... Args>
uint32_t StackFrame__(uint32_t sp, uint32_t &x, Args&... args);
template<int Bytes, int Offset, typename... Args>
uint32_t StackFrame__(uint32_t sp, uint16_t &x, Args&... args);
template<int Bytes, int Offset>
uint32_t StackFrame__(uint32_t sp);
2013-02-15 05:00:15 +00:00
template<int Bytes, int Offset>
uint32_t StackFrame__(uint32_t sp)
{
static_assert(Offset == 0, "Invalid Stack Size");
cpuSetAReg(7, sp + Bytes);
return sp + Bytes;
}
template<int Bytes, int Offset, typename... Args>
uint32_t StackFrame__(uint32_t sp, uint32_t &x, Args&... args)
{
x = memoryReadLong(sp + Offset - 4);
return StackFrame__<Bytes, Offset - 4>(sp, args...);
}
template<int Bytes, int Offset, typename... Args>
uint32_t StackFrame__(uint32_t sp, uint16_t &x, Args&... args)
{
x = memoryReadWord(sp + Offset - 2);
return StackFrame__<Bytes, Offset - 2>(sp, args...);
}
template<int Bytes, typename... Args>
uint32_t StackFrame(Args&... args)
{
uint32_t sp = cpuGetAReg(7);
return StackFrame__<Bytes, Bytes>(sp, args...);
}
#endif