Improved block size check

This commit is contained in:
Uwe Seimet 2021-08-29 16:45:12 +02:00
parent 5ed6673429
commit 502b19bfb2
6 changed files with 19 additions and 23 deletions

View File

@ -32,20 +32,16 @@ DeviceFactory::DeviceFactory()
sector_sizes_scsi.insert(2048); sector_sizes_scsi.insert(2048);
sector_sizes_scsi.insert(4096); sector_sizes_scsi.insert(4096);
// 128 MB, 512 bytes per block, 248826 blocks // 128 MB, 512 bytes per sector, 248826 sectors
geometries_mo[0x797f400] = make_pair(512, 248826); geometries_mo[0x797f400] = make_pair(512, 248826);
// 230 MB, 512 bytes per sector, 446325 blocks // 230 MB, 512 bytes per block, 446325 sectors
geometries_mo[0xd9eea00] = make_pair(512, 446325); geometries_mo[0xd9eea00] = make_pair(512, 446325);
// 540 MB, 512 bytes per sector, 1041500 blocks // 540 MB, 512 bytes per sector, 1041500 sectors
geometries_mo[0x1fc8b800] = make_pair(512, 1041500); geometries_mo[0x1fc8b800] = make_pair(512, 1041500);
// 640 MB, 20248 bytes per sector, 310352 blocks // 640 MB, 20248 bytes per sector, 310352 sectors
geometries_mo[0x25e28000] = make_pair(2048, 310352); geometries_mo[0x25e28000] = make_pair(2048, 310352);
} }
DeviceFactory::~DeviceFactory()
{
}
DeviceFactory& DeviceFactory::instance() DeviceFactory& DeviceFactory::instance()
{ {
static DeviceFactory instance; static DeviceFactory instance;
@ -143,7 +139,7 @@ Device *DeviceFactory::CreateDevice(PbDeviceType& type, const string& filename,
} }
} }
catch(const illegal_argument_exception& e) { catch(const illegal_argument_exception& e) {
// There was an internal problem with setting the INQUIRY DATA // There was an internal problem with setting up the device data
return NULL; return NULL;
} }

View File

@ -18,16 +18,16 @@
using namespace std; using namespace std;
typedef pair<uint32_t, uint32_t> Geometry;
class Device; class Device;
class DeviceFactory class DeviceFactory
{ {
public: public:
typedef pair<uint32_t, uint32_t> Geometry;
DeviceFactory(); DeviceFactory();
~DeviceFactory(); ~DeviceFactory() {};
static DeviceFactory& instance(); static DeviceFactory& instance();

View File

@ -1756,7 +1756,7 @@ void Disk::SetSectorSizeInBytes(uint32_t size, bool sasi)
set<uint32_t> sector_sizes = sasi ? DeviceFactory::instance().GetSasiSectorSizes() : DeviceFactory::instance().GetScsiSectorSizes(); set<uint32_t> sector_sizes = sasi ? DeviceFactory::instance().GetSasiSectorSizes() : DeviceFactory::instance().GetScsiSectorSizes();
if (sector_sizes.find(size) == sector_sizes.end()) { if (sector_sizes.find(size) == sector_sizes.end()) {
stringstream error; stringstream error;
error << "Invalid sector size of " << size << " bytes"; error << "Invalid block size of " << size << " bytes";
throw io_exception(error.str()); throw io_exception(error.str());
} }
@ -1809,8 +1809,10 @@ uint32_t Disk::GetConfiguredSectorSize() const
bool Disk::SetConfiguredSectorSize(uint32_t configured_sector_size) bool Disk::SetConfiguredSectorSize(uint32_t configured_sector_size)
{ {
if (configured_sector_size != 512 && configured_sector_size != 1024 && const DeviceFactory& device_factory = DeviceFactory::instance();
configured_sector_size != 2048 && configured_sector_size != 4096) {
set<uint32_t> sector_sizes = IsSCSI() ? device_factory.GetScsiSectorSizes() : device_factory.GetSasiSectorSizes();
if (sector_sizes.find(configured_sector_size) == sector_sizes.end()) {
return false; return false;
} }
@ -1819,15 +1821,13 @@ bool Disk::SetConfiguredSectorSize(uint32_t configured_sector_size)
return true; return true;
} }
bool Disk::SetGeometries(const map<uint64_t, DeviceFactory::Geometry>& geometries) void Disk::SetGeometries(const map<uint64_t, Geometry>& geometries)
{ {
if (!IsMo()) { if (!IsMo()) {
return false; throw illegal_argument_exception("Can't set geometry for");
} }
this->geometries = geometries; this->geometries = geometries;
return true;
} }
void Disk::SetGeometryForCapacity(uint64_t capacity) { void Disk::SetGeometryForCapacity(uint64_t capacity) {

View File

@ -43,7 +43,7 @@ private:
uint32_t configured_sector_size; uint32_t configured_sector_size;
// The mapping of supported capacities to block sizes and block counts, empty if there is no capacity restriction // The mapping of supported capacities to block sizes and block counts, empty if there is no capacity restriction
map<uint64_t, DeviceFactory::Geometry> geometries; map<uint64_t, Geometry> geometries;
SASIDEV::ctrl_t *ctrl; SASIDEV::ctrl_t *ctrl;
@ -137,7 +137,7 @@ public:
void SetSectorSizes(const set<uint32_t>&); void SetSectorSizes(const set<uint32_t>&);
uint32_t GetConfiguredSectorSize() const; uint32_t GetConfiguredSectorSize() const;
bool SetConfiguredSectorSize(uint32_t); bool SetConfiguredSectorSize(uint32_t);
bool SetGeometries(const map<uint64_t, DeviceFactory::Geometry>&); void SetGeometries(const map<uint64_t, Geometry>&);
void SetGeometryForCapacity(uint64_t); void SetGeometryForCapacity(uint64_t);
uint32_t GetBlockCount() const; uint32_t GetBlockCount() const;
void SetBlockCount(uint32_t); void SetBlockCount(uint32_t);

View File

@ -727,7 +727,7 @@ bool ProcessCmd(int fd, const PbDeviceDefinition& pbDevice, const PbOperation op
Disk *disk = dynamic_cast<Disk *>(device); Disk *disk = dynamic_cast<Disk *>(device);
if (disk && disk->IsSectorSizeConfigurable()) { if (disk && disk->IsSectorSizeConfigurable()) {
if (!disk->SetConfiguredSectorSize(pbDevice.block_size())) { if (!disk->SetConfiguredSectorSize(pbDevice.block_size())) {
error << "Invalid block size " << pbDevice.block_size(); error << "Invalid block size " << pbDevice.block_size() << " bytes";
return ReturnStatus(fd, false, error); return ReturnStatus(fd, false, error);
} }
} }

View File

@ -34,7 +34,7 @@ string ListDevices(const PbDevices& devices)
} }
list<PbDevice> sorted_devices = { devices.devices().begin(), devices.devices().end() }; list<PbDevice> sorted_devices = { devices.devices().begin(), devices.devices().end() };
sorted_devices.sort([](const PbDevice& a, const PbDevice& b) { return a.id() < b.id() && a.unit() < b.unit(); }); sorted_devices.sort([](const auto& a, const auto& b) { return a.id() < b.id() && a.unit() < b.unit(); });
for (const auto& device : sorted_devices) { for (const auto& device : sorted_devices) {
string filename; string filename;