Path: blob/a-new-beginning/Cherry/Core/include/opcode_timing.h
2 views
/*1* Gearcoleco - ColecoVision Emulator2* Copyright (C) 2021 Ignacio Sanchez34* This program is free software: you can redistribute it and/or modify5* it under the terms of the GNU General Public License as published by6* the Free Software Foundation, either version 3 of the License, or7* any later version.89* This program is distributed in the hope that it will be useful,10* but WITHOUT ANY WARRANTY; without even the implied warranty of11* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the12* GNU General Public License for more details.1314* You should have received a copy of the GNU General Public License15* along with this program. If not, see http://www.gnu.org/licenses/16*17*/1819#ifndef OPCODE_TIMING_H20#define OPCODE_TIMING_H2122const u8 kOPCodeTStates[256] =23{24/* 0 1 2 3 4 5 6 7 8 9 A B C D E F */25/* 0x00 */ 4,10, 7, 6, 4, 4, 7, 4, 4,11, 7, 6, 4, 4, 7, 4,26/* 0x10 */ 8,10, 7, 6, 4, 4, 7, 4,12,11, 7, 6, 4, 4, 7, 4,27/* 0x20 */ 7,10,16, 6, 4, 4, 7, 4, 7,11,16, 6, 4, 4, 7, 4,28/* 0x30 */ 7,10,13, 6,11,11,10, 4, 7,11,13, 6, 4, 4, 7, 4,29/* 0x40 */ 4, 4, 4, 4, 4, 4, 7, 4, 4, 4, 4, 4, 4, 4, 7, 4,30/* 0x50 */ 4, 4, 4, 4, 4, 4, 7, 4, 4, 4, 4, 4, 4, 4, 7, 4,31/* 0x60 */ 4, 4, 4, 4, 4, 4, 7, 4, 4, 4, 4, 4, 4, 4, 7, 4,32/* 0x70 */ 7, 7, 7, 7, 7, 7, 4, 7, 4, 4, 4, 4, 4, 4, 7, 4,33/* 0x80 */ 4, 4, 4, 4, 4, 4, 7, 4, 4, 4, 4, 4, 4, 4, 7, 4,34/* 0x90 */ 4, 4, 4, 4, 4, 4, 7, 4, 4, 4, 4, 4, 4, 4, 7, 4,35/* 0xA0 */ 4, 4, 4, 4, 4, 4, 7, 4, 4, 4, 4, 4, 4, 4, 7, 4,36/* 0xB0 */ 4, 4, 4, 4, 4, 4, 7, 4, 4, 4, 4, 4, 4, 4, 7, 4,37/* 0xC0 */ 5,10,10,10,10,11, 7,11, 5,10,10, 0,10,17, 7,11,38/* 0xD0 */ 5,10,10,11,10,11, 7,11, 5, 4,10,11,10, 0, 7,11,39/* 0xE0 */ 5,10,10,19,10,11, 7,11, 5, 4,10, 4,10, 0, 7,11,40/* 0xF0 */ 5,10,10, 4,10,11, 7,11, 5, 6,10, 4,10, 0, 7,1141};4243const u8 kOPCodeTStatesBranched[256] =44{45/* 0 1 2 3 4 5 6 7 8 9 A B C D E F */46/* 0x00 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,47/* 0x10 */ 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,48/* 0x20 */ 5, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0,49/* 0x30 */ 5, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 0, 0, 0, 0,50/* 0x40 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,51/* 0x50 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,52/* 0x60 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,53/* 0x70 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,54/* 0x80 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,55/* 0x90 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,56/* 0xA0 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,57/* 0xB0 */ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,58/* 0xC0 */ 6, 0, 0, 0, 7, 0, 0, 0, 6, 0, 0, 0, 7, 0, 0, 0,59/* 0xD0 */ 6, 0, 0, 0, 7, 0, 0, 0, 6, 0, 0, 0, 7, 0, 0, 0,60/* 0xE0 */ 6, 0, 0, 0, 7, 0, 0, 0, 6, 0, 0, 0, 7, 0, 0, 0,61/* 0xF0 */ 6, 0, 0, 0, 7, 0, 0, 0, 6, 0, 0, 0, 7, 0, 0, 062};6364const u8 kOPCodeCBTStates[256] =65{66/* 0 1 2 3 4 5 6 7 8 9 A B C D E F */67/* 0x00 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,68/* 0x10 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,69/* 0x20 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,70/* 0x30 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,71/* 0x40 */ 8, 8, 8, 8, 8, 8,12, 8, 8, 8, 8, 8, 8, 8,12, 8,72/* 0x50 */ 8, 8, 8, 8, 8, 8,12, 8, 8, 8, 8, 8, 8, 8,12, 8,73/* 0x60 */ 8, 8, 8, 8, 8, 8,12, 8, 8, 8, 8, 8, 8, 8,12, 8,74/* 0x70 */ 8, 8, 8, 8, 8, 8,12, 8, 8, 8, 8, 8, 8, 8,12, 8,75/* 0x80 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,76/* 0x90 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,77/* 0xA0 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,78/* 0xB0 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,79/* 0xC0 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,80/* 0xD0 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,81/* 0xE0 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 8,82/* 0xF0 */ 8, 8, 8, 8, 8, 8,15, 8, 8, 8, 8, 8, 8, 8,15, 883};8485const u8 kOPCodeEDTStates[256] =86{87/* 0 1 2 3 4 5 6 7 8 9 A B C D E F */88/* 0x00 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,89/* 0x10 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,90/* 0x20 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,91/* 0x30 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,92/* 0x40 */ 12,12,15,20, 8,14, 8, 9,12,12,15,20, 8,14, 8, 9,93/* 0x50 */ 12,12,15,20, 8,14, 8, 9,12,12,15,20, 8,14, 8, 9,94/* 0x60 */ 12,12,15,20, 8,14, 8,18,12,12,15,20, 8,14, 8,18,95/* 0x70 */ 12,12,15,20, 8,14, 8, 8,12,12,15,20, 8,14, 8, 8,96/* 0x80 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,97/* 0x90 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,98/* 0xA0 */ 16,16,16,16, 8, 8, 8, 8,16,16,16,16, 8, 8, 8, 8,99/* 0xB0 */ 16,16,16,16, 8, 8, 8, 8,16,16,16,16, 8, 8, 8, 8,100/* 0xC0 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,101/* 0xD0 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,102/* 0xE0 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8,103/* 0xF0 */ 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8104};105106const u8 kOPCodeXYTStates[256] =107{108/* 0 1 2 3 4 5 6 7 8 9 A B C D E F */109/* 0x00 */ 4+4,10+4, 7+4, 6+4, 4+4, 4+4, 7+4, 4+4, 4+4,11+4, 7+4, 6+4, 4+4, 4+4, 7+4, 4+4,110/* 0x10 */ 8+4,10+4, 7+4, 6+4, 4+4, 4+4, 7+4, 4+4,12+4,11+4, 7+4, 6+4, 4+4, 4+4, 7+4, 4+4,111/* 0x20 */ 7+4,10+4,16+4, 6+4, 4+4, 4+4, 7+4, 4+4, 7+4,11+4,16+4, 6+4, 4+4, 4+4, 7+4, 4+4,112/* 0x30 */ 7+4,10+4,13+4, 6+4, 23 , 23 , 19 , 4+4, 7+4,11+4,13+4, 6+4, 4+4, 4+4, 7+4, 4+4,113/* 0x40 */ 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,114/* 0x50 */ 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,115/* 0x60 */ 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,116/* 0x70 */ 19 , 19 , 19 , 19 , 19 , 19 , 4+4, 19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,117/* 0x80 */ 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,118/* 0x90 */ 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,119/* 0xA0 */ 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,120/* 0xB0 */ 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4, 4+4, 4+4, 4+4, 4+4, 4+4, 4+4,19 , 4+4,121/* 0xC0 */ 5+4,10+4,10+4,10+4,10+4,11+4, 7+4,11+4, 5+4,10+4,10+4, 0 ,10+4,17+4, 7+4,11+4,122/* 0xD0 */ 5+4,10+4,10+4,11+4,10+4,11+4, 7+4,11+4, 5+4, 4+4,10+4,11+4,10+4, 4 , 7+4,11+4,123/* 0xE0 */ 5+4,10+4,10+4,19+4,10+4,11+4, 7+4,11+4, 5+4, 4+4,10+4, 4+4,10+4, 4 , 7+4,11+4,124/* 0xF0 */ 5+4,10+4,10+4, 4+4,10+4,11+4, 7+4,11+4, 5+4, 6+4,10+4, 4+4,10+4, 4 , 7+4,11+4125};126127const u8 kOPCodeXYCBTStates[256] =128{129/* 0 1 2 3 4 5 6 7 8 9 A B C D E F */130/* 0x00 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,131/* 0x10 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,132/* 0x20 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,133/* 0x30 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,134/* 0x40 */ 20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,135/* 0x50 */ 20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,136/* 0x60 */ 20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,137/* 0x70 */ 20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,138/* 0x80 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,139/* 0x90 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,140/* 0xA0 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,141/* 0xB0 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,142/* 0xC0 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,143/* 0xD0 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,144/* 0xE0 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,145/* 0xF0 */ 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23146};147148#endif /* OPCODE_TIMING_H */149150151152