mirror of
https://github.com/akuker/RASCSI.git
synced 2024-12-21 23:29:39 +00:00
a6a8cadf21
* Revert "Don't ResizeCache on sector change if no filename is defined (#1438)" This reverts commitdd9a3296d4
. * Revert "Add ModeSense page 0x25 (DEC special function control page) (#1412)" This reverts commit1121b8d9d6
. * Revert "DiskCache needs a size" This reverts commit7cc8df271c
. * Revert "Honor sector size change via ModeSelect6 in scsicd (#1406)" This reverts commitb7f65d33e2
. * Revert "Multiple fixes for ModeSelect (#1405)" This reverts commitad5eae93e7
.
79 lines
2.2 KiB
C++
79 lines
2.2 KiB
C++
//---------------------------------------------------------------------------
|
||
//
|
||
// X68000 EMULATOR "XM6"
|
||
//
|
||
// Copyright (C) 2001-2006 PI.(ytanaka@ipc-tokai.or.jp)
|
||
// Copyright (C) 2014-2020 GIMONS
|
||
//
|
||
// XM6i
|
||
// Copyright (C) 2010-2015 isaki@NetBSD.org
|
||
//
|
||
// Imported sava's Anex86/T98Next image and MO format support patch.
|
||
// Comments translated to english by akuker.
|
||
//
|
||
//---------------------------------------------------------------------------
|
||
|
||
#pragma once
|
||
|
||
#include "generated/piscsi_interface.pb.h"
|
||
#include <span>
|
||
#include <array>
|
||
#include <memory>
|
||
#include <string>
|
||
|
||
using namespace std;
|
||
using namespace piscsi_interface;
|
||
|
||
class DiskCache
|
||
{
|
||
// Number of tracks to cache
|
||
static const int CACHE_MAX = 16;
|
||
|
||
uint64_t read_error_count = 0;
|
||
uint64_t write_error_count = 0;
|
||
uint64_t cache_miss_read_count = 0;
|
||
uint64_t cache_miss_write_count = 0;
|
||
|
||
inline static const string READ_ERROR_COUNT = "read_error_count";
|
||
inline static const string WRITE_ERROR_COUNT = "write_error_count";
|
||
inline static const string CACHE_MISS_READ_COUNT = "cache_miss_read_count";
|
||
inline static const string CACHE_MISS_WRITE_COUNT = "cache_miss_write_count";
|
||
|
||
public:
|
||
|
||
// Internal data definition
|
||
using cache_t = struct {
|
||
shared_ptr<DiskTrack> disktrk; // Disk Track
|
||
uint32_t serial; // Serial
|
||
};
|
||
|
||
DiskCache(const string&, int, uint32_t, off_t = 0);
|
||
~DiskCache() = default;
|
||
|
||
void SetRawMode(bool b) { cd_raw = b; } // CD-ROM raw mode setting
|
||
|
||
bool Save(); // Save and release all
|
||
bool ReadSector(span<uint8_t>, uint32_t); // Sector Read
|
||
bool WriteSector(span<const uint8_t>, uint32_t); // Sector Write
|
||
|
||
vector<PbStatistics> GetStatistics(bool) const;
|
||
|
||
private:
|
||
|
||
// Internal Management
|
||
shared_ptr<DiskTrack> Assign(int);
|
||
shared_ptr<DiskTrack> GetTrack(uint32_t);
|
||
bool Load(int index, int track, shared_ptr<DiskTrack>);
|
||
void UpdateSerialNumber();
|
||
|
||
// Internal data
|
||
array<cache_t, CACHE_MAX> cache = {}; // Cache management
|
||
uint32_t serial = 0; // Last serial number
|
||
string sec_path; // Path
|
||
int sec_size; // Sector Size (8=256, 9=512, 10=1024, 11=2048, 12=4096)
|
||
int sec_blocks; // Blocks per sector
|
||
bool cd_raw = false; // CD-ROM RAW mode
|
||
off_t imgoffset; // Offset to actual data
|
||
};
|
||
|