2016-08-27 18:17:40 -04:00
|
|
|
//
|
2016-08-27 18:26:51 -04:00
|
|
|
// Cartridge.hpp
|
2016-08-27 18:17:40 -04:00
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 27/08/2016.
|
|
|
|
// Copyright © 2016 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
2016-08-27 18:26:51 -04:00
|
|
|
#ifndef Storage_Cartridge_hpp
|
|
|
|
#define Storage_Cartridge_hpp
|
2016-08-27 18:17:40 -04:00
|
|
|
|
2016-08-28 12:20:40 -04:00
|
|
|
#include <list>
|
|
|
|
#include <vector>
|
|
|
|
#include <memory>
|
|
|
|
|
2016-08-27 18:17:40 -04:00
|
|
|
namespace Storage {
|
2016-08-27 18:26:51 -04:00
|
|
|
namespace Cartridge {
|
2016-08-27 18:17:40 -04:00
|
|
|
|
2016-08-28 12:20:40 -04:00
|
|
|
/*!
|
|
|
|
Provides a base class for cartridges; the bus provided to cartridges and therefore
|
|
|
|
the interface they support is extremely machine-dependent so unlike disks and tapes,
|
|
|
|
no model is imposed; this class seeks merely to be a base class for fully-descriptive
|
|
|
|
summaries of the contents of emulator files that themselves describe cartridges.
|
|
|
|
|
|
|
|
Consumers will almost certainly seek to dynamic_cast to something more appropriate,
|
|
|
|
however some cartridge container formats have no exposition beyond the ROM dump,
|
|
|
|
making the base class 100% descriptive.
|
|
|
|
*/
|
|
|
|
class Cartridge {
|
|
|
|
public:
|
|
|
|
struct Segment {
|
|
|
|
Segment(int start_address, int end_address, std::vector<uint8_t> data) :
|
|
|
|
start_address(start_address), end_address(end_address), data(std::move(data)) {}
|
|
|
|
|
|
|
|
/// Indicates that an address is unknown.
|
|
|
|
static const int UnknownAddress;
|
|
|
|
|
|
|
|
/// The initial CPU-exposed starting address for this segment; may be @c UnknownAddress.
|
|
|
|
int start_address;
|
|
|
|
/*!
|
|
|
|
The initial CPU-exposed ending address for this segment; may be @c UnknownAddress. Not necessarily equal
|
|
|
|
to start_address + data_length due to potential paging.
|
|
|
|
*/
|
|
|
|
int end_address;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
The data contents for this segment. If @c start_address and @c end_address are suppled then
|
|
|
|
the first end_address - start_address bytes will be those initially visible. The size will
|
|
|
|
not necessarily be the same as @c end_address - @c start_address due to potential paging.
|
|
|
|
*/
|
|
|
|
std::vector<uint8_t> data;
|
|
|
|
};
|
|
|
|
|
2016-12-03 11:59:28 -05:00
|
|
|
const std::list<Segment> &get_segments() { return segments_; }
|
2017-08-27 15:19:30 -04:00
|
|
|
virtual ~Cartridge() {}
|
2016-08-28 12:20:40 -04:00
|
|
|
|
|
|
|
protected:
|
2016-12-03 11:59:28 -05:00
|
|
|
std::list<Segment> segments_;
|
2016-08-28 12:20:40 -04:00
|
|
|
};
|
2016-08-27 18:17:40 -04:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* ROM_hpp */
|