#include "stdafx.h" #include "../inc/Profiler.h" #include "../inc/Disassembler.h" #include "../inc/Z80.h" EightBit::Profiler::Profiler(Z80& cpu, Disassembler& disassembler) : m_cpu(cpu), m_disassembler(disassembler) { std::fill(m_instructions.begin(), m_instructions.end(), 0); std::fill(m_addresses.begin(), m_addresses.end(), 0); } EightBit::Profiler::~Profiler() { } void EightBit::Profiler::addInstruction(uint8_t instruction) { m_instructions[instruction]++; } void EightBit::Profiler::addAddress(uint16_t address) { m_addresses[address]++; } void EightBit::Profiler::dump() const { dumpInstructionProfiles(); dumpAddressProfiles(); } void EightBit::Profiler::dumpInstructionProfiles() const { if (instructions_available()) { std::cout << "** instructions" << std::endl; for (int i = 0; i < 0x100; ++i) { auto count = m_instructions[i]; if (count > 0) std::cout << Disassembler::hex((uint8_t)i) << "\t" << count << std::endl; } } } void EightBit::Profiler::dumpAddressProfiles() const { if (addresses_available()) { std::cout << "** addresses" << std::endl; for (int i = 0; i < 0x10000; ++i) { auto count = m_addresses[i]; m_cpu.PC().word = i; if (count > 0) std::cout << Disassembler::hex((uint16_t)i) << "\t" << count << "\t" << m_disassembler.disassemble(m_cpu) << std::endl; } } }