2017-05-16 21:28:17 -04:00
|
|
|
//
|
|
|
|
// AllRAMProcessor.hpp
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 16/05/2017.
|
|
|
|
// Copyright © 2017 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef AllRAMProcessor_hpp
|
|
|
|
#define AllRAMProcessor_hpp
|
|
|
|
|
|
|
|
#include <cstdint>
|
2017-05-19 21:20:28 -04:00
|
|
|
#include <set>
|
2017-05-16 21:28:17 -04:00
|
|
|
#include <vector>
|
|
|
|
|
2017-07-27 20:17:13 -04:00
|
|
|
#include "../ClockReceiver/ClockReceiver.hpp"
|
|
|
|
|
2017-05-16 21:28:17 -04:00
|
|
|
namespace CPU {
|
|
|
|
|
|
|
|
class AllRAMProcessor {
|
|
|
|
public:
|
|
|
|
AllRAMProcessor(size_t memory_size);
|
2017-07-27 20:17:13 -04:00
|
|
|
HalfCycles get_timestamp();
|
2017-05-16 21:28:17 -04:00
|
|
|
void set_data_at_address(uint16_t startAddress, size_t length, const uint8_t *data);
|
2017-05-19 21:53:39 -04:00
|
|
|
void get_data_at_address(uint16_t startAddress, size_t length, uint8_t *data);
|
2017-05-16 21:28:17 -04:00
|
|
|
|
2017-05-19 21:20:28 -04:00
|
|
|
class TrapHandler {
|
|
|
|
public:
|
|
|
|
virtual void processor_did_trap(AllRAMProcessor &, uint16_t address) = 0;
|
|
|
|
};
|
|
|
|
void set_trap_handler(TrapHandler *trap_handler);
|
|
|
|
void add_trap_address(uint16_t address);
|
|
|
|
|
2017-05-16 21:28:17 -04:00
|
|
|
protected:
|
|
|
|
std::vector<uint8_t> memory_;
|
2017-07-27 20:17:13 -04:00
|
|
|
HalfCycles timestamp_;
|
2017-05-19 21:20:28 -04:00
|
|
|
|
2017-06-01 18:28:34 -04:00
|
|
|
inline void check_address_for_trap(uint16_t address) {
|
2017-06-03 21:54:42 -04:00
|
|
|
if(traps_[address]) {
|
2017-06-01 18:28:34 -04:00
|
|
|
trap_handler_->processor_did_trap(*this, address);
|
|
|
|
}
|
|
|
|
}
|
2017-05-19 21:20:28 -04:00
|
|
|
|
|
|
|
private:
|
|
|
|
TrapHandler *trap_handler_;
|
2017-06-03 21:54:42 -04:00
|
|
|
std::vector<bool> traps_;
|
2017-05-16 21:28:17 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* AllRAMProcessor_hpp */
|