Move sector sizes lists from DeviceFactory to the respective devices (#1323)

This commit is contained in:
Uwe Seimet 2023-11-14 15:32:46 +01:00 committed by Daniel Markstedt
parent 41fb8db6dd
commit a516544d98
24 changed files with 160 additions and 191 deletions

View File

@ -7,7 +7,7 @@
// //
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
#include "shared/network_util.h" #include "shared/piscsi_util.h"
#include "scsihd.h" #include "scsihd.h"
#include "scsihd_nec.h" #include "scsihd_nec.h"
#include "scsimo.h" #include "scsimo.h"
@ -20,39 +20,14 @@
using namespace std; using namespace std;
using namespace piscsi_util; using namespace piscsi_util;
using namespace network_util;
DeviceFactory::DeviceFactory()
{
sector_sizes[SCHD] = { 512, 1024, 2048, 4096 };
sector_sizes[SCRM] = { 512, 1024, 2048, 4096 };
sector_sizes[SCMO] = { 512, 1024, 2048, 4096 };
sector_sizes[SCCD] = { 512, 2048};
extension_mapping["hd1"] = SCHD;
extension_mapping["hds"] = SCHD;
extension_mapping["hda"] = SCHD;
extension_mapping["hdn"] = SCHD;
extension_mapping["hdi"] = SCHD;
extension_mapping["nhd"] = SCHD;
extension_mapping["hdr"] = SCRM;
extension_mapping["mos"] = SCMO;
extension_mapping["iso"] = SCCD;
extension_mapping["is1"] = SCCD;
device_mapping["bridge"] = SCBR;
device_mapping["daynaport"] = SCDP;
device_mapping["printer"] = SCLP;
device_mapping["services"] = SCHS;
}
PbDeviceType DeviceFactory::GetTypeForFile(const string& filename) const PbDeviceType DeviceFactory::GetTypeForFile(const string& filename) const
{ {
if (const auto& it = extension_mapping.find(GetExtensionLowerCase(filename)); it != extension_mapping.end()) { if (const auto& it = EXTENSION_MAPPING.find(GetExtensionLowerCase(filename)); it != EXTENSION_MAPPING.end()) {
return it->second; return it->second;
} }
if (const auto& it = device_mapping.find(filename); it != device_mapping.end()) { if (const auto& it = DEVICE_MAPPING.find(filename); it != DEVICE_MAPPING.end()) {
return it->second; return it->second;
} }
@ -75,8 +50,7 @@ shared_ptr<PrimaryDevice> DeviceFactory::CreateDevice(PbDeviceType type, int lun
if (const string ext = GetExtensionLowerCase(filename); ext == "hdn" || ext == "hdi" || ext == "nhd") { if (const string ext = GetExtensionLowerCase(filename); ext == "hdn" || ext == "hdi" || ext == "nhd") {
device = make_shared<SCSIHD_NEC>(lun); device = make_shared<SCSIHD_NEC>(lun);
} else { } else {
device = make_shared<SCSIHD>(lun, sector_sizes.find(type)->second, false, device = make_shared<SCSIHD>(lun, false, ext == "hd1" ? scsi_level::scsi_1_ccs : scsi_level::scsi_2);
ext == "hd1" ? scsi_level::scsi_1_ccs : scsi_level::scsi_2);
// Some Apple tools require a particular drive identification // Some Apple tools require a particular drive identification
if (ext == "hda") { if (ext == "hda") {
@ -88,17 +62,17 @@ shared_ptr<PrimaryDevice> DeviceFactory::CreateDevice(PbDeviceType type, int lun
} }
case SCRM: case SCRM:
device = make_shared<SCSIHD>(lun, sector_sizes.find(type)->second, true); device = make_shared<SCSIHD>(lun, true, scsi_level::scsi_2);
device->SetProduct("SCSI HD (REM.)"); device->SetProduct("SCSI HD (REM.)");
break; break;
case SCMO: case SCMO:
device = make_shared<SCSIMO>(lun, sector_sizes.find(type)->second); device = make_shared<SCSIMO>(lun);
device->SetProduct("SCSI MO"); device->SetProduct("SCSI MO");
break; break;
case SCCD: case SCCD:
device = make_shared<SCSICD>(lun, sector_sizes.find(type)->second, device = make_shared<SCSICD>(lun,
GetExtensionLowerCase(filename) == "is1" ? scsi_level::scsi_1_ccs : scsi_level::scsi_2); GetExtensionLowerCase(filename) == "is1" ? scsi_level::scsi_1_ccs : scsi_level::scsi_2);
device->SetProduct("SCSI CD-ROM"); device->SetProduct("SCSI CD-ROM");
break; break;
@ -135,15 +109,3 @@ shared_ptr<PrimaryDevice> DeviceFactory::CreateDevice(PbDeviceType type, int lun
return device; return device;
} }
// TODO Move to respective device, which may require changes in the SCSI_HD/SCSIHD_NEC inheritance hierarchy
unordered_set<uint32_t> DeviceFactory::GetSectorSizes(PbDeviceType type) const
{
const auto& it = sector_sizes.find(type);
if (it != sector_sizes.end()) {
return it->second;
}
else {
return {};
}
}

View File

@ -11,9 +11,7 @@
#pragma once #pragma once
#include "shared/piscsi_util.h"
#include <string> #include <string>
#include <unordered_set>
#include <unordered_map> #include <unordered_map>
#include "generated/piscsi_interface.pb.h" #include "generated/piscsi_interface.pb.h"
@ -27,19 +25,32 @@ class DeviceFactory
public: public:
DeviceFactory(); DeviceFactory() = default;
~DeviceFactory() = default; ~DeviceFactory() = default;
shared_ptr<PrimaryDevice> CreateDevice(PbDeviceType, int, const string&) const; shared_ptr<PrimaryDevice> CreateDevice(PbDeviceType, int, const string&) const;
PbDeviceType GetTypeForFile(const string&) const; PbDeviceType GetTypeForFile(const string&) const;
unordered_set<uint32_t> GetSectorSizes(PbDeviceType type) const; const auto& GetExtensionMapping() const { return EXTENSION_MAPPING; }
const auto& GetExtensionMapping() const { return extension_mapping; }
private: private:
unordered_map<PbDeviceType, unordered_set<uint32_t>> sector_sizes; const inline static unordered_map<string, PbDeviceType, piscsi_util::StringHash, equal_to<>> EXTENSION_MAPPING = {
{ "hd1", SCHD },
{ "hds", SCHD },
{ "hda", SCHD },
{ "hdn", SCHD },
{ "hdi", SCHD },
{ "nhd", SCHD },
{ "hdr", SCRM },
{ "mos", SCMO },
{ "is1", SCCD },
{ "iso", SCCD }
};
unordered_map<string, PbDeviceType, piscsi_util::StringHash, equal_to<>> extension_mapping; const inline static unordered_map<string, PbDeviceType, piscsi_util::StringHash, equal_to<>> DEVICE_MAPPING = {
{ "bridge", SCBR },
unordered_map<string, PbDeviceType, piscsi_util::StringHash, equal_to<>> device_mapping; { "daynaport", SCDP },
{ "printer", SCLP },
{ "services", SCHS }
};
}; };

View File

@ -695,7 +695,7 @@ uint32_t Disk::GetSectorSizeInBytes() const
void Disk::SetSectorSizeInBytes(uint32_t size_in_bytes) void Disk::SetSectorSizeInBytes(uint32_t size_in_bytes)
{ {
if (DeviceFactory device_factory; !device_factory.GetSectorSizes(GetType()).contains(size_in_bytes)) { if (!GetSupportedSectorSizes().contains(size_in_bytes)) {
throw io_exception("Invalid sector size of " + to_string(size_in_bytes) + " byte(s)"); throw io_exception("Invalid sector size of " + to_string(size_in_bytes) + " byte(s)");
} }
@ -708,9 +708,9 @@ uint32_t Disk::GetConfiguredSectorSize() const
return configured_sector_size; return configured_sector_size;
} }
bool Disk::SetConfiguredSectorSize(const DeviceFactory& device_factory, uint32_t configured_size) bool Disk::SetConfiguredSectorSize(uint32_t configured_size)
{ {
if (!device_factory.GetSectorSizes(GetType()).contains(configured_size)) { if (!supported_sector_sizes.contains(configured_size)) {
return false; return false;
} }

View File

@ -16,7 +16,6 @@
#include "shared/scsi.h" #include "shared/scsi.h"
#include "shared/piscsi_util.h" #include "shared/piscsi_util.h"
#include "device_factory.h"
#include "disk_track.h" #include "disk_track.h"
#include "disk_cache.h" #include "disk_cache.h"
#include "interfaces/scsi_block_commands.h" #include "interfaces/scsi_block_commands.h"
@ -35,8 +34,7 @@ class Disk : public StorageDevice, private ScsiBlockCommands
unique_ptr<DiskCache> cache; unique_ptr<DiskCache> cache;
// The supported configurable sector sizes, empty if not configurable unordered_set<uint32_t> supported_sector_sizes;
unordered_set<uint32_t> sector_sizes;
uint32_t configured_sector_size = 0; uint32_t configured_sector_size = 0;
// Sector size shift count (9=512, 10=1024, 11=2048, 12=4096) // Sector size shift count (9=512, 10=1024, 11=2048, 12=4096)
@ -50,7 +48,9 @@ class Disk : public StorageDevice, private ScsiBlockCommands
public: public:
using StorageDevice::StorageDevice; Disk(PbDeviceType type, int lun, const unordered_set<uint32_t>& s)
: StorageDevice(type, lun), supported_sector_sizes(s) {}
~Disk() override = default;
bool Init(const param_map&) override; bool Init(const param_map&) override;
void CleanUp() override; void CleanUp() override;
@ -64,8 +64,9 @@ public:
virtual int Read(span<uint8_t> , uint64_t); virtual int Read(span<uint8_t> , uint64_t);
uint32_t GetSectorSizeInBytes() const; uint32_t GetSectorSizeInBytes() const;
bool IsSectorSizeConfigurable() const { return !sector_sizes.empty(); } bool IsSectorSizeConfigurable() const { return supported_sector_sizes.size() > 1; }
bool SetConfiguredSectorSize(const DeviceFactory&, uint32_t); const auto& GetSupportedSectorSizes() const { return supported_sector_sizes; }
bool SetConfiguredSectorSize(uint32_t);
void FlushCache() override; void FlushCache() override;
vector<PbStatistics> GetStatistics() const override; vector<PbStatistics> GetStatistics() const override;
@ -119,7 +120,6 @@ protected:
void AddCachePage(map<int, vector<byte>>&, bool) const; void AddCachePage(map<int, vector<byte>>&, bool) const;
unordered_set<uint32_t> GetSectorSizes() const; unordered_set<uint32_t> GetSectorSizes() const;
void SetSectorSizes(const unordered_set<uint32_t>& sizes) { sector_sizes = sizes; }
void SetSectorSizeInBytes(uint32_t); void SetSectorSizeInBytes(uint32_t);
uint32_t GetSectorSizeShiftCount() const { return size_shift_count; } uint32_t GetSectorSizeShiftCount() const { return size_shift_count; }
void SetSectorSizeShiftCount(uint32_t count) { size_shift_count = count; } void SetSectorSizeShiftCount(uint32_t count) { size_shift_count = count; }

View File

@ -21,11 +21,8 @@
using namespace scsi_defs; using namespace scsi_defs;
using namespace scsi_command_util; using namespace scsi_command_util;
SCSICD::SCSICD(int lun, const unordered_set<uint32_t>& sector_sizes, scsi_defs::scsi_level level) SCSICD::SCSICD(int lun, scsi_defs::scsi_level level) : Disk(SCCD, lun, { 512, 2048 }), scsi_level(level)
: Disk(SCCD, lun), scsi_level(level)
{ {
SetSectorSizes(sector_sizes);
SetReadOnly(true); SetReadOnly(true);
SetRemovable(true); SetRemovable(true);
SetLockable(true); SetLockable(true);

View File

@ -25,7 +25,7 @@ class SCSICD : public Disk, private ScsiMmcCommands
{ {
public: public:
SCSICD(int, const unordered_set<uint32_t>&, scsi_defs::scsi_level = scsi_level::scsi_2); SCSICD(int, scsi_defs::scsi_level = scsi_level::scsi_2);
~SCSICD() override = default; ~SCSICD() override = default;
bool Init(const param_map&) override; bool Init(const param_map&) override;

View File

@ -19,11 +19,9 @@
using namespace scsi_command_util; using namespace scsi_command_util;
SCSIHD::SCSIHD(int lun, const unordered_set<uint32_t>& sector_sizes, bool removable, scsi_defs::scsi_level level) SCSIHD::SCSIHD(int lun, bool removable, scsi_defs::scsi_level level, const unordered_set<uint32_t>& sector_sizes)
: Disk(removable ? SCRM : SCHD, lun), scsi_level(level) : Disk(removable ? SCRM : SCHD, lun, sector_sizes), scsi_level(level)
{ {
SetSectorSizes(sector_sizes);
SetProtectable(true); SetProtectable(true);
SetRemovable(removable); SetRemovable(removable);
SetLockable(removable); SetLockable(removable);

View File

@ -28,7 +28,7 @@ class SCSIHD : public Disk
public: public:
SCSIHD(int, const unordered_set<uint32_t>&, bool, scsi_defs::scsi_level = scsi_level::scsi_2); SCSIHD(int, bool, scsi_defs::scsi_level, const unordered_set<uint32_t>& = { 512, 1024, 2048, 4096 });
~SCSIHD() override = default; ~SCSIHD() override = default;
void FinalizeSetup(off_t); void FinalizeSetup(off_t);

View File

@ -33,7 +33,7 @@ class SCSIHD_NEC : public SCSIHD //NOSONAR The inheritance hierarchy depth is ac
{ {
public: public:
explicit SCSIHD_NEC(int lun) : SCSIHD(lun, { 512 }, false) {} explicit SCSIHD_NEC(int lun) : SCSIHD(lun, false, scsi_level::scsi_1_ccs, { 512 }) {}
~SCSIHD_NEC() override = default; ~SCSIHD_NEC() override = default;
void Open() override; void Open() override;

View File

@ -19,10 +19,8 @@
using namespace scsi_command_util; using namespace scsi_command_util;
SCSIMO::SCSIMO(int lun, const unordered_set<uint32_t>& sector_sizes) : Disk(SCMO, lun) SCSIMO::SCSIMO(int lun) : Disk(SCMO, lun, { 512, 1024, 2048, 4096 })
{ {
SetSectorSizes(sector_sizes);
// 128 MB, 512 bytes per sector, 248826 sectors // 128 MB, 512 bytes per sector, 248826 sectors
geometries[512 * 248826] = { 512, 248826 }; geometries[512 * 248826] = { 512, 248826 };
// 230 MB, 512 bytes per block, 446325 sectors // 230 MB, 512 bytes per block, 446325 sectors

View File

@ -26,7 +26,7 @@ class SCSIMO : public Disk
{ {
public: public:
SCSIMO(int, const unordered_set<uint32_t>&); explicit SCSIMO(int);
~SCSIMO() override = default; ~SCSIMO() override = default;
void Open() override; void Open() override;

View File

@ -17,7 +17,6 @@
#include "shared/piscsi_version.h" #include "shared/piscsi_version.h"
#include "controllers/scsi_controller.h" #include "controllers/scsi_controller.h"
#include "devices/device_logger.h" #include "devices/device_logger.h"
#include "devices/device_factory.h"
#include "devices/storage_device.h" #include "devices/storage_device.h"
#include "hal/gpiobus_factory.h" #include "hal/gpiobus_factory.h"
#include "hal/gpiobus.h" #include "hal/gpiobus.h"

View File

@ -67,7 +67,7 @@ private:
PiscsiImage piscsi_image; PiscsiImage piscsi_image;
PiscsiResponse response; [[no_unique_address]] PiscsiResponse response;
PiscsiService service; PiscsiService service;

View File

@ -10,7 +10,6 @@
#include "shared/piscsi_util.h" #include "shared/piscsi_util.h"
#include "shared/protobuf_util.h" #include "shared/protobuf_util.h"
#include "shared/piscsi_exceptions.h" #include "shared/piscsi_exceptions.h"
#include "devices/device_factory.h"
#include "devices/disk.h" #include "devices/disk.h"
#include "localizer.h" #include "localizer.h"
#include "command_context.h" #include "command_context.h"
@ -530,7 +529,7 @@ bool PiscsiExecutor::SetSectorSize(const CommandContext& context, shared_ptr<Pri
if (size) { if (size) {
const auto disk = dynamic_pointer_cast<Disk>(device); const auto disk = dynamic_pointer_cast<Disk>(device);
if (disk != nullptr && disk->IsSectorSizeConfigurable()) { if (disk != nullptr && disk->IsSectorSizeConfigurable()) {
if (!disk->SetConfiguredSectorSize(device_factory, size)) { if (!disk->SetConfiguredSectorSize(size)) {
return context.ReturnLocalizedError(LocalizationKey::ERROR_BLOCK_SIZE, to_string(size)); return context.ReturnLocalizedError(LocalizationKey::ERROR_BLOCK_SIZE, to_string(size));
} }
} }

View File

@ -11,6 +11,7 @@
#include "hal/bus.h" #include "hal/bus.h"
#include "controllers/controller_manager.h" #include "controllers/controller_manager.h"
#include "devices/device_factory.h"
#include <unordered_set> #include <unordered_set>
class DeviceFactory; class DeviceFactory;
@ -60,7 +61,7 @@ private:
ControllerManager& controller_manager; ControllerManager& controller_manager;
const DeviceFactory device_factory; [[no_unique_address]] const DeviceFactory device_factory;
unordered_set<int> reserved_ids; unordered_set<int> reserved_ids;
}; };

View File

@ -24,26 +24,29 @@ using namespace piscsi_util;
using namespace network_util; using namespace network_util;
using namespace protobuf_util; using namespace protobuf_util;
void PiscsiResponse::GetDeviceProperties(const Device& device, PbDeviceProperties& properties) const void PiscsiResponse::GetDeviceProperties(shared_ptr<Device> device, PbDeviceProperties& properties) const
{ {
properties.set_luns(ControllerManager::GetScsiLunMax()); properties.set_luns(ControllerManager::GetScsiLunMax());
properties.set_read_only(device.IsReadOnly()); properties.set_read_only(device->IsReadOnly());
properties.set_protectable(device.IsProtectable()); properties.set_protectable(device->IsProtectable());
properties.set_stoppable(device.IsStoppable()); properties.set_stoppable(device->IsStoppable());
properties.set_removable(device.IsRemovable()); properties.set_removable(device->IsRemovable());
properties.set_lockable(device.IsLockable()); properties.set_lockable(device->IsLockable());
properties.set_supports_file(device.SupportsFile()); properties.set_supports_file(device->SupportsFile());
properties.set_supports_params(device.SupportsParams()); properties.set_supports_params(device->SupportsParams());
if (device.SupportsParams()) { if (device->SupportsParams()) {
for (const auto& [key, value] : device.GetDefaultParams()) { for (const auto& [key, value] : device->GetDefaultParams()) {
auto& map = *properties.mutable_default_params(); auto& map = *properties.mutable_default_params();
map[key] = value; map[key] = value;
} }
} }
for (const auto& block_size : device_factory.GetSectorSizes(device.GetType())) { shared_ptr<Disk> disk = dynamic_pointer_cast<Disk>(device);
properties.add_block_sizes(block_size); if (disk != nullptr && disk->IsSectorSizeConfigurable()) {
for (const auto& sector_size : disk->GetSupportedSectorSizes()) {
properties.add_block_sizes(sector_size);
}
} }
} }
@ -52,7 +55,7 @@ void PiscsiResponse::GetDeviceTypeProperties(PbDeviceTypesInfo& device_types_inf
auto type_properties = device_types_info.add_properties(); auto type_properties = device_types_info.add_properties();
type_properties->set_type(type); type_properties->set_type(type);
const auto device = device_factory.CreateDevice(type, 0, ""); const auto device = device_factory.CreateDevice(type, 0, "");
GetDeviceProperties(*device, *type_properties->mutable_properties()); GetDeviceProperties(device, *type_properties->mutable_properties());
} }
void PiscsiResponse::GetDeviceTypesInfo(PbDeviceTypesInfo& device_types_info) const void PiscsiResponse::GetDeviceTypesInfo(PbDeviceTypesInfo& device_types_info) const
@ -67,37 +70,37 @@ void PiscsiResponse::GetDeviceTypesInfo(PbDeviceTypesInfo& device_types_info) co
} }
} }
void PiscsiResponse::GetDevice(const Device& device, PbDevice& pb_device, const string& default_folder) const void PiscsiResponse::GetDevice(shared_ptr<Device> device, PbDevice& pb_device, const string& default_folder) const
{ {
pb_device.set_id(device.GetId()); pb_device.set_id(device->GetId());
pb_device.set_unit(device.GetLun()); pb_device.set_unit(device->GetLun());
pb_device.set_vendor(device.GetVendor()); pb_device.set_vendor(device->GetVendor());
pb_device.set_product(device.GetProduct()); pb_device.set_product(device->GetProduct());
pb_device.set_revision(device.GetRevision()); pb_device.set_revision(device->GetRevision());
pb_device.set_type(device.GetType()); pb_device.set_type(device->GetType());
GetDeviceProperties(device, *pb_device.mutable_properties()); GetDeviceProperties(device, *pb_device.mutable_properties());
auto status = pb_device.mutable_status(); auto status = pb_device.mutable_status();
status->set_protected_(device.IsProtected()); status->set_protected_(device->IsProtected());
status->set_stopped(device.IsStopped()); status->set_stopped(device->IsStopped());
status->set_removed(device.IsRemoved()); status->set_removed(device->IsRemoved());
status->set_locked(device.IsLocked()); status->set_locked(device->IsLocked());
if (device.SupportsParams()) { if (device->SupportsParams()) {
for (const auto& [key, value] : device.GetParams()) { for (const auto& [key, value] : device->GetParams()) {
SetParam(pb_device, key, value); SetParam(pb_device, key, value);
} }
} }
if (const auto disk = dynamic_cast<const Disk*>(&device); disk) { if (const auto disk = dynamic_pointer_cast<const Disk>(device); disk) {
pb_device.set_block_size(device.IsRemoved()? 0 : disk->GetSectorSizeInBytes()); pb_device.set_block_size(device->IsRemoved()? 0 : disk->GetSectorSizeInBytes());
pb_device.set_block_count(device.IsRemoved() ? 0: disk->GetBlockCount()); pb_device.set_block_count(device->IsRemoved() ? 0: disk->GetBlockCount());
} }
const auto storage_device = dynamic_cast<const StorageDevice *>(&device); const auto storage_device = dynamic_pointer_cast<const StorageDevice>(device);
if (storage_device != nullptr) { if (storage_device != nullptr) {
GetImageFile(*pb_device.mutable_file(), default_folder, device.IsReady() ? storage_device->GetFilename() : ""); GetImageFile(*pb_device.mutable_file(), default_folder, device->IsReady() ? storage_device->GetFilename() : "");
} }
} }
@ -191,7 +194,7 @@ void PiscsiResponse::GetDevices(const unordered_set<shared_ptr<PrimaryDevice>>&
{ {
for (const auto& device : devices) { for (const auto& device : devices) {
PbDevice *pb_device = server_info.mutable_devices_info()->add_devices(); PbDevice *pb_device = server_info.mutable_devices_info()->add_devices();
GetDevice(*device, *pb_device, default_folder); GetDevice(device, *pb_device, default_folder);
} }
} }
@ -218,7 +221,7 @@ void PiscsiResponse::GetDevicesInfo(const unordered_set<shared_ptr<PrimaryDevice
for (const auto& [id, lun] : id_sets) { for (const auto& [id, lun] : id_sets) {
for (const auto& d : devices) { for (const auto& d : devices) {
if (d->GetId() == id && d->GetLun() == lun) { if (d->GetId() == id && d->GetLun() == lun) {
GetDevice(*d, *devices_info->add_devices(), default_folder); GetDevice(d, *devices_info->add_devices(), default_folder);
break; break;
} }
} }

View File

@ -47,11 +47,10 @@ private:
inline static const vector<string> EMPTY_VECTOR; inline static const vector<string> EMPTY_VECTOR;
// TODO Try to get rid of this field by having the device instead of the factory providing the device data [[no_unique_address]] const DeviceFactory device_factory;
const DeviceFactory device_factory;
void GetDeviceProperties(const Device&, PbDeviceProperties&) const; void GetDeviceProperties(shared_ptr<Device>, PbDeviceProperties&) const;
void GetDevice(const Device&, PbDevice&, const string&) const; void GetDevice(shared_ptr<Device>, PbDevice&, const string&) const;
void GetDeviceTypeProperties(PbDeviceTypesInfo&, PbDeviceType) const; void GetDeviceTypeProperties(PbDeviceTypesInfo&, PbDeviceType) const;
void GetAvailableImages(PbImageFilesInfo&, const string&, const string&, const string&, int) const; void GetAvailableImages(PbImageFilesInfo&, const string&, const string&, const string&, int) const;
void GetAvailableImages(PbServerInfo&, const string&, const string&, const string&, int) const; void GetAvailableImages(PbServerInfo&, const string&, const string&, const string&, int) const;

View File

@ -39,41 +39,6 @@ TEST(DeviceFactoryTest, GetTypeForFile)
EXPECT_EQ(device_factory.GetTypeForFile("test.iso.suffix"), UNDEFINED); EXPECT_EQ(device_factory.GetTypeForFile("test.iso.suffix"), UNDEFINED);
} }
TEST(DeviceFactoryTest, GetSectorSizes)
{
DeviceFactory device_factory;
unordered_set<uint32_t> sector_sizes = device_factory.GetSectorSizes(SCHD);
EXPECT_EQ(4, sector_sizes.size());
EXPECT_TRUE(sector_sizes.contains(512));
EXPECT_TRUE(sector_sizes.contains(1024));
EXPECT_TRUE(sector_sizes.contains(2048));
EXPECT_TRUE(sector_sizes.contains(4096));
sector_sizes = device_factory.GetSectorSizes(SCRM);
EXPECT_EQ(4, sector_sizes.size());
EXPECT_TRUE(sector_sizes.contains(512));
EXPECT_TRUE(sector_sizes.contains(1024));
EXPECT_TRUE(sector_sizes.contains(2048));
EXPECT_TRUE(sector_sizes.contains(4096));
sector_sizes = device_factory.GetSectorSizes(SCMO);
EXPECT_EQ(4, sector_sizes.size());
EXPECT_TRUE(sector_sizes.contains(512));
EXPECT_TRUE(sector_sizes.contains(1024));
EXPECT_TRUE(sector_sizes.contains(2048));
EXPECT_TRUE(sector_sizes.contains(4096));
sector_sizes = device_factory.GetSectorSizes(SCCD);
EXPECT_EQ(2, sector_sizes.size());
EXPECT_TRUE(sector_sizes.contains(512));
EXPECT_TRUE(sector_sizes.contains(2048));
}
TEST(DeviceFactoryTest, GetExtensionMapping) TEST(DeviceFactoryTest, GetExtensionMapping)
{ {
DeviceFactory device_factory; DeviceFactory device_factory;

View File

@ -774,14 +774,8 @@ TEST(DiskTest, SectorSize)
{ {
MockDisk disk; MockDisk disk;
unordered_set<uint32_t> sizes = { 512, 1024 };
disk.SetSectorSizes(sizes);
EXPECT_TRUE(disk.IsSectorSizeConfigurable()); EXPECT_TRUE(disk.IsSectorSizeConfigurable());
sizes.clear();
disk.SetSectorSizes(sizes);
EXPECT_FALSE(disk.IsSectorSizeConfigurable());
disk.SetSectorSizeShiftCount(9); disk.SetSectorSizeShiftCount(9);
EXPECT_EQ(9, disk.GetSectorSizeShiftCount()); EXPECT_EQ(9, disk.GetSectorSizeShiftCount());
EXPECT_EQ(512, disk.GetSectorSizeInBytes()); EXPECT_EQ(512, disk.GetSectorSizeInBytes());
@ -815,13 +809,12 @@ TEST(DiskTest, SectorSize)
TEST(DiskTest, ConfiguredSectorSize) TEST(DiskTest, ConfiguredSectorSize)
{ {
DeviceFactory device_factory; MockSCSIHD disk(0, false);
MockSCSIHD disk(0, {}, false);
EXPECT_TRUE(disk.SetConfiguredSectorSize(device_factory, 512)); EXPECT_TRUE(disk.SetConfiguredSectorSize(512));
EXPECT_EQ(512, disk.GetConfiguredSectorSize()); EXPECT_EQ(512, disk.GetConfiguredSectorSize());
EXPECT_FALSE(disk.SetConfiguredSectorSize(device_factory, 1234)); EXPECT_FALSE(disk.SetConfiguredSectorSize(1234));
EXPECT_EQ(512, disk.GetConfiguredSectorSize()); EXPECT_EQ(512, disk.GetConfiguredSectorSize());
} }

View File

@ -352,7 +352,7 @@ public:
MOCK_METHOD(void, FlushCache, (), (override)); MOCK_METHOD(void, FlushCache, (), (override));
MOCK_METHOD(void, Open, (), (override)); MOCK_METHOD(void, Open, (), (override));
MockDisk() : Disk(SCHD, 0) {} MockDisk() : Disk(SCHD, 0, { 512, 1024, 2048, 4096 }) {}
~MockDisk() override = default; ~MockDisk() override = default;
}; };
@ -363,10 +363,15 @@ class MockSCSIHD : public SCSIHD //NOSONAR Ignore inheritance hierarchy depth in
FRIEND_TEST(ScsiHdTest, FinalizeSetup); FRIEND_TEST(ScsiHdTest, FinalizeSetup);
FRIEND_TEST(ScsiHdTest, GetProductData); FRIEND_TEST(ScsiHdTest, GetProductData);
FRIEND_TEST(ScsiHdTest, SetUpModePages); FRIEND_TEST(ScsiHdTest, SetUpModePages);
FRIEND_TEST(PiscsiExecutorTest, SetSectorSize); FRIEND_TEST(ScsiHdTest, GetSectorSizes);
FRIEND_TEST(ScsiHdTest, ModeSelect); FRIEND_TEST(ScsiHdTest, ModeSelect);
FRIEND_TEST(PiscsiExecutorTest, SetSectorSize);
using SCSIHD::SCSIHD; public:
MockSCSIHD(int lun, bool removable) : SCSIHD(lun, removable, scsi_level::scsi_2) {}
explicit MockSCSIHD(const unordered_set<uint32_t>& sector_sizes) : SCSIHD(0, false, scsi_level::scsi_2, sector_sizes) {}
~MockSCSIHD() override = default;
}; };
class MockSCSIHD_NEC : public SCSIHD_NEC //NOSONAR Ignore inheritance hierarchy depth in unit tests class MockSCSIHD_NEC : public SCSIHD_NEC //NOSONAR Ignore inheritance hierarchy depth in unit tests
@ -382,6 +387,7 @@ class MockSCSIHD_NEC : public SCSIHD_NEC //NOSONAR Ignore inheritance hierarchy
class MockSCSICD : public SCSICD //NOSONAR Ignore inheritance hierarchy depth in unit tests class MockSCSICD : public SCSICD //NOSONAR Ignore inheritance hierarchy depth in unit tests
{ {
FRIEND_TEST(ScsiCdTest, GetSectorSizes);
FRIEND_TEST(ScsiCdTest, SetUpModePages); FRIEND_TEST(ScsiCdTest, SetUpModePages);
FRIEND_TEST(ScsiCdTest, ReadToc); FRIEND_TEST(ScsiCdTest, ReadToc);

View File

@ -252,8 +252,6 @@ TEST(PiscsiExecutorTest, Attach)
TEST(PiscsiExecutorTest, Insert) TEST(PiscsiExecutorTest, Insert)
{ {
DeviceFactory device_factory;
auto bus = make_shared<MockBus>(); auto bus = make_shared<MockBus>();
ControllerManager controller_manager; ControllerManager controller_manager;
auto [controller, device] = CreateDevice(SCHD); auto [controller, device] = CreateDevice(SCHD);
@ -500,13 +498,17 @@ TEST(PiscsiExecutorTest, SetSectorSize)
CommandContext context(command, "", ""); CommandContext context(command, "", "");
unordered_set<uint32_t> sizes; unordered_set<uint32_t> sizes;
auto hd = make_shared<MockSCSIHD>(0, sizes, false); auto hd = make_shared<MockSCSIHD>(sizes);
EXPECT_FALSE(executor.SetSectorSize(context, hd, 512)); EXPECT_FALSE(executor.SetSectorSize(context, hd, 512));
sizes.insert(512); sizes.insert(512);
hd = make_shared<MockSCSIHD>(0, sizes, false); hd = make_shared<MockSCSIHD>(sizes);
EXPECT_TRUE(executor.SetSectorSize(context, hd, 0)); EXPECT_TRUE(executor.SetSectorSize(context, hd, 0));
EXPECT_FALSE(executor.SetSectorSize(context, hd, 1)); EXPECT_FALSE(executor.SetSectorSize(context, hd, 1));
EXPECT_FALSE(executor.SetSectorSize(context, hd, 512));
sizes.insert(1024);
hd = make_shared<MockSCSIHD>(sizes);
EXPECT_TRUE(executor.SetSectorSize(context, hd, 512)); EXPECT_TRUE(executor.SetSectorSize(context, hd, 512));
} }

View File

@ -34,10 +34,21 @@ TEST(ScsiCdTest, Inquiry)
TestInquiry::Inquiry(SCCD, device_type::cd_rom, scsi_level::scsi_1_ccs, "PiSCSI SCSI CD-ROM ", 0x1f, true, "file.is1"); TestInquiry::Inquiry(SCCD, device_type::cd_rom, scsi_level::scsi_1_ccs, "PiSCSI SCSI CD-ROM ", 0x1f, true, "file.is1");
} }
TEST(ScsiCdTest, GetSectorSizes)
{
MockSCSICD cd(0);
const auto& sector_sizes = cd.GetSupportedSectorSizes();
EXPECT_EQ(2, sector_sizes.size());
EXPECT_TRUE(sector_sizes.contains(512));
EXPECT_TRUE(sector_sizes.contains(2048));
}
TEST(ScsiCdTest, SetUpModePages) TEST(ScsiCdTest, SetUpModePages)
{ {
map<int, vector<byte>> pages; map<int, vector<byte>> pages;
MockSCSICD cd(0, {}); MockSCSICD cd(0);
// Non changeable // Non changeable
cd.SetUpModePages(pages, 0x3f, false); cd.SetUpModePages(pages, 0x3f, false);
@ -51,10 +62,10 @@ TEST(ScsiCdTest, SetUpModePages)
TEST(ScsiCdTest, Open) TEST(ScsiCdTest, Open)
{ {
MockSCSICD cd_iso(0, {}); MockSCSICD cd_iso(0);
MockSCSICD cd_cue(0, {}); MockSCSICD cd_cue(0);
MockSCSICD cd_raw(0, {}); MockSCSICD cd_raw(0);
MockSCSICD cd_physical(0, {}); MockSCSICD cd_physical(0);
EXPECT_THROW(cd_iso.Open(), io_exception) << "Missing filename"; EXPECT_THROW(cd_iso.Open(), io_exception) << "Missing filename";
@ -111,8 +122,7 @@ TEST(ScsiCdTest, Open)
TEST(ScsiCdTest, ReadToc) TEST(ScsiCdTest, ReadToc)
{ {
auto controller = make_shared<MockAbstractController>(); auto controller = make_shared<MockAbstractController>();
const unordered_set<uint32_t> sector_sizes; auto cd = make_shared<MockSCSICD>(0);
auto cd = make_shared<MockSCSICD>(0, sector_sizes);
EXPECT_TRUE(cd->Init({})); EXPECT_TRUE(cd->Init({}));
controller->AddDevice(cd); controller->AddDevice(cd);

View File

@ -30,14 +30,14 @@ TEST(ScsiHdTest, Inquiry)
TEST(ScsiHdTest, SupportsSaveParameters) TEST(ScsiHdTest, SupportsSaveParameters)
{ {
MockSCSIHD hd(0, {}, false); MockSCSIHD hd(0, false);
EXPECT_TRUE(hd.SupportsSaveParameters()); EXPECT_TRUE(hd.SupportsSaveParameters());
} }
TEST(ScsiHdTest, FinalizeSetup) TEST(ScsiHdTest, FinalizeSetup)
{ {
MockSCSIHD hd(0, {}, false); MockSCSIHD hd(0, false);
hd.SetSectorSizeInBytes(1024); hd.SetSectorSizeInBytes(1024);
EXPECT_THROW(hd.FinalizeSetup(0), io_exception) << "Device has 0 blocks"; EXPECT_THROW(hd.FinalizeSetup(0), io_exception) << "Device has 0 blocks";
@ -45,9 +45,9 @@ TEST(ScsiHdTest, FinalizeSetup)
TEST(ScsiHdTest, GetProductData) TEST(ScsiHdTest, GetProductData)
{ {
MockSCSIHD hd_kb(0, {}, false); MockSCSIHD hd_kb(0, false);
MockSCSIHD hd_mb(0, {}, false); MockSCSIHD hd_mb(0, false);
MockSCSIHD hd_gb(0, {}, false); MockSCSIHD hd_gb(0, false);
const path filename = CreateTempFile(1); const path filename = CreateTempFile(1);
hd_kb.SetFilename(string(filename)); hd_kb.SetFilename(string(filename));
@ -73,10 +73,23 @@ TEST(ScsiHdTest, GetProductData)
remove(filename); remove(filename);
} }
TEST(ScsiHdTest, GetSectorSizes)
{
MockSCSIHD hd(0, false);
const auto& sector_sizes = hd.GetSupportedSectorSizes();
EXPECT_EQ(4, sector_sizes.size());
EXPECT_TRUE(sector_sizes.contains(512));
EXPECT_TRUE(sector_sizes.contains(1024));
EXPECT_TRUE(sector_sizes.contains(2048));
EXPECT_TRUE(sector_sizes.contains(4096));
}
TEST(ScsiHdTest, SetUpModePages) TEST(ScsiHdTest, SetUpModePages)
{ {
map<int, vector<byte>> pages; map<int, vector<byte>> pages;
MockSCSIHD hd(0, {}, false); MockSCSIHD hd(0, false);
// Non changeable // Non changeable
hd.SetUpModePages(pages, 0x3f, false); hd.SetUpModePages(pages, 0x3f, false);
@ -90,7 +103,7 @@ TEST(ScsiHdTest, SetUpModePages)
TEST(ScsiHdTest, ModeSelect) TEST(ScsiHdTest, ModeSelect)
{ {
MockSCSIHD hd(0, { 512 }, false); MockSCSIHD hd({ 512 });
vector<int> cmd(10); vector<int> cmd(10);
vector<uint8_t> buf(255); vector<uint8_t> buf(255);

View File

@ -28,15 +28,28 @@ TEST(ScsiMoTest, Inquiry)
TEST(ScsiMoTest, SupportsSaveParameters) TEST(ScsiMoTest, SupportsSaveParameters)
{ {
map<int, vector<byte>> pages; map<int, vector<byte>> pages;
MockSCSIMO mo(0, {}); MockSCSIMO mo(0);
EXPECT_TRUE(mo.SupportsSaveParameters()); EXPECT_TRUE(mo.SupportsSaveParameters());
} }
TEST(ScsiMoTest, GetSectorSizes)
{
MockSCSIMO mo(0);
const auto& sector_sizes = mo.GetSupportedSectorSizes();
EXPECT_EQ(4, sector_sizes.size());
EXPECT_TRUE(sector_sizes.contains(512));
EXPECT_TRUE(sector_sizes.contains(1024));
EXPECT_TRUE(sector_sizes.contains(2048));
EXPECT_TRUE(sector_sizes.contains(4096));
}
TEST(ScsiMoTest, SetUpModePages) TEST(ScsiMoTest, SetUpModePages)
{ {
map<int, vector<byte>> pages; map<int, vector<byte>> pages;
MockSCSIMO mo(0, {}); MockSCSIMO mo(0);
// Non changeable // Non changeable
mo.SetUpModePages(pages, 0x3f, false); mo.SetUpModePages(pages, 0x3f, false);
@ -51,7 +64,7 @@ TEST(ScsiMoTest, SetUpModePages)
TEST(ScsiMoTest, TestAddVendorPage) TEST(ScsiMoTest, TestAddVendorPage)
{ {
map<int, vector<byte>> pages; map<int, vector<byte>> pages;
MockSCSIMO mo(0, {}); MockSCSIMO mo(0);
mo.SetReady(true); mo.SetReady(true);
mo.SetUpModePages(pages, 0x21, false); mo.SetUpModePages(pages, 0x21, false);
@ -122,7 +135,7 @@ TEST(ScsiMoTest, TestAddVendorPage)
TEST(ScsiMoTest, ModeSelect) TEST(ScsiMoTest, ModeSelect)
{ {
MockSCSIMO mo(0, { 1024, 2048 }); MockSCSIMO mo(0);
vector<int> cmd(10); vector<int> cmd(10);
vector<uint8_t> buf(255); vector<uint8_t> buf(255);