mirror of
https://github.com/open-simh/simtools.git
synced 2026-02-28 17:20:29 +00:00
Too much to list all, but includes (in no particular order): - Cleanup for 64-bit builds, MSVC warnings. - Structured help - Help file compiler. - Supports volsets, writes/create work. - Support for I18n in messages, help. - Makefiles. - Initialize volume/volset - Command line editing/history Builds and works on Linux and Windows (VS). Not recently built or tested on other platforms, but not intentinonally broken.
392 lines
9.3 KiB
C
392 lines
9.3 KiB
C
/*
|
|
* This is distributed as part of ODS2, originally written by
|
|
* Paul Nankervis, email address: Paulnank@au1.ibm.com
|
|
*
|
|
* ODS2 is distributed freely for all members of the
|
|
* VMS community to use. However all derived works
|
|
* must maintain comments in their source to acknowledge
|
|
* the contributions of the original author and
|
|
* subsequent contributors. This is free software; no
|
|
* warranty is offered, and while we believe it to be useful,
|
|
* you use it at your own risk.
|
|
*/
|
|
|
|
//
|
|
|
|
// Name: WNASPI32.H
|
|
|
|
//
|
|
|
|
// Description: ASPI for Win32 definitions ('C' Language)
|
|
|
|
//
|
|
|
|
//***************************************************************************
|
|
|
|
#ifndef _WNASPI32_H
|
|
#define _WNASPI32_H
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef void *LPSRB;
|
|
|
|
typedef void (*PFNPOST)();
|
|
|
|
|
|
|
|
DWORD SendASPI32Command (LPSRB);
|
|
|
|
DWORD GetASPI32SupportInfo (VOID);
|
|
|
|
|
|
|
|
#define SENSE_LEN 14 // Default sense buffer length
|
|
|
|
#define SRB_DIR_IN 0x08 // Transfer from SCSI target to
|
|
|
|
// host
|
|
|
|
#define SRB_DIR_OUT 0x10 // Transfer from host to SCSI
|
|
|
|
// target
|
|
|
|
#define SRB_POSTING 0x01 // Enable ASPI posting
|
|
|
|
#define SRB_EVENT_NOTIFY 0x40 // Enable ASPI event notification
|
|
|
|
#define SRB_ENABLE_RESIDUAL_COUNT 0x04 // Enable residual byte count
|
|
|
|
// reporting
|
|
|
|
#define SRB_DATA_SG_LIST 0x02 // Data buffer points to
|
|
|
|
// scatter-gather list
|
|
|
|
#define WM_ASPIPOST 0x4D42 // ASPI Post message
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% ASPI Command Definitions %%%
|
|
|
|
//***************************************************************************
|
|
|
|
#define SC_HA_INQUIRY 0x00 // Host adapter inquiry
|
|
|
|
#define SC_GET_DEV_TYPE 0x01 // Get device type
|
|
|
|
#define SC_EXEC_SCSI_CMD 0x02 // Execute SCSI command
|
|
|
|
#define SC_ABORT_SRB 0x03 // Abort an SRB
|
|
|
|
#define SC_RESET_DEV 0x04 // SCSI bus device reset
|
|
|
|
#define SC_GET_DISK_INFO 0x06 // Get Disk information
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% SRB Status %%%
|
|
|
|
//***************************************************************************
|
|
|
|
#define SS_PENDING 0x00 // SRB being processed
|
|
|
|
#define SS_COMP 0x01 // SRB completed without error
|
|
|
|
#define SS_ABORTED 0x02 // SRB aborted
|
|
|
|
#define SS_ABORT_FAIL 0x03 // Unable to abort SRB
|
|
|
|
#define SS_ERR 0x04 // SRB completed with error
|
|
|
|
|
|
|
|
#define SS_INVALID_CMD 0x80 // Invalid ASPI command
|
|
|
|
#define SS_INVALID_HA 0x81 // Invalid host adapter number
|
|
|
|
#define SS_NO_DEVICE 0x82 // SCSI device not installed
|
|
|
|
#define SS_INVALID_SRB 0xE0 // Invalid parameter set in SRB
|
|
|
|
#define SS_BUFFER_ALIGN 0xE1 // Buffer alignment problem
|
|
|
|
#define SS_SECURITY_VIOLATION 0xE2 // Device access security violation
|
|
|
|
#define SS_FAILED_INIT 0xE4 // ASPI for windows failed init
|
|
|
|
#define SS_BUFFER_TO_BIG 0xE6 // Buffer size too big to handle!
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% Host Adapter Status %%%
|
|
|
|
//***************************************************************************
|
|
|
|
#define HASTAT_OK 0x00 // Host adapter did not detect an
|
|
|
|
// error
|
|
|
|
#define HASTAT_SEL_TO 0x11 // Selection Timeout
|
|
|
|
#define HASTAT_DO_DU 0x12 // Data overrun data underrun
|
|
|
|
#define HASTAT_BUS_FREE 0x13 // Unexpected bus free
|
|
|
|
#define HASTAT_PHASE_ERR 0x14 // Target bus phase sequence
|
|
|
|
// failure
|
|
|
|
#define HASTAT_TIMEOUT 0x09 // Timed out while SRB was
|
|
|
|
// waiting to beprocessed.
|
|
|
|
#define HASTAT_COMMAND_TIMEOUT 0x0B // While processing the SRB, the
|
|
|
|
// adapter timed out.
|
|
|
|
#define HASTAT_MESSAGE_REJECT 0x0D // While processing SRB, the
|
|
|
|
// adapter received a MESSAGE
|
|
|
|
// REJECT.
|
|
|
|
#define HASTAT_BUS_RESET 0x0E // A bus reset was detected.
|
|
|
|
#define HASTAT_PARITY_ERROR 0x0F // A parity error was detected.
|
|
|
|
#define HASTAT_REQUEST_SENSE_FAILED 0x10 // The adapter failed in issuing
|
|
|
|
// REQUEST SENSE.
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% SRB - HOST ADAPTER INQUIRY - SC_HA_INQUIRY %%%
|
|
|
|
//***************************************************************************
|
|
|
|
typedef struct {
|
|
|
|
BYTE SRB_Cmd; // ASPI command code = SC_HA_INQUIRY
|
|
|
|
BYTE SRB_Status; // ASPI command status byte
|
|
|
|
BYTE SRB_HaId; // ASPI host adapter number
|
|
|
|
BYTE SRB_Flags; // ASPI request flags
|
|
|
|
DWORD SRB_Hdr_Rsvd; // Reserved, MUST = 0
|
|
|
|
BYTE HA_Count; // Number of host adapters present
|
|
|
|
BYTE HA_SCSI_ID; // SCSI ID of host adapter
|
|
|
|
BYTE HA_ManagerId[16]; // String describing the manager
|
|
|
|
BYTE HA_Identifier[16]; // String describing the host adapter
|
|
|
|
BYTE HA_Unique[16]; // Host Adapter Unique parameters
|
|
|
|
WORD HA_Rsvd1;
|
|
|
|
} SRB_HAInquiry, *PSRB_HAInquiry;
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% SRB - GET DEVICE TYPE - SC_GET_DEV_TYPE %%%
|
|
|
|
//***************************************************************************
|
|
|
|
typedef struct {
|
|
|
|
BYTE SRB_Cmd; // ASPI command code = SC_GET_DEV_TYPE
|
|
|
|
BYTE SRB_Status; // ASPI command status byte
|
|
|
|
BYTE SRB_HaId; // ASPI host adapter number
|
|
|
|
BYTE SRB_Flags; // Reserved
|
|
|
|
DWORD SRB_Hdr_Rsvd; // Reserved
|
|
|
|
BYTE SRB_Target; // Target's SCSI ID
|
|
|
|
BYTE SRB_Lun; // Target's LUN number
|
|
|
|
BYTE SRB_DeviceType; // Target's peripheral device type
|
|
|
|
BYTE SRB_Rsvd1;
|
|
|
|
} SRB_GDEVBlock, *PSRB_GDEVBlock;
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% SRB - EXECUTE SCSI COMMAND - SC_EXEC_SCSI_CMD %%%
|
|
|
|
//***************************************************************************
|
|
|
|
typedef struct {
|
|
|
|
BYTE SRB_Cmd; // ASPI command code = SC_EXEC_SCSI_CMD
|
|
|
|
BYTE SRB_Status; // ASPI command status byte
|
|
|
|
BYTE SRB_HaId; // ASPI host adapter number
|
|
|
|
BYTE SRB_Flags; // ASPI request flags
|
|
|
|
DWORD SRB_Hdr_Rsvd; // Reserved
|
|
|
|
BYTE SRB_Target; // Target's SCSI ID
|
|
|
|
BYTE SRB_Lun; // Target's LUN number
|
|
|
|
WORD SRB_Rsvd1; // Reserved for Alignment
|
|
|
|
DWORD SRB_BufLen; // Data Allocation Length
|
|
|
|
BYTE *SRB_BufPointer; // Data Buffer Pointer
|
|
|
|
BYTE SRB_SenseLen; // Sense Allocation Length
|
|
|
|
BYTE SRB_CDBLen; // CDB Length
|
|
|
|
BYTE SRB_HaStat; // Host Adapter Status
|
|
|
|
BYTE SRB_TargStat; // Target Status
|
|
|
|
void (*SRB_PostProc)(); // Post routine
|
|
|
|
void *SRB_Rsvd2; // Reserved
|
|
|
|
BYTE SRB_Rsvd3[16]; // Reserved for alignment
|
|
|
|
BYTE CDBByte[16]; // SCSI CDB
|
|
|
|
BYTE SenseArea[SENSE_LEN+2]; // Request Sense buffer
|
|
|
|
} SRB_ExecSCSICmd, *PSRB_ExecSCSICmd;
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% SRB - ABORT AN SRB - SC_ABORT_SRB %%%
|
|
|
|
//***************************************************************************
|
|
|
|
typedef struct {
|
|
|
|
BYTE SRB_Cmd; // ASPI command code = SC_EXEC_SCSI_CMD
|
|
|
|
BYTE SRB_Status; // ASPI command status byte
|
|
|
|
BYTE SRB_HaId; // ASPI host adapter number
|
|
|
|
BYTE SRB_Flags; // Reserved
|
|
|
|
DWORD SRB_Hdr_Rsvd; // Reserved
|
|
|
|
void *SRB_ToAbort; // Pointer to SRB to abort
|
|
|
|
} SRB_Abort, *PSRB_Abort;
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% SRB - BUS DEVICE RESET - SC_RESET_DEV %%%
|
|
|
|
//***************************************************************************
|
|
|
|
typedef struct {
|
|
|
|
BYTE SRB_Cmd; // ASPI command code = SC_EXEC_SCSI_CMD
|
|
|
|
BYTE SRB_Status; // ASPI command status byte
|
|
|
|
BYTE SRB_HaId; // ASPI host adapter number
|
|
|
|
BYTE SRB_Flags; // Reserved
|
|
|
|
DWORD SRB_Hdr_Rsvd; // Reserved
|
|
|
|
BYTE SRB_Target; // Target's SCSI ID
|
|
|
|
BYTE SRB_Lun; // Target's LUN number
|
|
|
|
BYTE SRB_Rsvd1[12]; // Reserved for Alignment
|
|
|
|
BYTE SRB_HaStat; // Host Adapter Status
|
|
|
|
BYTE SRB_TargStat; // Target Status
|
|
|
|
void (*SRB_PostProc)(); // Post routine
|
|
|
|
void *SRB_Rsvd2; // Reserved
|
|
|
|
BYTE SRB_Rsvd3[32]; // Reserved
|
|
|
|
} SRB_BusDeviceReset, *PSRB_BusDeviceReset;
|
|
|
|
|
|
|
|
//***************************************************************************
|
|
|
|
// %%% SRB - GET DISK INFORMATION - SC_GET_DISK_INFO %%%
|
|
|
|
//***************************************************************************
|
|
|
|
typedef struct {
|
|
|
|
BYTE SRB_Cmd; // ASPI command code = SC_EXEC_SCSI_CMD
|
|
|
|
BYTE SRB_Status; // ASPI command status byte
|
|
|
|
BYTE SRB_HaId; // ASPI host adapter number
|
|
|
|
BYTE SRB_Flags; // Reserved
|
|
|
|
DWORD SRB_Hdr_Rsvd; // Reserved
|
|
|
|
BYTE SRB_Target; // Target's SCSI ID
|
|
|
|
BYTE SRB_Lun; // Target's LUN number
|
|
|
|
BYTE SRB_DriveFlags; // Driver flags
|
|
|
|
BYTE SRB_Int13HDriveInfo; // Host Adapter Status
|
|
|
|
BYTE SRB_Heads; // Preferred number of heads translation
|
|
|
|
BYTE SRB_Sectors; // Preferred number of sectors translation
|
|
|
|
BYTE SRB_Rsvd1[10]; // Reserved
|
|
|
|
} SRB_GetDiskInfo, *PSRB_GetDiskInfo;
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif /* #ifndef _WNASPI32_H */
|