]> git.proxmox.com Git - mirror_edk2.git/blame - OvmfPkg/LsiScsiDxe/LsiScsi.h
OvmfPkg/LsiScsiDxe: Process the SCSI Request Packet
[mirror_edk2.git] / OvmfPkg / LsiScsiDxe / LsiScsi.h
CommitLineData
5e6b870a
GL
1/** @file\r
2\r
3 Internal definitions for the LSI 53C895A SCSI driver, which produces\r
4 Extended SCSI Pass Thru Protocol instances for LSI 53C895A SCSI devices.\r
5\r
6 Copyright (C) 2020, SUSE LLC.\r
7\r
8 SPDX-License-Identifier: BSD-2-Clause-Patent\r
9\r
10**/\r
11\r
12#ifndef _LSI_SCSI_DXE_H_\r
13#define _LSI_SCSI_DXE_H_\r
14\r
f1d6c1eb 15typedef struct {\r
31830b07
GL
16 //\r
17 // Allocate 32 UINT32 entries for the script and it's sufficient for\r
18 // 16 instructions.\r
19 //\r
20 UINT32 Script[32];\r
97e60818
GL
21 //\r
22 // The max size of CDB is 32.\r
23 //\r
24 UINT8 Cdb[32];\r
f1d6c1eb
GL
25 //\r
26 // Allocate 64KB for read/write buffer. It seems sufficient for the common\r
27 // boot scenarios.\r
28 //\r
29 // NOTE: The number of bytes for data transmission is bounded by DMA Byte\r
30 // Count (DBC), a 24-bit register, so the maximum is 0xFFFFFF (16MB-1).\r
31 //\r
32 UINT8 Data[SIZE_64KB];\r
31830b07
GL
33 //\r
34 // For SCSI Message In phase\r
35 //\r
36 UINT8 MsgIn[2];\r
37 //\r
38 // For SCSI Message Out phase\r
39 //\r
40 UINT8 MsgOut;\r
41 //\r
42 // For SCSI Status phase\r
43 //\r
44 UINT8 Status;\r
f1d6c1eb
GL
45} LSI_SCSI_DMA_BUFFER;\r
46\r
23d982e2
GL
47typedef struct {\r
48 UINT32 Signature;\r
8d619390
GL
49 UINT64 OrigPciAttrs;\r
50 EFI_EVENT ExitBoot;\r
51 EFI_PCI_IO_PROTOCOL *PciIo;\r
12d99b8f
GL
52 UINT8 MaxTarget;\r
53 UINT8 MaxLun;\r
31830b07 54 UINT32 StallPerPollUsec;\r
f1d6c1eb
GL
55 LSI_SCSI_DMA_BUFFER *Dma;\r
56 EFI_PHYSICAL_ADDRESS DmaPhysical;\r
57 VOID *DmaMapping;\r
23d982e2
GL
58 EFI_EXT_SCSI_PASS_THRU_MODE PassThruMode;\r
59 EFI_EXT_SCSI_PASS_THRU_PROTOCOL PassThru;\r
60} LSI_SCSI_DEV;\r
61\r
62#define LSI_SCSI_DEV_SIGNATURE SIGNATURE_32 ('L','S','I','S')\r
63\r
64#define LSI_SCSI_FROM_PASS_THRU(PassThruPtr) \\r
65 CR (PassThruPtr, LSI_SCSI_DEV, PassThru, LSI_SCSI_DEV_SIGNATURE)\r
66\r
31830b07
GL
67#define LSI_SCSI_DMA_ADDR(Dev, MemberName) \\r
68 ((UINT32)(Dev->DmaPhysical + OFFSET_OF (LSI_SCSI_DMA_BUFFER, MemberName)))\r
69\r
23d982e2 70\r
5e6b870a
GL
71//\r
72// Probe, start and stop functions of this driver, called by the DXE core for\r
73// specific devices.\r
74//\r
75// The following specifications document these interfaces:\r
76// - Driver Writer's Guide for UEFI 2.3.1 v1.01, 9 Driver Binding Protocol\r
77// - UEFI Spec 2.3.1 + Errata C, 10.1 EFI Driver Binding Protocol\r
78//\r
79\r
80EFI_STATUS\r
81EFIAPI\r
82LsiScsiControllerSupported (\r
83 IN EFI_DRIVER_BINDING_PROTOCOL *This,\r
84 IN EFI_HANDLE ControllerHandle,\r
85 IN EFI_DEVICE_PATH_PROTOCOL *RemainingDevicePath OPTIONAL\r
86 );\r
87\r
88EFI_STATUS\r
89EFIAPI\r
90LsiScsiControllerStart (\r
91 IN EFI_DRIVER_BINDING_PROTOCOL *This,\r
92 IN EFI_HANDLE ControllerHandle,\r
93 IN EFI_DEVICE_PATH_PROTOCOL *RemainingDevicePath OPTIONAL\r
94 );\r
95\r
96EFI_STATUS\r
97EFIAPI\r
98LsiScsiControllerStop (\r
99 IN EFI_DRIVER_BINDING_PROTOCOL *This,\r
100 IN EFI_HANDLE ControllerHandle,\r
101 IN UINTN NumberOfChildren,\r
102 IN EFI_HANDLE *ChildHandleBuffer\r
103 );\r
104\r
386ca8ab 105\r
23d982e2
GL
106//\r
107// The next seven functions implement EFI_EXT_SCSI_PASS_THRU_PROTOCOL\r
108// for the LSI 53C895A SCSI Controller. Refer to UEFI Spec 2.3.1 + Errata C,\r
109// sections\r
110// - 14.1 SCSI Driver Model Overview,\r
111// - 14.7 Extended SCSI Pass Thru Protocol.\r
112//\r
113\r
114EFI_STATUS\r
115EFIAPI\r
116LsiScsiPassThru (\r
117 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL *This,\r
118 IN UINT8 *Target,\r
119 IN UINT64 Lun,\r
120 IN OUT EFI_EXT_SCSI_PASS_THRU_SCSI_REQUEST_PACKET *Packet,\r
121 IN EFI_EVENT Event OPTIONAL\r
122 );\r
123\r
124EFI_STATUS\r
125EFIAPI\r
126LsiScsiGetNextTargetLun (\r
127 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL *This,\r
128 IN OUT UINT8 **TargetPointer,\r
129 IN OUT UINT64 *Lun\r
130 );\r
131\r
132EFI_STATUS\r
133EFIAPI\r
134LsiScsiBuildDevicePath (\r
135 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL *This,\r
136 IN UINT8 *Target,\r
137 IN UINT64 Lun,\r
138 IN OUT EFI_DEVICE_PATH_PROTOCOL **DevicePath\r
139 );\r
140\r
141EFI_STATUS\r
142EFIAPI\r
143LsiScsiGetTargetLun (\r
144 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL *This,\r
145 IN EFI_DEVICE_PATH_PROTOCOL *DevicePath,\r
146 OUT UINT8 **TargetPointer,\r
147 OUT UINT64 *Lun\r
148 );\r
149\r
150EFI_STATUS\r
151EFIAPI\r
152LsiScsiResetChannel (\r
153 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL *This\r
154 );\r
155\r
156EFI_STATUS\r
157EFIAPI\r
158LsiScsiResetTargetLun (\r
159 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL *This,\r
160 IN UINT8 *Target,\r
161 IN UINT64 Lun\r
162 );\r
163\r
164EFI_STATUS\r
165EFIAPI\r
166LsiScsiGetNextTarget (\r
167 IN EFI_EXT_SCSI_PASS_THRU_PROTOCOL *This,\r
168 IN OUT UINT8 **TargetPointer\r
169 );\r
170\r
171\r
386ca8ab
GL
172//\r
173// The purpose of the following scaffolding (EFI_COMPONENT_NAME_PROTOCOL and\r
174// EFI_COMPONENT_NAME2_PROTOCOL implementation) is to format the driver's name\r
175// in English, for display on standard console devices. This is recommended for\r
176// UEFI drivers that follow the UEFI Driver Model. Refer to the Driver Writer's\r
177// Guide for UEFI 2.3.1 v1.01, 11 UEFI Driver and Controller Names.\r
178//\r
179// Device type names ("LSI 53C895A SCSI Controller") are not formatted because\r
180// the driver supports only that device type. Therefore the driver name\r
181// suffices for unambiguous identification.\r
182//\r
183\r
184EFI_STATUS\r
185EFIAPI\r
186LsiScsiGetDriverName (\r
187 IN EFI_COMPONENT_NAME_PROTOCOL *This,\r
188 IN CHAR8 *Language,\r
189 OUT CHAR16 **DriverName\r
190 );\r
191\r
192EFI_STATUS\r
193EFIAPI\r
194LsiScsiGetDeviceName (\r
195 IN EFI_COMPONENT_NAME_PROTOCOL *This,\r
196 IN EFI_HANDLE DeviceHandle,\r
197 IN EFI_HANDLE ChildHandle,\r
198 IN CHAR8 *Language,\r
199 OUT CHAR16 **ControllerName\r
200 );\r
201\r
5e6b870a 202#endif // _LSI_SCSI_DXE_H_\r