Mesen-SX/Core/AluMulDiv.h

33 lines
518 B
C
Raw Normal View History

#pragma once
#include "stdafx.h"
2019-10-10 23:54:38 -04:00
#include "InternalRegisterTypes.h"
#include "../Utilities/ISerializable.h"
class Cpu;
class AluMulDiv final : public ISerializable
{
private:
2020-12-19 23:30:09 +03:00
Cpu* _cpu;
uint64_t _prevCpuCycle = 0;
2019-10-10 23:54:38 -04:00
AluState _state;
uint32_t _shift = 0;
uint8_t _multCounter = 0;
uint8_t _divCounter = 0;
2020-12-19 23:30:09 +03:00
public:
2019-08-09 11:45:20 -04:00
void Initialize(Cpu* cpu);
2020-12-19 23:30:09 +03:00
void Run(bool isRead);
uint8_t Read(uint16_t addr);
void Write(uint16_t addr, uint8_t value);
2019-10-10 23:54:38 -04:00
AluState GetState();
2020-12-19 23:30:09 +03:00
void Serialize(Serializer& s) override;
};