Do not abort but only warn on unexpected CD-ROM image size (#1084)

* Do not abort but only warn on unexpected CD-ROM image size

* Unit test update

* Updated exception handling

* Cleanup

* Fixed typo
This commit is contained in:
Uwe Seimet 2023-01-28 17:28:21 +01:00 committed by GitHub
parent 139a6ec371
commit b6941c9e81
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 9 additions and 30 deletions

View File

@ -10,8 +10,6 @@
// Licensed under the BSD 3-Clause License. // Licensed under the BSD 3-Clause License.
// See LICENSE file in the project root folder. // See LICENSE file in the project root folder.
// //
// [ SCSI CD-ROM ]
//
//--------------------------------------------------------------------------- //---------------------------------------------------------------------------
#include "shared/piscsi_exceptions.h" #include "shared/piscsi_exceptions.h"
@ -79,7 +77,6 @@ void SCSICD::Open()
SetReadOnly(true); SetReadOnly(true);
SetProtectable(false); SetProtectable(false);
// Attention if ready
if (IsReady()) { if (IsReady()) {
SetAttn(true); SetAttn(true);
} }
@ -113,13 +110,12 @@ void SCSICD::OpenIso()
throw io_exception("Illegal raw ISO CD-ROM file header"); throw io_exception("Illegal raw ISO CD-ROM file header");
} }
// Set to RAW file
rawfile = true; rawfile = true;
} }
if (rawfile) { if (rawfile) {
if (size % 2536) { if (size % 2536) {
throw io_exception("Raw ISO CD-ROM file size must be a multiple of 2536 bytes but is " GetLogger().Warn("Raw ISO CD-ROM file size is not a multiple of 2536 bytes but is "
+ to_string(size) + " bytes"); + to_string(size) + " bytes");
} }
@ -134,7 +130,6 @@ void SCSICD::OpenIso()
// TODO This code is only executed if the filename starts with a `\`, but fails to open files starting with `\`. // TODO This code is only executed if the filename starts with a `\`, but fails to open files starting with `\`.
void SCSICD::OpenPhysical() void SCSICD::OpenPhysical()
{ {
// Get size
off_t size = GetFileSize(); off_t size = GetFileSize();
if (size < 2048) { if (size < 2048) {
throw io_exception("CD-ROM file size must be at least 2048 bytes"); throw io_exception("CD-ROM file size must be at least 2048 bytes");
@ -176,12 +171,10 @@ void SCSICD::SetUpModePages(map<int, vector<byte>>& pages, int page, bool change
{ {
Disk::SetUpModePages(pages, page, changeable); Disk::SetUpModePages(pages, page, changeable);
// Page code 13
if (page == 0x0d || page == 0x3f) { if (page == 0x0d || page == 0x3f) {
AddCDROMPage(pages, changeable); AddCDROMPage(pages, changeable);
} }
// Page code 14
if (page == 0x0e || page == 0x3f) { if (page == 0x0e || page == 0x3f) {
AddCDDAPage(pages, changeable); AddCDDAPage(pages, changeable);
} }
@ -226,10 +219,7 @@ int SCSICD::Read(const vector<int>& cdb, vector<uint8_t>& buf, uint64_t block)
{ {
CheckReady(); CheckReady();
// Search for the track
const int index = SearchTrack(static_cast<int>(block)); const int index = SearchTrack(static_cast<int>(block));
// If invalid, out of range
if (index < 0) { if (index < 0) {
throw scsi_exception(sense_key::ILLEGAL_REQUEST, asc::LBA_OUT_OF_RANGE); throw scsi_exception(sense_key::ILLEGAL_REQUEST, asc::LBA_OUT_OF_RANGE);
} }
@ -249,7 +239,6 @@ int SCSICD::Read(const vector<int>& cdb, vector<uint8_t>& buf, uint64_t block)
dataindex = index; dataindex = index;
} }
// Base class
assert(dataindex >= 0); assert(dataindex >= 0);
return Disk::Read(cdb, buf, block); return Disk::Read(cdb, buf, block);
} }
@ -321,7 +310,6 @@ int SCSICD::ReadTocInternal(const vector<int>& cdb, vector<uint8_t>& buf)
int offset = 4; int offset = 4;
// Loop....
for (int i = 0; i < loop; i++) { for (int i = 0; i < loop; i++) {
// ADR and Control // ADR and Control
if (tracks[index]->IsAudio()) { if (tracks[index]->IsAudio()) {
@ -351,11 +339,6 @@ int SCSICD::ReadTocInternal(const vector<int>& cdb, vector<uint8_t>& buf)
return length; return length;
} }
//---------------------------------------------------------------------------
//
// LBA→MSF Conversion
//
//---------------------------------------------------------------------------
void SCSICD::LBAtoMSF(uint32_t lba, uint8_t *msf) const void SCSICD::LBAtoMSF(uint32_t lba, uint8_t *msf) const
{ {
// 75 and 75*60 get the remainder // 75 and 75*60 get the remainder
@ -390,12 +373,6 @@ void SCSICD::ClearTrack()
audioindex = -1; audioindex = -1;
} }
//---------------------------------------------------------------------------
//
// Track Search
// * Returns -1 if not found
//
//---------------------------------------------------------------------------
int SCSICD::SearchTrack(uint32_t lba) const int SCSICD::SearchTrack(uint32_t lba) const
{ {
// Track loop // Track loop

View File

@ -599,7 +599,12 @@ bool PiscsiExecutor::ValidateImageFile(const CommandContext& context, StorageDev
storage_device.SetProtectable(true); storage_device.SetProtectable(true);
} }
try {
storage_device.Open(); storage_device.Open();
}
catch(const io_exception&) {
return context.ReturnLocalizedError(LocalizationKey::ERROR_FILE_OPEN, effective_filename);
}
full_path = effective_filename; full_path = effective_filename;

View File

@ -278,7 +278,7 @@ TEST_F(PiscsiExecutorTest, Attach)
path filename = CreateTempFile(1); path filename = CreateTempFile(1);
SetParam(definition, "file", filename.c_str()); SetParam(definition, "file", filename.c_str());
EXPECT_THROW(executor.Attach(context, definition, false), io_exception) << "Too small image file not rejected"; EXPECT_FALSE(executor.Attach(context, definition, false)) << "Too small image file not rejected";
remove(filename); remove(filename);
filename = CreateTempFile(512); filename = CreateTempFile(512);
@ -359,8 +359,7 @@ TEST_F(PiscsiExecutorTest, Insert)
path filename = CreateTempFile(1); path filename = CreateTempFile(1);
SetParam(definition, "file", filename.c_str()); SetParam(definition, "file", filename.c_str());
EXPECT_THROW(executor.Insert(context, definition, device, false), io_exception) EXPECT_FALSE(executor.Insert(context, definition, device, false)) << "Too small image file not rejected";
<< "Too small image file not rejected";
remove(filename); remove(filename);
filename = CreateTempFile(512); filename = CreateTempFile(512);

View File

@ -95,9 +95,7 @@ TEST(ScsiCdTest, Open)
out.open(filename); out.open(filename);
out.write(header.data(), header.size()); out.write(header.data(), header.size());
out.close(); out.close();
resize_file(filename, 2 * 2535);
cd_raw.SetFilename(string(filename)); cd_raw.SetFilename(string(filename));
EXPECT_THROW(cd_raw.Open(), io_exception) << "Raw ISO CD-ROM image file size must be a multiple of 2536";
resize_file(filename, 2 * 2536); resize_file(filename, 2 * 2536);
cd_raw.Open(); cd_raw.Open();
EXPECT_EQ(2, cd_raw.GetBlockCount()); EXPECT_EQ(2, cd_raw.GetBlockCount());