mirror of
https://github.com/akuker/RASCSI.git
synced 2025-01-03 01:33:14 +00:00
Apple Mode Page support for SCHD & SCCD (#835)
Co-authored-by: Troy <jokker@gmail.com>
This commit is contained in:
parent
05db0e4688
commit
a56aae6d78
@ -81,3 +81,24 @@ void scsi_command_util::EnrichFormatPage(map<int, vector<BYTE>>& pages, bool cha
|
|||||||
format_page[13] = sector_size;
|
format_page[13] = sector_size;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// Add Vendor special page to make drive Apple compatible
|
||||||
|
//
|
||||||
|
//---------------------------------------------------------------------------
|
||||||
|
void scsi_command_util::AddAppleVendorModePage(map<int, vector<BYTE>>& pages, int page, bool changeable)
|
||||||
|
{
|
||||||
|
// Page code 48 (30h) - Apple Vendor Mode Page
|
||||||
|
// Needed for SCCD for stock Apple driver support
|
||||||
|
// Needed for SCHD for stock Apple HD SC Setup
|
||||||
|
vector<BYTE> buf(30);
|
||||||
|
|
||||||
|
// No changeable area
|
||||||
|
if (!changeable) {
|
||||||
|
BYTE apple_data[] = "APPLE COMPUTER, INC ";
|
||||||
|
memcpy(&buf[2], apple_data, sizeof(apple_data));
|
||||||
|
}
|
||||||
|
|
||||||
|
pages[0x30] = buf;
|
||||||
|
}
|
||||||
|
@ -21,4 +21,6 @@ namespace scsi_command_util
|
|||||||
{
|
{
|
||||||
void ModeSelect(const DWORD *, const BYTE *, int, int);
|
void ModeSelect(const DWORD *, const BYTE *, int, int);
|
||||||
void EnrichFormatPage(map<int, vector<BYTE>>&, bool, int);
|
void EnrichFormatPage(map<int, vector<BYTE>>&, bool, int);
|
||||||
|
|
||||||
|
void AddAppleVendorModePage(map<int, vector<BYTE>>&, int, bool);
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,8 @@
|
|||||||
#include "scsicd.h"
|
#include "scsicd.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "rascsi_exceptions.h"
|
#include "rascsi_exceptions.h"
|
||||||
|
#include "scsi_command_util.h"
|
||||||
|
|
||||||
|
|
||||||
using namespace scsi_defs;
|
using namespace scsi_defs;
|
||||||
|
|
||||||
@ -415,6 +417,15 @@ void SCSICD::AddCDDAPage(map<int, vector<BYTE>>& pages, bool) const
|
|||||||
pages[14] = buf;
|
pages[14] = buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SCSICD::AddVendorPage(map<int, vector<BYTE>>& pages, int page, bool changeable) const
|
||||||
|
{
|
||||||
|
// Page code 48
|
||||||
|
if (page == 0x30 || page == 0x3f) {
|
||||||
|
scsi_command_util::AddAppleVendorModePage(pages, page, changeable);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int SCSICD::Read(const DWORD *cdb, BYTE *buf, uint64_t block)
|
int SCSICD::Read(const DWORD *cdb, BYTE *buf, uint64_t block)
|
||||||
{
|
{
|
||||||
assert(buf);
|
assert(buf);
|
||||||
|
@ -86,6 +86,7 @@ public:
|
|||||||
protected:
|
protected:
|
||||||
|
|
||||||
void AddModePages(map<int, vector<BYTE>>&, int, bool) const override;
|
void AddModePages(map<int, vector<BYTE>>&, int, bool) const override;
|
||||||
|
void AddVendorPage(map<int, vector<BYTE>>&, int, bool) const override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
using super = Disk;
|
using super = Disk;
|
||||||
|
@ -110,24 +110,10 @@ void SCSIHD::AddFormatPage(map<int, vector<BYTE>>& pages, bool changeable) const
|
|||||||
scsi_command_util::EnrichFormatPage(pages, changeable, 1 << GetSectorSizeShiftCount());
|
scsi_command_util::EnrichFormatPage(pages, changeable, 1 << GetSectorSizeShiftCount());
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
// Add Vendor special page to make drive Apple compatible
|
|
||||||
//
|
|
||||||
//---------------------------------------------------------------------------
|
|
||||||
void SCSIHD::AddVendorPage(map<int, vector<BYTE>>& pages, int page, bool changeable) const
|
void SCSIHD::AddVendorPage(map<int, vector<BYTE>>& pages, int page, bool changeable) const
|
||||||
{
|
{
|
||||||
// Page code 48
|
// Page code 48
|
||||||
if (page != 0x30 && page != 0x3f) {
|
if (page == 0x30 || page == 0x3f) {
|
||||||
return;
|
scsi_command_util::AddAppleVendorModePage(pages, page, changeable);
|
||||||
}
|
}
|
||||||
|
|
||||||
vector<BYTE> buf(30);
|
|
||||||
|
|
||||||
// No changeable area
|
|
||||||
if (!changeable) {
|
|
||||||
memcpy(&buf[0xa], "APPLE COMPUTER, INC.", 20);
|
|
||||||
}
|
|
||||||
|
|
||||||
pages[48] = buf;
|
|
||||||
}
|
}
|
||||||
|
@ -72,13 +72,14 @@ TEST(ModePagesTest, SCSICD_AddModePages)
|
|||||||
MockSCSICD device(sector_sizes);
|
MockSCSICD device(sector_sizes);
|
||||||
device.AddModePages(mode_pages, 0x3f, false);
|
device.AddModePages(mode_pages, 0x3f, false);
|
||||||
|
|
||||||
EXPECT_EQ(6, mode_pages.size()) << "Unexpected number of code pages";
|
EXPECT_EQ(7, mode_pages.size()) << "Unexpected number of code pages";
|
||||||
EXPECT_EQ(12, mode_pages[1].size());
|
EXPECT_EQ(12, mode_pages[1].size());
|
||||||
EXPECT_EQ(24, mode_pages[3].size());
|
EXPECT_EQ(24, mode_pages[3].size());
|
||||||
EXPECT_EQ(24, mode_pages[4].size());
|
EXPECT_EQ(24, mode_pages[4].size());
|
||||||
EXPECT_EQ(12, mode_pages[8].size());
|
EXPECT_EQ(12, mode_pages[8].size());
|
||||||
EXPECT_EQ(8, mode_pages[13].size());
|
EXPECT_EQ(8, mode_pages[13].size());
|
||||||
EXPECT_EQ(16, mode_pages[14].size());
|
EXPECT_EQ(16, mode_pages[14].size());
|
||||||
|
EXPECT_EQ(30, mode_pages[48].size());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(ModePagesTest, SCSIMO_AddModePages)
|
TEST(ModePagesTest, SCSIMO_AddModePages)
|
||||||
|
Loading…
Reference in New Issue
Block a user