2007-03-27 17:47:10 +00:00
|
|
|
/*
|
|
|
|
* CiderPress
|
|
|
|
* Copyright (C) 2007 by faddenSoft, LLC. All Rights Reserved.
|
|
|
|
* See the file LICENSE for distribution terms.
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
* ASPI (Advanced SCSI Programming Interface) definitions.
|
|
|
|
*
|
|
|
|
* This may be included directly by an application. It must not be necessary
|
|
|
|
* to include the lower-level headers, e.g. wnaspi32.h.
|
Large set of changes to restore CiderPress build.
CiderPress and MDC now compile, and execute far enough to open
their respective "about" boxes, but I doubt they'll do much
more than that.
* Switch from MBCS to UNICODE APIs
Microsoft switched to UTF-16 (by way of UCS-2) a long time ago,
and the support for MBCS seems to be getting phased out. So it's
time to switch to wide strings.
This is a bit awkward for CiderPress because it works with disk
and file archives with 8-bit filenames, and I want NufxLib and
DiskImgLib to continue to work on Linux (which has largely taken
the UTF-8 approach to Unicode). The libraries will continue to
work with 8-bit filenames, with CiderPress/MDC doing the
conversion at the appropriate point.
There were a couple of places where strings from a structure
handed back by one of the libraries were used directly in the UI,
or vice-versa, which is a problem because we have nowhere to
store the result of the conversion. These currently have fixed
place-holder "xyzzy" strings.
All UI strings are now wide.
Various format strings now use "%ls" and "%hs" to explicitly
specify wide and narrow. This doesn't play well with gcc, so
only the Windows-specific parts use those.
* Various updates to vcxproj files
The project-file conversion had some cruft that is now largely
gone. The build now has a common output directory for the EXEs
and libraries, avoiding the old post-build copy steps.
* Added zlib 1.2.8 and nufxlib 2.2.2 source snapshots
The old "prebuilts" directory is now gone. The libraries are now
built as part of building the apps.
I added a minimal set of files for zlib, and a full set for nufxlib.
The Linux-specific nufxlib goodies are included for the benefit of
the Linux utilities, which are currently broken (don't build).
* Replace symbols used for include guards
Symbols with a leading "__" are reserved.
2014-11-10 15:32:55 -08:00
|
|
|
*
|
|
|
|
* TODO: this was only necessary for older versions of Windows, e.g. Win98,
|
|
|
|
* as a way to access SCSI drives. It's no longer needed.
|
2007-03-27 17:47:10 +00:00
|
|
|
*/
|
|
|
|
#ifndef __ASPI__
|
|
|
|
#define __ASPI__
|
|
|
|
|
Large set of changes to restore CiderPress build.
CiderPress and MDC now compile, and execute far enough to open
their respective "about" boxes, but I doubt they'll do much
more than that.
* Switch from MBCS to UNICODE APIs
Microsoft switched to UTF-16 (by way of UCS-2) a long time ago,
and the support for MBCS seems to be getting phased out. So it's
time to switch to wide strings.
This is a bit awkward for CiderPress because it works with disk
and file archives with 8-bit filenames, and I want NufxLib and
DiskImgLib to continue to work on Linux (which has largely taken
the UTF-8 approach to Unicode). The libraries will continue to
work with 8-bit filenames, with CiderPress/MDC doing the
conversion at the appropriate point.
There were a couple of places where strings from a structure
handed back by one of the libraries were used directly in the UI,
or vice-versa, which is a problem because we have nowhere to
store the result of the conversion. These currently have fixed
place-holder "xyzzy" strings.
All UI strings are now wide.
Various format strings now use "%ls" and "%hs" to explicitly
specify wide and narrow. This doesn't play well with gcc, so
only the Windows-specific parts use those.
* Various updates to vcxproj files
The project-file conversion had some cruft that is now largely
gone. The build now has a common output directory for the EXEs
and libraries, avoiding the old post-build copy steps.
* Added zlib 1.2.8 and nufxlib 2.2.2 source snapshots
The old "prebuilts" directory is now gone. The libraries are now
built as part of building the apps.
I added a minimal set of files for zlib, and a full set for nufxlib.
The Linux-specific nufxlib goodies are included for the benefit of
the Linux utilities, which are currently broken (don't build).
* Replace symbols used for include guards
Symbols with a leading "__" are reserved.
2014-11-10 15:32:55 -08:00
|
|
|
#if !defined(_WIN32) || !defined(WANT_ASPI)
|
2007-03-27 17:47:10 +00:00
|
|
|
/*
|
|
|
|
* Placeholder definition to keep Linux build happy.
|
|
|
|
*/
|
|
|
|
namespace DiskImgLib {
|
|
|
|
class DISKIMG_API ASPI {
|
|
|
|
public:
|
|
|
|
ASPI(void) {}
|
|
|
|
virtual ~ASPI(void) {}
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef __WNASPI32_H__
|
2014-11-03 16:26:53 -08:00
|
|
|
struct SRB_ExecSCSICmd; // fwd
|
2007-03-27 17:47:10 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
namespace DiskImgLib {
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Descriptor for one SCSI device.
|
|
|
|
*/
|
|
|
|
class DISKIMG_API ASPIDevice {
|
|
|
|
public:
|
2014-11-17 21:13:13 -08:00
|
|
|
ASPIDevice(void) : fVendorID(NULL), fProductID(NULL),
|
2014-11-03 16:26:53 -08:00
|
|
|
fAdapter(0xff), fTarget(0xff), fLun(0xff), fDeviceReady(false)
|
|
|
|
{}
|
|
|
|
virtual ~ASPIDevice(void) {
|
|
|
|
delete[] fVendorID;
|
|
|
|
delete[] fProductID;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Init(unsigned char adapter, unsigned char target, unsigned char lun,
|
|
|
|
const unsigned char* vendor, unsigned const char* product,
|
|
|
|
int deviceType, bool ready)
|
|
|
|
{
|
|
|
|
fAdapter = adapter;
|
|
|
|
fTarget = target;
|
|
|
|
fLun = lun;
|
2014-11-17 21:13:13 -08:00
|
|
|
assert(fVendorID == NULL);
|
2014-11-03 16:26:53 -08:00
|
|
|
fVendorID = new char[strlen((const char*)vendor)+1];
|
|
|
|
strcpy(fVendorID, (const char*)vendor);
|
2014-11-17 21:13:13 -08:00
|
|
|
assert(fProductID == NULL);
|
2014-11-03 16:26:53 -08:00
|
|
|
fProductID = new char[strlen((const char*)product)+1];
|
|
|
|
strcpy(fProductID, (const char*)product);
|
|
|
|
fDeviceReady = ready;
|
|
|
|
fDeviceType = deviceType;
|
|
|
|
}
|
|
|
|
|
|
|
|
enum {
|
|
|
|
kTypeDASD = 0, // kScsiDevTypeDASD
|
|
|
|
kTypeCDROM = 5, // kScsiDevTypeCDROM
|
|
|
|
};
|
|
|
|
|
|
|
|
unsigned char GetAdapter(void) const { return fAdapter; }
|
|
|
|
unsigned char GetTarget(void) const { return fTarget; }
|
|
|
|
unsigned char GetLun(void) const { return fLun; }
|
|
|
|
const char* GetVendorID(void) const { return fVendorID; }
|
|
|
|
const char* GetProductID(void) const { return fProductID; }
|
|
|
|
bool GetDeviceReady(void) const { return fDeviceReady; }
|
|
|
|
int GetDeviceType(void) const { return fDeviceType; }
|
2007-03-27 17:47:10 +00:00
|
|
|
|
|
|
|
private:
|
2014-11-03 16:26:53 -08:00
|
|
|
// strings from SCSI inquiry, padded with spaces at end
|
|
|
|
char* fVendorID;
|
|
|
|
char* fProductID;
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-03 16:26:53 -08:00
|
|
|
unsigned char fAdapter; // physical or logical host adapter (0-15)
|
|
|
|
unsigned char fTarget; // SCSI ID on adapter (0-15)
|
|
|
|
unsigned char fLun; // logical unit (0-7)
|
2007-03-27 17:47:10 +00:00
|
|
|
|
2014-11-03 16:26:53 -08:00
|
|
|
int fDeviceType; // e.g. kScsiDevTypeCDROM
|
|
|
|
bool fDeviceReady;
|
2007-03-27 17:47:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* There should be only one instance of this in the library (part of the
|
|
|
|
* DiskImgLib Globals). It wouldn't actually break anything to have more than
|
|
|
|
* one, but there's no need for it.
|
|
|
|
*/
|
|
|
|
class DISKIMG_API ASPI {
|
|
|
|
public:
|
2014-11-03 16:26:53 -08:00
|
|
|
ASPI(void) :
|
2014-11-17 21:13:13 -08:00
|
|
|
fhASPI(NULL),
|
|
|
|
GetASPI32SupportInfo(NULL),
|
|
|
|
SendASPI32Command(NULL),
|
|
|
|
GetASPI32DLLVersion(NULL),
|
2014-11-03 16:26:53 -08:00
|
|
|
fASPIVersion(0),
|
|
|
|
fHostAdapterCount(-1)
|
|
|
|
{}
|
|
|
|
virtual ~ASPI(void);
|
|
|
|
|
|
|
|
// load ASPI DLL if it exists
|
|
|
|
DIError Init(void);
|
|
|
|
|
|
|
|
// return the version returned by the loaded DLL
|
|
|
|
DWORD GetVersion(void) const {
|
2014-11-17 21:13:13 -08:00
|
|
|
assert(fhASPI != NULL);
|
2014-11-03 16:26:53 -08:00
|
|
|
return fASPIVersion;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return an *array* of ASPIDevice structures for drives in system;
|
|
|
|
// the caller is expected to delete[] it when done.
|
|
|
|
enum { kDevMaskCDROM = 0x01, kDevMaskHardDrive = 0x02 };
|
|
|
|
DIError GetAccessibleDevices(int deviceMask, ASPIDevice** ppDeviceArray,
|
|
|
|
int* pNumDevices);
|
|
|
|
|
|
|
|
// Get the type of the device (DTYPE_*, 0x00-0x1f) using ASPI query
|
|
|
|
DIError GetDeviceType(unsigned char adapter, unsigned char target,
|
|
|
|
unsigned char lun, unsigned char* pType);
|
|
|
|
// convert DTYPE_* to a string
|
|
|
|
const char* DeviceTypeToString(unsigned char deviceType);
|
|
|
|
|
|
|
|
// Get the capacity, expressed as the highest-available LBA and the device
|
|
|
|
// block size.
|
|
|
|
DIError GetDeviceCapacity(unsigned char adapter, unsigned char target,
|
|
|
|
unsigned char lun, unsigned long* pLastBlock, unsigned long* pBlockSize);
|
|
|
|
|
|
|
|
// Read blocks from the device.
|
|
|
|
DIError ReadBlocks(unsigned char adapter, unsigned char target,
|
|
|
|
unsigned char lun, long startBlock, short numBlocks, long blockSize,
|
|
|
|
void* buf);
|
|
|
|
|
|
|
|
// Write blocks to the device.
|
|
|
|
DIError WriteBlocks(unsigned char adapter, unsigned char target,
|
|
|
|
unsigned char lun, long startBlock, short numBlocks, long blockSize,
|
|
|
|
const void* buf);
|
2007-03-27 17:47:10 +00:00
|
|
|
|
|
|
|
private:
|
2014-11-03 16:26:53 -08:00
|
|
|
/*
|
|
|
|
* The interesting bits that come out of an SC_HA_INQUIRY request.
|
|
|
|
*/
|
|
|
|
typedef struct AdapterInfo {
|
|
|
|
unsigned char adapterScsiID; // SCSI ID of the adapter itself
|
|
|
|
unsigned char managerID[16+1]; // string describing manager
|
|
|
|
unsigned char identifier[16+1]; // string describing host adapter
|
|
|
|
unsigned char maxTargets; // max #of targets on this adapter
|
|
|
|
unsigned short bufferAlignment; // buffer alignment requirement
|
|
|
|
} AdapterInfo;
|
|
|
|
/*
|
|
|
|
* The interesting bits from a SCSI device INQUIRY command.
|
|
|
|
*/
|
|
|
|
typedef struct Inquiry {
|
|
|
|
unsigned char vendorID[8+1]; // vendor ID string
|
|
|
|
unsigned char productID[16+1]; // product ID string
|
|
|
|
unsigned char productRevision[4]; // product revision bytes
|
|
|
|
} Inquiry;
|
|
|
|
|
|
|
|
// Issue an ASPI adapter inquiry request.
|
|
|
|
DIError HostAdapterInquiry(unsigned char adapter,
|
|
|
|
AdapterInfo* pAdapterInfo);
|
|
|
|
// Issue a SCSI device inquiry request.
|
|
|
|
DIError DeviceInquiry(unsigned char adapter, unsigned char target,
|
|
|
|
unsigned char lun, Inquiry* pInquiry);
|
|
|
|
// Issue a SCSI test unit ready request.
|
|
|
|
DIError TestUnitReady(unsigned char adapter, unsigned char target,
|
|
|
|
unsigned char lun, bool* pReady);
|
|
|
|
// execute a SCSI command
|
|
|
|
DIError ExecSCSICommand(SRB_ExecSCSICmd* pSRB);
|
|
|
|
|
|
|
|
|
|
|
|
enum {
|
|
|
|
kMaxAdapters = 16,
|
|
|
|
kMaxTargets = 16,
|
|
|
|
kMaxLuns = 8,
|
|
|
|
kTimeout = 30, // timeout, in seconds
|
|
|
|
kMaxAccessibleDrives = 16,
|
|
|
|
};
|
|
|
|
|
|
|
|
HMODULE fhASPI;
|
|
|
|
DWORD (*GetASPI32SupportInfo)(void);
|
|
|
|
DWORD (*SendASPI32Command)(void* lpsrb);
|
|
|
|
DWORD (*GetASPI32DLLVersion)(void);
|
|
|
|
DWORD fASPIVersion;
|
|
|
|
int fHostAdapterCount;
|
2007-03-27 17:47:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}; // namespace DiskImgLib
|
|
|
|
|
|
|
|
#endif /*__ASPI__*/
|
|
|
|
|
|
|
|
#endif /*_WIN32*/
|