Merged via: PR - https://github.com/tianocore/edk2/pull/3559 Commit - https://github.com/tianocore/edk2/commit/52199bf5326a8355d28b2d395db483f7c77d5a4d
Best Regards, Hao Wu > -----Original Message----- > From: devel@edk2.groups.io <devel@edk2.groups.io> On Behalf Of Wu, Hao A > Sent: Friday, October 28, 2022 10:26 AM > To: devel@edk2.groups.io; go...@ami.com > Cc: Selvaraj, Sundaresan <sundares...@ami.com>; Sambandan, Vasudevan > <vasudev...@ami.com> > Subject: Re: [edk2-devel] [PATCH v2] MdeModulePkg/ScsiDiskDxe: Update > proper device name for ScsiDisk drive > > Thanks. > Reviewed-by: Hao A Wu <hao.a...@intel.com> > > Will wait a couple of days before merging to see if comments from other > reviewers. > > Best Regards, > Hao Wu > > > -----Original Message----- > > From: devel@edk2.groups.io <devel@edk2.groups.io> On Behalf Of > > Cheripally Gopi via groups.io > > Sent: Thursday, October 27, 2022 3:07 PM > > To: devel@edk2.groups.io > > Cc: Selvaraj, Sundaresan <sundares...@ami.com>; Sambandan, Vasudevan > > <vasudev...@ami.com>; Cheripally Gopi <go...@ami.com> > > Subject: [edk2-devel] [PATCH v2] MdeModulePkg/ScsiDiskDxe: Update > > proper device name for ScsiDisk drive > > > > ScsiDiskDxe driver updates ControllerNameTable with common string > > "SCSI Disk Device" for all SCSI disks. Due to this, when multiple SCSI > > disk devices connected, facing difficulty in identifying correct SCSI > > disk device. As per SCSI spec, standard Inquiry Data is having the > > fields to know Vendor and Product information. Updated > > "ControllerNameTable" with Vendor and Product information. So that, > > device specific name can be retrieved using ComponentName protocol. > > > > Cc: Vasudevan Sambandan <vasudev...@ami.com> > > Cc: Sundaresan Selvaraj <sundares...@ami.com> > > Signed-off-by: Cheripally Gopi <go...@ami.com> > > --- > > MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.c | 53 > > ++++++++++++++++++- MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.h | 9 > ++++ > > .../Bus/Scsi/ScsiDiskDxe/ScsiDiskDxe.inf | 2 + > > 3 files changed, 62 insertions(+), 2 deletions(-) > > > > diff --git a/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.c > > b/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.c > > index 98e84b4ea8..0928605dc4 100644 > > --- a/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.c > > +++ b/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.c > > @@ -2,6 +2,7 @@ > > SCSI disk driver that layers on every SCSI IO protocol in the system. > > > > > > > > Copyright (c) 2006 - 2019, Intel Corporation. All rights > > reserved.<BR> > > > > +Copyright (c) 1985 - 2022, American Megatrends International LLC.<BR> > > > > SPDX-License-Identifier: BSD-2-Clause-Patent > > > > > > > > **/ > > > > @@ -67,6 +68,33 @@ FreeAlignedBuffer ( > > } > > > > } > > > > > > > > +/** > > > > + Remove trailing spaces from the string. > > > > + > > > > + @param String The ASCII string to remove the trailing spaces. > > > > + > > > > + @retval the new length of the string. > > > > +**/ > > > > +UINTN > > > > +RemoveTrailingSpaces ( > > > > + IN OUT CHAR8 *String > > > > + ) > > > > +{ > > > > + UINTN Length; > > > > + > > > > + Length = AsciiStrLen (String); > > > > + if (Length == 0) { > > > > + return 0; > > > > + } > > > > + > > > > + while ((Length > 0) && (String[Length-1] == ' ')) { > > > > + Length--; > > > > + } > > > > + > > > > + String[Length] = '\0'; > > > > + return Length; > > > > +} > > > > + > > > > /** > > > > The user Entry Point for module ScsiDisk. > > > > > > > > @@ -203,6 +231,9 @@ ScsiDiskDriverBindingStart ( > > UINT8 MaxRetry; > > > > BOOLEAN NeedRetry; > > > > BOOLEAN MustReadCapacity; > > > > + CHAR8 VendorStr[VENDOR_IDENTIFICATION_LENGTH + 1]; > > > > + CHAR8 ProductStr[PRODUCT_IDENTIFICATION_LENGTH + 1]; > > > > + CHAR16 DeviceStr[VENDOR_IDENTIFICATION_LENGTH + > > PRODUCT_IDENTIFICATION_LENGTH + 2]; > > > > > > > > MustReadCapacity = TRUE; > > > > > > > > @@ -354,19 +385,37 @@ ScsiDiskDriverBindingStart ( > > } > > > > } > > > > > > > > + CopyMem ( > > > > + VendorStr, > > > > + &ScsiDiskDevice- > > >InquiryData.Reserved_5_95[VENDOR_IDENTIFICATION_OFFSET], > > > > + VENDOR_IDENTIFICATION_LENGTH > > > > + ); > > > > + VendorStr[VENDOR_IDENTIFICATION_LENGTH] = 0; > > > > + RemoveTrailingSpaces (VendorStr); > > > > + > > > > + CopyMem ( > > > > + ProductStr, > > > > + &ScsiDiskDevice- > > >InquiryData.Reserved_5_95[PRODUCT_IDENTIFICATION_OFFSET], > > > > + PRODUCT_IDENTIFICATION_LENGTH > > > > + ); > > > > + ProductStr[PRODUCT_IDENTIFICATION_LENGTH] = 0; > > > > + RemoveTrailingSpaces (ProductStr); > > > > + > > > > + UnicodeSPrint (DeviceStr, sizeof (DeviceStr), L"%a %a", > > + VendorStr, > > ProductStr); > > > > + > > > > ScsiDiskDevice->ControllerNameTable = NULL; > > > > AddUnicodeString2 ( > > > > "eng", > > > > gScsiDiskComponentName.SupportedLanguages, > > > > &ScsiDiskDevice->ControllerNameTable, > > > > - L"SCSI Disk Device", > > > > + DeviceStr, > > > > TRUE > > > > ); > > > > AddUnicodeString2 ( > > > > "en", > > > > gScsiDiskComponentName2.SupportedLanguages, > > > > &ScsiDiskDevice->ControllerNameTable, > > > > - L"SCSI Disk Device", > > > > + DeviceStr, > > > > FALSE > > > > ); > > > > return EFI_SUCCESS; > > > > diff --git a/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.h > > b/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.h > > index d54282df5f..5b4047e1db 100644 > > --- a/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.h > > +++ b/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDisk.h > > @@ -2,6 +2,7 @@ > > Header file for SCSI Disk Driver. > > > > > > > > Copyright (c) 2004 - 2019, Intel Corporation. All rights > > reserved.<BR> > > > > +Copyright (c) 1985 - 2022, American Megatrends International LLC.<BR> > > > > SPDX-License-Identifier: BSD-2-Clause-Patent > > > > > > > > **/ > > > > @@ -30,6 +31,7 @@ SPDX-License-Identifier: BSD-2-Clause-Patent > > #include <Library/UefiScsiLib.h> > > > > #include <Library/UefiBootServicesTableLib.h> > > > > #include <Library/DevicePathLib.h> > > > > +#include <Library/PrintLib.h> > > > > > > > > #include <IndustryStandard/Scsi.h> > > > > #include <IndustryStandard/Atapi.h> > > > > @@ -179,6 +181,13 @@ extern EFI_COMPONENT_NAME2_PROTOCOL > > gScsiDiskComponentName2; #define SCSI_COMMAND_VERSION_2 0x02 > > > > #define SCSI_COMMAND_VERSION_3 0x03 > > > > > > > > +// Per SCSI spec, EFI_SCSI_INQUIRY_DATA.Reserved_5_95[3 - 10] has the > > Vendor identification > > > > +// EFI_SCSI_INQUIRY_DATA.Reserved_5_95[11 - 26] has the product > > identification > > > > +#define VENDOR_IDENTIFICATION_OFFSET 3 > > > > +#define VENDOR_IDENTIFICATION_LENGTH 8 > > > > +#define PRODUCT_IDENTIFICATION_OFFSET 11 > > > > +#define PRODUCT_IDENTIFICATION_LENGTH 16 > > > > + > > > > // > > > > // SCSI Disk Timeout Experience Value > > > > // > > > > diff --git a/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDiskDxe.inf > > b/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDiskDxe.inf > > index 40818e669b..26227132e8 100644 > > --- a/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDiskDxe.inf > > +++ b/MdeModulePkg/Bus/Scsi/ScsiDiskDxe/ScsiDiskDxe.inf > > @@ -4,6 +4,7 @@ > > # the device handle. > > > > # > > > > # Copyright (c) 2006 - 2019, Intel Corporation. All rights > > reserved.<BR> > > > > +# Copyright (c) 1985 - 2022, American Megatrends International > > +LLC.<BR> > > > > # SPDX-License-Identifier: BSD-2-Clause-Patent > > > > # > > > > ## > > > > @@ -46,6 +47,7 @@ > > UefiDriverEntryPoint > > > > DebugLib > > > > DevicePathLib > > > > + PrintLib > > > > > > > > [Protocols] > > > > gEfiDiskInfoProtocolGuid ## BY_START > > > > -- > > 2.33.0.windows.2 > > -The information contained in this message may be confidential and > > proprietary to American Megatrends (AMI). This communication is > > intended to be read only by the individual or entity to whom it is > > addressed or by their designee. If the reader of this message is not > > the intended recipient, you are on notice that any distribution of this > > message, > in any form, is strictly prohibited. > > Please promptly notify the sender by reply e-mail or by telephone at > > 770-246- 8600, and then delete or destroy all copies of the transmission. > > > > > > > > > > > > > -=-=-=-=-=-=-=-=-=-=-=- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#95766): https://edk2.groups.io/g/devel/message/95766 Mute This Topic: https://groups.io/mt/94600311/21656 Group Owner: devel+ow...@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [arch...@mail-archive.com] -=-=-=-=-=-=-=-=-=-=-=-