3 Internal definitions for the LSI 53C895A SCSI driver, which produces
4 Extended SCSI Pass Thru Protocol instances for LSI 53C895A SCSI devices.
6 Copyright (C) 2020, SUSE LLC.
8 SPDX-License-Identifier: BSD-2-Clause-Patent
12 #ifndef _LSI_SCSI_DXE_H_
13 #define _LSI_SCSI_DXE_H_
17 // Allocate 32 UINT32 entries for the script and it's sufficient for
22 // The max size of CDB is 32.
26 // Allocate 64KB for read/write buffer. It seems sufficient for the common
29 // NOTE: The number of bytes for data transmission is bounded by DMA Byte
30 // Count (DBC), a 24-bit register, so the maximum is 0xFFFFFF (16MB-1).
32 UINT8 Data
[SIZE_64KB
];
34 // For SCSI Message In phase
38 // For SCSI Message Out phase
42 // For SCSI Status phase
45 } LSI_SCSI_DMA_BUFFER
;
51 EFI_PCI_IO_PROTOCOL
*PciIo
;
54 UINT32 StallPerPollUsec
;
55 LSI_SCSI_DMA_BUFFER
*Dma
;
56 EFI_PHYSICAL_ADDRESS DmaPhysical
;
58 EFI_EXT_SCSI_PASS_THRU_MODE PassThruMode
;
59 EFI_EXT_SCSI_PASS_THRU_PROTOCOL PassThru
;
62 #define LSI_SCSI_DEV_SIGNATURE SIGNATURE_32 ('L','S','I','S')
64 #define LSI_SCSI_FROM_PASS_THRU(PassThruPtr) \
65 CR (PassThruPtr, LSI_SCSI_DEV, PassThru, LSI_SCSI_DEV_SIGNATURE)
67 #define LSI_SCSI_DMA_ADDR(Dev, MemberName) \
68 ((UINT32)(Dev->DmaPhysical + OFFSET_OF (LSI_SCSI_DMA_BUFFER, MemberName)))
72 // Probe, start and stop functions of this driver, called by the DXE core for
75 // The following specifications document these interfaces:
76 // - Driver Writer's Guide for UEFI 2.3.1 v1.01, 9 Driver Binding Protocol
77 // - UEFI Spec 2.3.1 + Errata C, 10.1 EFI Driver Binding Protocol
82 LsiScsiControllerSupported (
83 IN EFI_DRIVER_BINDING_PROTOCOL
*This
,
84 IN EFI_HANDLE ControllerHandle
,
85 IN EFI_DEVICE_PATH_PROTOCOL
*RemainingDevicePath OPTIONAL
90 LsiScsiControllerStart (
91 IN EFI_DRIVER_BINDING_PROTOCOL
*This
,
92 IN EFI_HANDLE ControllerHandle
,
93 IN EFI_DEVICE_PATH_PROTOCOL
*RemainingDevicePath OPTIONAL
98 LsiScsiControllerStop (
99 IN EFI_DRIVER_BINDING_PROTOCOL
*This
,
100 IN EFI_HANDLE ControllerHandle
,
101 IN UINTN NumberOfChildren
,
102 IN EFI_HANDLE
*ChildHandleBuffer
107 // The next seven functions implement EFI_EXT_SCSI_PASS_THRU_PROTOCOL
108 // for the LSI 53C895A SCSI Controller. Refer to UEFI Spec 2.3.1 + Errata C,
110 // - 14.1 SCSI Driver Model Overview,
111 // - 14.7 Extended SCSI Pass Thru Protocol.
117 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL
*This
,
120 IN OUT EFI_EXT_SCSI_PASS_THRU_SCSI_REQUEST_PACKET
*Packet
,
121 IN EFI_EVENT Event OPTIONAL
126 LsiScsiGetNextTargetLun (
127 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL
*This
,
128 IN OUT UINT8
**TargetPointer
,
134 LsiScsiBuildDevicePath (
135 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL
*This
,
138 IN OUT EFI_DEVICE_PATH_PROTOCOL
**DevicePath
143 LsiScsiGetTargetLun (
144 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL
*This
,
145 IN EFI_DEVICE_PATH_PROTOCOL
*DevicePath
,
146 OUT UINT8
**TargetPointer
,
152 LsiScsiResetChannel (
153 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL
*This
158 LsiScsiResetTargetLun (
159 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL
*This
,
166 LsiScsiGetNextTarget (
167 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL
*This
,
168 IN OUT UINT8
**TargetPointer
173 // The purpose of the following scaffolding (EFI_COMPONENT_NAME_PROTOCOL and
174 // EFI_COMPONENT_NAME2_PROTOCOL implementation) is to format the driver's name
175 // in English, for display on standard console devices. This is recommended for
176 // UEFI drivers that follow the UEFI Driver Model. Refer to the Driver Writer's
177 // Guide for UEFI 2.3.1 v1.01, 11 UEFI Driver and Controller Names.
179 // Device type names ("LSI 53C895A SCSI Controller") are not formatted because
180 // the driver supports only that device type. Therefore the driver name
181 // suffices for unambiguous identification.
186 LsiScsiGetDriverName (
187 IN EFI_COMPONENT_NAME_PROTOCOL
*This
,
189 OUT CHAR16
**DriverName
194 LsiScsiGetDeviceName (
195 IN EFI_COMPONENT_NAME_PROTOCOL
*This
,
196 IN EFI_HANDLE DeviceHandle
,
197 IN EFI_HANDLE ChildHandle
,
199 OUT CHAR16
**ControllerName
202 #endif // _LSI_SCSI_DXE_H_