mirror of
https://github.com/akuker/RASCSI.git
synced 2025-01-03 17:29:37 +00:00
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:
parent
139a6ec371
commit
b6941c9e81
@ -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
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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());
|
||||||
|
Loading…
Reference in New Issue
Block a user