1
0
mirror of https://github.com/TomHarte/CLK.git synced 2024-11-22 12:33:29 +00:00
CLK/Machines/Apple/AppleII/SCSICard.hpp

56 lines
1.3 KiB
C++
Raw Normal View History

2022-08-22 14:22:19 +00:00
//
// SCSICard.hpp
// Clock Signal
//
// Created by Thomas Harte on 22/08/2022.
// Copyright © 2022 Thomas Harte. All rights reserved.
//
#ifndef SCSICard_hpp
#define SCSICard_hpp
#include "Card.hpp"
#include "../../ROMMachine.hpp"
2022-08-22 20:48:51 +00:00
#include "../../../Components/5380/ncr5380.hpp"
2022-08-24 19:23:50 +00:00
#include "../../../Storage/MassStorage/SCSI/SCSI.hpp"
#include "../../../Storage/MassStorage/SCSI/DirectAccessDevice.hpp"
#include "../../../Storage/MassStorage/MassStorageDevice.hpp"
2022-08-22 20:48:51 +00:00
#include <array>
#include <memory>
2022-08-22 20:48:51 +00:00
2022-08-22 14:22:19 +00:00
namespace Apple {
namespace II {
class SCSICard: public Card {
public:
static ROM::Request rom_request();
SCSICard(ROM::Map &, int clock_rate);
2022-08-22 14:22:19 +00:00
void perform_bus_operation(Select select, bool is_read, uint16_t address, uint8_t *value) final;
2022-08-24 19:23:50 +00:00
void set_storage_device(const std::shared_ptr<Storage::MassStorage::MassStorageDevice> &device);
void run_for([[maybe_unused]] Cycles cycles, [[maybe_unused]] int stretches) final {
scsi_bus_.run_for(cycles);
}
2022-08-22 14:22:19 +00:00
private:
2022-08-22 20:48:51 +00:00
uint8_t *ram_pointer_ = nullptr;
uint8_t *rom_pointer_ = nullptr;
std::array<uint8_t, 8*1024> ram_;
std::array<uint8_t, 16*1024> rom_;
SCSI::Bus scsi_bus_;
NCR::NCR5380::NCR5380 ncr5380_;
2022-08-24 19:23:50 +00:00
SCSI::Target::Target<SCSI::DirectAccessDevice> storage_;
2022-08-22 14:22:19 +00:00
};
}
}
#endif /* SCSICard_hpp */