2017-07-02 21:57:27 +00:00
|
|
|
//============================================================================
|
|
|
|
//
|
|
|
|
// SSSS tt lll lll
|
|
|
|
// SS SS tt ll ll
|
|
|
|
// SS tttttt eeee ll ll aaaa
|
|
|
|
// SSSS tt ee ee ll ll aa
|
|
|
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
|
|
|
// SS SS tt ee ll ll aa aa
|
|
|
|
// SSSS ttt eeeee llll llll aaaaa
|
|
|
|
//
|
2019-12-31 17:18:56 +00:00
|
|
|
// Copyright (c) 1995-2020 by Bradford W. Mott, Stephen Anthony
|
2017-07-02 21:57:27 +00:00
|
|
|
// and the Stella Team
|
|
|
|
//
|
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef CARTRIDGE_DETECTOR_HXX
|
|
|
|
#define CARTRIDGE_DETECTOR_HXX
|
|
|
|
|
|
|
|
class Cartridge;
|
|
|
|
class Properties;
|
|
|
|
|
2018-08-31 11:48:35 +00:00
|
|
|
#include "Bankswitch.hxx"
|
2017-07-02 21:57:27 +00:00
|
|
|
#include "bspf.hxx"
|
2019-02-26 21:46:54 +00:00
|
|
|
#include "Settings.hxx"
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Auto-detect cart type based on various attributes (file size, signatures,
|
|
|
|
filenames, etc)
|
|
|
|
|
|
|
|
@author Stephen Anthony
|
|
|
|
*/
|
|
|
|
class CartDetector
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Create a new cartridge object allocated on the heap. The
|
|
|
|
type of cartridge created depends on the properties object.
|
|
|
|
|
|
|
|
@param image A pointer to the ROM image
|
|
|
|
@param size The size of the ROM image
|
|
|
|
@param md5 The md5sum for the given ROM image (can be updated)
|
|
|
|
@param dtype The detected bankswitch type of the ROM image
|
2019-02-26 21:46:54 +00:00
|
|
|
@param settings The settings container
|
2017-07-02 21:57:27 +00:00
|
|
|
@return Pointer to the new cartridge object allocated on the heap
|
|
|
|
*/
|
2018-08-31 11:48:35 +00:00
|
|
|
static unique_ptr<Cartridge> create(const FilesystemNode& file,
|
2019-09-16 23:59:08 +00:00
|
|
|
const ByteBuffer& image, size_t size, string& md5,
|
2019-02-26 21:46:54 +00:00
|
|
|
const string& dtype, Settings& settings);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
2019-08-12 07:22:36 +00:00
|
|
|
/**
|
|
|
|
Try to auto-detect the bankswitching type of the cartridge
|
|
|
|
|
|
|
|
@param image A pointer to the ROM image
|
|
|
|
@param size The size of the ROM image
|
|
|
|
|
|
|
|
@return The "best guess" for the cartridge type
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static Bankswitch::Type autodetectType(const ByteBuffer& image, size_t size);
|
2019-08-12 07:22:36 +00:00
|
|
|
|
2017-07-02 21:57:27 +00:00
|
|
|
private:
|
|
|
|
/**
|
|
|
|
Create a cartridge from a multi-cart image pointer; internally this
|
|
|
|
takes a slice of the ROM image ues that for the cartridge.
|
|
|
|
|
|
|
|
@param image A pointer to the complete ROM image
|
|
|
|
@param size The size of the ROM image slice
|
|
|
|
@param numroms The number of ROMs in the multicart
|
|
|
|
@param md5 The md5sum for the slice of the ROM image
|
|
|
|
@param type The detected type of the slice of the ROM image
|
|
|
|
@param id The ID for the slice of the ROM image
|
2019-02-26 21:46:54 +00:00
|
|
|
@param settings The settings container
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
@return Pointer to the new cartridge object allocated on the heap
|
|
|
|
*/
|
|
|
|
static unique_ptr<Cartridge>
|
2019-09-16 23:59:08 +00:00
|
|
|
createFromMultiCart(const ByteBuffer& image, size_t& size,
|
2018-08-31 11:48:35 +00:00
|
|
|
uInt32 numroms, string& md5, Bankswitch::Type type, string& id,
|
2019-02-26 21:46:54 +00:00
|
|
|
Settings& settings);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Create a cartridge from the entire image pointer.
|
|
|
|
|
|
|
|
@param image A pointer to the complete ROM image
|
|
|
|
@param size The size of the ROM image
|
|
|
|
@param type The bankswitch type of the ROM image
|
|
|
|
@param md5 The md5sum for the ROM image
|
2019-02-26 21:46:54 +00:00
|
|
|
@param settings The settings container
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
@return Pointer to the new cartridge object allocated on the heap
|
|
|
|
*/
|
|
|
|
static unique_ptr<Cartridge>
|
2019-09-16 23:59:08 +00:00
|
|
|
createFromImage(const ByteBuffer& image, size_t size, Bankswitch::Type type,
|
2019-02-26 21:46:54 +00:00
|
|
|
const string& md5, Settings& settings);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Search the image for the specified byte signature
|
|
|
|
|
|
|
|
@param image A pointer to the ROM image
|
|
|
|
@param imagesize The size of the ROM image
|
|
|
|
@param signature The byte sequence to search for
|
|
|
|
@param sigsize The number of bytes in the signature
|
|
|
|
@param minhits The minimum number of times a signature is to be found
|
|
|
|
|
|
|
|
@return True if the signature was found at least 'minhits' time, else false
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool searchForBytes(const uInt8* image, size_t imagesize,
|
2017-07-02 21:57:27 +00:00
|
|
|
const uInt8* signature, uInt32 sigsize,
|
|
|
|
uInt32 minhits);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a SuperChip (128 bytes RAM)
|
|
|
|
Note: should be called only on ROMs with size multiple of 4K
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablySC(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image probably contains ARM code in the first 1K
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyARM(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a 0840 bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbably0840(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a 3E bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbably3E(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a 3E+ bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbably3EPlus(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a 3F bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbably3F(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a 4A50 bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbably4A50(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
2018-11-20 19:09:30 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably a 4K SuperChip (128 bytes RAM)
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbably4KSC(const ByteBuffer& image, size_t size);
|
2018-11-20 19:09:30 +00:00
|
|
|
|
2017-07-02 21:57:27 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably a BF/BFSC bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyBF(const ByteBuffer& image, size_t size, Bankswitch::Type& type);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a BUS bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyBUS(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a CDF bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyCDF(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a CTY bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyCTY(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a CV bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyCV(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a CV+ bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyCVPlus(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a DASH bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyDASH(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a DF/DFSC bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyDF(const ByteBuffer& image, size_t size, Bankswitch::Type& type);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a DPC+ bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyDPCplus(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a E0 bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyE0(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a E7 bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyE7(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
2017-11-27 21:49:53 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably a E78K bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyE78K(const ByteBuffer& image, size_t size);
|
2017-11-27 21:49:53 +00:00
|
|
|
|
2017-07-02 21:57:27 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably an EF/EFSC bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyEF(const ByteBuffer& image, size_t size, Bankswitch::Type& type);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably an F6 bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
//static bool isProbablyF6(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably an FA2 bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyFA2(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
2019-11-02 11:23:03 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably an FC bankswitching cartridge
|
|
|
|
*/
|
|
|
|
static bool isProbablyFC(const ByteBuffer& image, size_t size);
|
|
|
|
|
2017-07-02 21:57:27 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably an FE bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyFE(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a MDM bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyMDM(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a SB bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablySB(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns true if the image is probably a UA bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyUA(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
2019-10-16 20:05:33 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably a Wickstead Design bankswitching cartridge
|
|
|
|
*/
|
|
|
|
static bool isProbablyWD(const ByteBuffer& image, size_t size);
|
|
|
|
|
2017-07-02 21:57:27 +00:00
|
|
|
/**
|
|
|
|
Returns true if the image is probably an X07 bankswitching cartridge
|
|
|
|
*/
|
2019-09-16 23:59:08 +00:00
|
|
|
static bool isProbablyX07(const ByteBuffer& image, size_t size);
|
2017-07-02 21:57:27 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
// Following constructors and assignment operators not supported
|
|
|
|
CartDetector() = delete;
|
|
|
|
CartDetector(const CartDetector&) = delete;
|
|
|
|
CartDetector(CartDetector&&) = delete;
|
|
|
|
CartDetector& operator=(const CartDetector&) = delete;
|
|
|
|
CartDetector& operator=(CartDetector&&) = delete;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|