Yes, I will fix this problem. Is it more reasonable to use the following patch?

--- a/MdePkg/Include/Protocol/DevicePath.h
+++ b/MdePkg/Include/Protocol/DevicePath.h
@@ -904,7 +904,7 @@ typedef struct {
   ///
   /// Service set identifier. A 32-byte octets string.
   ///
-  UINT8                           SSId[32];
+  CHAR8                           SSId[32];
 } WIFI_DEVICE_PATH;

 //

Since SSId is a human readable identifier, so using CHAR8 instead of INT8 
sounds better?

Best Regards,
Hao Wu

-----Original Message-----
From: Ard Biesheuvel [mailto:ard.biesheu...@linaro.org] 
Sent: Wednesday, May 20, 2015 3:14 PM
To: edk2-devel@lists.sourceforge.net; Wu, Hao A; Ye, Ting
Subject: Re: [edk2] [PATCH 2/2] MdePkg: Add WiFi device path definition and its 
node/text conversion

On 15 May 2015 at 02:58, Hao Wu <hao.a...@intel.com> wrote:
> Contributed-under: TianoCore Contribution Agreement 1.0
> Signed-off-by: Hao Wu <hao.a...@intel.com>
> Reviewed-by: Ye Ting <ting...@intel.com>

This patch uses UINT8* and CHAR8* interchangeably, which breaks the
build on ARM since unqualified CHAR is signed not unsigned.

Please fix by adding this patch on top:

diff --git a/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c
b/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c
index c2aa93cedc5e..ac54b88c9116 100644
--- a/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c
+++ b/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c
@@ -2793,7 +2793,7 @@ DevPathFromTextWiFi (
                                    (UINT16) sizeof (WIFI_DEVICE_PATH)
                                    );

-  AsciiStr = WiFiDp->SSId;
+  AsciiStr = (CHAR8 *)WiFiDp->SSId;
   StrToAscii (SSIdStr, &AsciiStr);

   return (EFI_DEVICE_PATH_PROTOCOL *) WiFiDp;


Regards,
Ard.



> ---
>  MdePkg/Include/Protocol/DevicePath.h               | 14 ++++++++++
>  .../Library/UefiDevicePathLib/DevicePathFromText.c | 31 
> ++++++++++++++++++++++
>  .../Library/UefiDevicePathLib/DevicePathToText.c   | 28 +++++++++++++++++++
>  3 files changed, 73 insertions(+)
>
> diff --git a/MdePkg/Include/Protocol/DevicePath.h 
> b/MdePkg/Include/Protocol/DevicePath.h
> index 1dbb1a1..7b9a4e5 100644
> --- a/MdePkg/Include/Protocol/DevicePath.h
> +++ b/MdePkg/Include/Protocol/DevicePath.h
> @@ -895,6 +895,18 @@ typedef struct {
>    BLUETOOTH_ADDRESS               BD_ADDR;
>  } BLUETOOTH_DEVICE_PATH;
>
> +///
> +/// Wi-Fi Device Path SubType.
> +///
> +#define MSG_WIFI_DP               0x1C
> +typedef struct {
> +  EFI_DEVICE_PATH_PROTOCOL        Header;
> +  ///
> +  /// Service set identifier. A 32-byte octets string.
> +  ///
> +  UINT8                           SSId[32];
> +} WIFI_DEVICE_PATH;
> +
>  //
>  // Media Device Path
>  //
> @@ -1145,6 +1157,7 @@ typedef union {
>    NVME_NAMESPACE_DEVICE_PATH                 NvmeNamespace;
>    URI_DEVICE_PATH                            Uri;
>    BLUETOOTH_DEVICE_PATH                      Bluetooth;
> +  WIFI_DEVICE_PATH                           WiFi;
>    UFS_DEVICE_PATH                            Ufs;
>    SD_DEVICE_PATH                             Sd;
>    HARDDRIVE_DEVICE_PATH                      HardDrive;
> @@ -1199,6 +1212,7 @@ typedef union {
>    NVME_NAMESPACE_DEVICE_PATH                 *NvmeNamespace;
>    URI_DEVICE_PATH                            *Uri;
>    BLUETOOTH_DEVICE_PATH                      *Bluetooth;
> +  WIFI_DEVICE_PATH                           *WiFi;
>    UFS_DEVICE_PATH                            *Ufs;
>    SD_DEVICE_PATH                             *Sd;
>    HARDDRIVE_DEVICE_PATH                      *HardDrive;
> diff --git a/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c 
> b/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c
> index 3bccad9..c2aa93c 100644
> --- a/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c
> +++ b/MdePkg/Library/UefiDevicePathLib/DevicePathFromText.c
> @@ -2770,6 +2770,36 @@ DevPathFromTextBluetooth (
>  }
>
>  /**
> +  Converts a text device path node to Wi-Fi device path structure.
> +
> +  @param TextDeviceNode  The input Text device path node.
> +
> +  @return A pointer to the newly-created Wi-Fi device path structure.
> +
> +**/
> +EFI_DEVICE_PATH_PROTOCOL *
> +DevPathFromTextWiFi (
> +  IN CHAR16 *TextDeviceNode
> +  )
> +{
> +  CHAR16                *SSIdStr;
> +  CHAR8                 *AsciiStr;
> +  WIFI_DEVICE_PATH      *WiFiDp;
> +
> +  SSIdStr = GetNextParamStr (&TextDeviceNode);
> +  WiFiDp  = (WIFI_DEVICE_PATH *) CreateDeviceNode (
> +                                   MESSAGING_DEVICE_PATH,
> +                                   MSG_WIFI_DP,
> +                                   (UINT16) sizeof (WIFI_DEVICE_PATH)
> +                                   );
> +
> +  AsciiStr = WiFiDp->SSId;
> +  StrToAscii (SSIdStr, &AsciiStr);
> +
> +  return (EFI_DEVICE_PATH_PROTOCOL *) WiFiDp;
> +}
> +
> +/**
>    Converts a text device path node to URI device path structure.
>
>    @param TextDeviceNode  The input Text device path node.
> @@ -3244,6 +3274,7 @@ GLOBAL_REMOVE_IF_UNREFERENCED 
> DEVICE_PATH_FROM_TEXT_TABLE mUefiDevicePathLibDevP
>    {L"Vlan",                    DevPathFromTextVlan                    },
>    {L"Uri",                     DevPathFromTextUri                     },
>    {L"Bluetooth",               DevPathFromTextBluetooth               },
> +  {L"WiFi",                    DevPathFromTextWiFi                    },
>    {L"MediaPath",               DevPathFromTextMediaPath               },
>    {L"HD",                      DevPathFromTextHD                      },
>    {L"CDROM",                   DevPathFromTextCDROM                   },
> diff --git a/MdePkg/Library/UefiDevicePathLib/DevicePathToText.c 
> b/MdePkg/Library/UefiDevicePathLib/DevicePathToText.c
> index a4a665b..68b9372 100644
> --- a/MdePkg/Library/UefiDevicePathLib/DevicePathToText.c
> +++ b/MdePkg/Library/UefiDevicePathLib/DevicePathToText.c
> @@ -1562,6 +1562,33 @@ DevPathToTextBluetooth (
>  }
>
>  /**
> +  Converts a Wi-Fi device path structure to its string representative.
> +
> +  @param Str             The string representative of input device.
> +  @param DevPath         The input device path structure.
> +  @param DisplayOnly     If DisplayOnly is TRUE, then the shorter text 
> representation
> +                         of the display node is used, where applicable. If 
> DisplayOnly
> +                         is FALSE, then the longer text representation of 
> the display node
> +                         is used.
> +  @param AllowShortcuts  If AllowShortcuts is TRUE, then the shortcut forms 
> of text
> +                         representation for a device node can be used, where 
> applicable.
> +
> +**/
> +VOID
> +DevPathToTextWiFi (
> +  IN OUT POOL_PRINT  *Str,
> +  IN VOID            *DevPath,
> +  IN BOOLEAN         DisplayOnly,
> +  IN BOOLEAN         AllowShortcuts
> +  )
> +{
> +  WIFI_DEVICE_PATH      *WiFi;
> +
> +  WiFi = DevPath;
> +  UefiDevicePathLibCatPrint (Str, L"WiFi(%a)", WiFi->SSId);
> +}
> +
> +/**
>    Converts a URI device path structure to its string representative.
>
>    @param Str             The string representative of input device.
> @@ -2021,6 +2048,7 @@ GLOBAL_REMOVE_IF_UNREFERENCED const 
> DEVICE_PATH_TO_TEXT_TABLE mUefiDevicePathLib
>    {MESSAGING_DEVICE_PATH, MSG_VLAN_DP,                      
> DevPathToTextVlan           },
>    {MESSAGING_DEVICE_PATH, MSG_URI_DP,                       DevPathToTextUri 
>            },
>    {MESSAGING_DEVICE_PATH, MSG_BLUETOOTH_DP,                 
> DevPathToTextBluetooth      },
> +  {MESSAGING_DEVICE_PATH, MSG_WIFI_DP,                      
> DevPathToTextWiFi           },
>    {MEDIA_DEVICE_PATH,     MEDIA_HARDDRIVE_DP,               
> DevPathToTextHardDrive      },
>    {MEDIA_DEVICE_PATH,     MEDIA_CDROM_DP,                   
> DevPathToTextCDROM          },
>    {MEDIA_DEVICE_PATH,     MEDIA_VENDOR_DP,                  
> DevPathToTextVendor         },
> --
> 1.9.5.msysgit.0
>
>
> ------------------------------------------------------------------------------
> One dashboard for servers and applications across Physical-Virtual-Cloud
> Widest out-of-the-box monitoring support with 50+ applications
> Performance metrics, stats and reports that give you Actionable Insights
> Deep dive visibility with transaction tracing using APM Insight.
> http://ad.doubleclick.net/ddm/clk/290420510;117567292;y
> _______________________________________________
> edk2-devel mailing list
> edk2-devel@lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/edk2-devel
------------------------------------------------------------------------------
One dashboard for servers and applications across Physical-Virtual-Cloud 
Widest out-of-the-box monitoring support with 50+ applications
Performance metrics, stats and reports that give you Actionable Insights
Deep dive visibility with transaction tracing using APM Insight.
http://ad.doubleclick.net/ddm/clk/290420510;117567292;y
_______________________________________________
edk2-devel mailing list
edk2-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/edk2-devel

Reply via email to