2019-07-06 09:29:35 -04:00
|
|
|
#pragma once
|
|
|
|
#include "stdafx.h"
|
2019-10-10 23:54:38 -04:00
|
|
|
#include "InternalRegisterTypes.h"
|
2019-07-06 09:29:35 -04:00
|
|
|
#include "../Utilities/ISerializable.h"
|
|
|
|
|
|
|
|
class Cpu;
|
|
|
|
|
|
|
|
class AluMulDiv final : public ISerializable
|
|
|
|
{
|
|
|
|
private:
|
2021-03-10 11:13:28 -05:00
|
|
|
Cpu *_cpu;
|
2019-07-06 09:29:35 -04:00
|
|
|
|
|
|
|
uint64_t _prevCpuCycle = 0;
|
|
|
|
|
2019-10-10 23:54:38 -04:00
|
|
|
AluState _state;
|
2019-07-06 09:29:35 -04:00
|
|
|
|
|
|
|
uint32_t _shift = 0;
|
|
|
|
uint8_t _multCounter = 0;
|
|
|
|
uint8_t _divCounter = 0;
|
2021-03-10 11:13:28 -05:00
|
|
|
|
2019-07-06 09:29:35 -04:00
|
|
|
public:
|
2019-08-09 11:45:20 -04:00
|
|
|
void Initialize(Cpu* cpu);
|
2021-03-10 11:13:28 -05:00
|
|
|
|
2019-07-06 09:29:35 -04: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();
|
|
|
|
|
2021-03-10 11:13:28 -05:00
|
|
|
void Serialize(Serializer &s) override;
|
|
|
|
};
|