KEK/tm-11.h

41 lines
1 KiB
C++

// (C) 2018-2023 by Folkert van Heusden
// Released under MIT license
#pragma once
#include <stdint.h>
#include <stdio.h>
#include <string>
#define TM_11_MTS 0172520 // status register
#define TM_11_MTC 0172522 // command register
#define TM_11_MTBRC 0172524 // byte record counter
#define TM_11_MTCMA 0172526 // current memory address register
#define TM_11_MTD 0172530 // data buffer register
#define TM_11_MTRD 0172532 // TU10 read lines
#define TM_11_BASE TM_11_MTS
#define TM_11_END (TM_11_MTRD + 2)
class memory;
class tm_11
{
private:
memory *const m { nullptr };
uint16_t registers[6] { 0 };
uint8_t xfer_buffer[65536];
int offset { 0 };
FILE *fh { nullptr };
public:
tm_11(const std::string & file, memory *const m);
virtual ~tm_11();
void reset();
uint8_t readByte(const uint16_t addr);
uint16_t readWord(const uint16_t addr);
void writeByte(const uint16_t addr, const uint8_t v);
void writeWord(const uint16_t addr, uint16_t v);
};