diff options
author | StapleButter <thetotalworm@gmail.com> | 2017-03-16 23:01:22 +0100 |
---|---|---|
committer | StapleButter <thetotalworm@gmail.com> | 2017-03-16 23:01:22 +0100 |
commit | 8a4ed8f41ca54164fdb335343461ab5f9c3bd87f (patch) | |
tree | 28ba71576603fef73dfcce5db33e157ec236e6c5 /src/ARMInterpreter_ALU.h | |
parent | 10ca9b6f7f20f88dfcdfdf680daf1b04cb7f22c5 (diff) |
reorganize repo, move shit around
Diffstat (limited to 'src/ARMInterpreter_ALU.h')
-rw-r--r-- | src/ARMInterpreter_ALU.h | 135 |
1 files changed, 135 insertions, 0 deletions
diff --git a/src/ARMInterpreter_ALU.h b/src/ARMInterpreter_ALU.h new file mode 100644 index 0000000..4cc3760 --- /dev/null +++ b/src/ARMInterpreter_ALU.h @@ -0,0 +1,135 @@ +/* + Copyright 2016-2017 StapleButter + + This file is part of melonDS. + + melonDS is free software: you can redistribute it and/or modify it under + the terms of the GNU General Public License as published by the Free + Software Foundation, either version 3 of the License, or (at your option) + any later version. + + melonDS is distributed in the hope that it will be useful, but WITHOUT ANY + WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS + FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. + + You should have received a copy of the GNU General Public License along + with melonDS. If not, see http://www.gnu.org/licenses/. +*/ + +#ifndef ARMINTERPRETER_ALU_H +#define ARMINTERPRETER_ALU_H + +namespace ARMInterpreter +{ + +#define A_PROTO_ALU_OP(x) \ +\ +void A_##x##_IMM(ARM* cpu); \ +void A_##x##_REG_LSL_IMM(ARM* cpu); \ +void A_##x##_REG_LSR_IMM(ARM* cpu); \ +void A_##x##_REG_ASR_IMM(ARM* cpu); \ +void A_##x##_REG_ROR_IMM(ARM* cpu); \ +void A_##x##_REG_LSL_REG(ARM* cpu); \ +void A_##x##_REG_LSR_REG(ARM* cpu); \ +void A_##x##_REG_ASR_REG(ARM* cpu); \ +void A_##x##_REG_ROR_REG(ARM* cpu); \ +void A_##x##_IMM_S(ARM* cpu); \ +void A_##x##_REG_LSL_IMM_S(ARM* cpu); \ +void A_##x##_REG_LSR_IMM_S(ARM* cpu); \ +void A_##x##_REG_ASR_IMM_S(ARM* cpu); \ +void A_##x##_REG_ROR_IMM_S(ARM* cpu); \ +void A_##x##_REG_LSL_REG_S(ARM* cpu); \ +void A_##x##_REG_LSR_REG_S(ARM* cpu); \ +void A_##x##_REG_ASR_REG_S(ARM* cpu); \ +void A_##x##_REG_ROR_REG_S(ARM* cpu); + +#define A_PROTO_ALU_TEST(x) \ +\ +void A_##x##_IMM(ARM* cpu); \ +void A_##x##_REG_LSL_IMM(ARM* cpu); \ +void A_##x##_REG_LSR_IMM(ARM* cpu); \ +void A_##x##_REG_ASR_IMM(ARM* cpu); \ +void A_##x##_REG_ROR_IMM(ARM* cpu); \ +void A_##x##_REG_LSL_REG(ARM* cpu); \ +void A_##x##_REG_LSR_REG(ARM* cpu); \ +void A_##x##_REG_ASR_REG(ARM* cpu); \ +void A_##x##_REG_ROR_REG(ARM* cpu); + +A_PROTO_ALU_OP(AND) +A_PROTO_ALU_OP(EOR) +A_PROTO_ALU_OP(SUB) +A_PROTO_ALU_OP(RSB) +A_PROTO_ALU_OP(ADD) +A_PROTO_ALU_OP(ADC) +A_PROTO_ALU_OP(SBC) +A_PROTO_ALU_OP(RSC) +A_PROTO_ALU_TEST(TST) +A_PROTO_ALU_TEST(TEQ) +A_PROTO_ALU_TEST(CMP) +A_PROTO_ALU_TEST(CMN) +A_PROTO_ALU_OP(ORR) +A_PROTO_ALU_OP(MOV) +A_PROTO_ALU_OP(BIC) +A_PROTO_ALU_OP(MVN) + +void A_MUL(ARM* cpu); +void A_MLA(ARM* cpu); +void A_UMULL(ARM* cpu); +void A_UMLAL(ARM* cpu); +void A_SMULL(ARM* cpu); +void A_SMLAL(ARM* cpu); +void A_SMLAxy(ARM* cpu); +void A_SMLAWy(ARM* cpu); +void A_SMULxy(ARM* cpu); +void A_SMULWy(ARM* cpu); +void A_SMLALxy(ARM* cpu); + +void A_CLZ(ARM* cpu); +void A_QADD(ARM* cpu); +void A_QSUB(ARM* cpu); +void A_QDADD(ARM* cpu); +void A_QDSUB(ARM* cpu); + + +void T_LSL_IMM(ARM* cpu); +void T_LSR_IMM(ARM* cpu); +void T_ASR_IMM(ARM* cpu); + +void T_ADD_REG_(ARM* cpu); +void T_SUB_REG_(ARM* cpu); +void T_ADD_IMM_(ARM* cpu); +void T_SUB_IMM_(ARM* cpu); + +void T_MOV_IMM(ARM* cpu); +void T_CMP_IMM(ARM* cpu); +void T_ADD_IMM(ARM* cpu); +void T_SUB_IMM(ARM* cpu); + +void T_AND_REG(ARM* cpu); +void T_EOR_REG(ARM* cpu); +void T_LSL_REG(ARM* cpu); +void T_LSR_REG(ARM* cpu); +void T_ASR_REG(ARM* cpu); +void T_ADC_REG(ARM* cpu); +void T_SBC_REG(ARM* cpu); +void T_ROR_REG(ARM* cpu); +void T_TST_REG(ARM* cpu); +void T_NEG_REG(ARM* cpu); +void T_CMP_REG(ARM* cpu); +void T_CMN_REG(ARM* cpu); +void T_ORR_REG(ARM* cpu); +void T_MUL_REG(ARM* cpu); +void T_BIC_REG(ARM* cpu); +void T_MVN_REG(ARM* cpu); + +void T_ADD_HIREG(ARM* cpu); +void T_CMP_HIREG(ARM* cpu); +void T_MOV_HIREG(ARM* cpu); + +void T_ADD_PCREL(ARM* cpu); +void T_ADD_SPREL(ARM* cpu); +void T_ADD_SP(ARM* cpu); + +} + +#endif |