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