mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-15 10:39:13 +01:00
30e437f9e3
variables, writeable strings and dangerously shadowed variables. index(), gamma(), exp() and y0() are POSIX functions and using those names can cause namespace confusion. A number of C files were missing the final newline required by ANSI C and some versions of GCC are pedantic enough to complain about this. These changes simply the scons build, allowing us to get rid of filterWarnings which is simply more trouble than it's worth. git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@5574 8ced0084-cf51-0410-be5f-012b33b47a6e
53 lines
1.4 KiB
C
53 lines
1.4 KiB
C
|
|
#include "Defines.h"
|
|
#include "Instructions.h"
|
|
|
|
enum Modify
|
|
{
|
|
MOD_CR0 = (1 << 0),
|
|
MOD_CR1 = (1 << 1),
|
|
MOD_SR = (1 << 2),
|
|
MOD_XER = (1 << 3),
|
|
MOD_FPSCR = (1 << 4)
|
|
};
|
|
enum IOput
|
|
{
|
|
IO_ARG1 = (1 << 0),
|
|
IO_ARG2 = (1 << 1),
|
|
IO_ARG3 = (1 << 2),
|
|
};
|
|
enum inst_type
|
|
{
|
|
TYPE_INTEGER,
|
|
TYPE_FLOAT
|
|
};
|
|
|
|
struct inst
|
|
{
|
|
char name[16];
|
|
u32 Modifies; // Flag modification
|
|
u8 numInput;
|
|
u32 Input;
|
|
u32 Ouput;
|
|
inst_type type;
|
|
void (*Call)(u32*, u32*, u32*, u32*);
|
|
void (*CallFP)(float*, float*, float*, float*);
|
|
|
|
};
|
|
|
|
static inst instructions[] = {
|
|
{ "add", NULL, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1,TYPE_INTEGER, add},
|
|
{ "add.", MOD_CR0, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1,TYPE_INTEGER, add},
|
|
{ "subfc", NULL, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1,TYPE_INTEGER, subfc},
|
|
{ "subfc.", MOD_CR0, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1,TYPE_INTEGER, subfcRC},
|
|
{ "divw", NULL, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1, TYPE_INTEGER, divw},
|
|
{ "divw.", MOD_CR0, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1,TYPE_INTEGER, divwRC},
|
|
{ "divwo", MOD_XER, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1,TYPE_INTEGER, divwo},
|
|
{ "divwo.", MOD_CR0 | MOD_XER, 3, IO_ARG1 | IO_ARG2 | IO_ARG3, IO_ARG1, TYPE_INTEGER, divwoRC},
|
|
//{ "fsqrt", MOD_FPSCR, 2, IO_ARG1 | IO_ARG2, IO_ARG1,TYPE_FLOAT, NULL, fsqrt},
|
|
//{ "fsqrt.", MOD_CR1 | MOD_FPSCR, 2, IO_ARG1 | IO_ARG2, IO_ARG1,TYPE_FLOAT, NULL, fsqrtRC}
|
|
};
|
|
|
|
|
|
void RunInstruction(u32 inst);
|