public inbox for devel@edk2.groups.io
 help / color / mirror / Atom feed
From: "Ni, Ray" <ray.ni@intel.com>
To: "Dong, Eric" <eric.dong@intel.com>,
	"devel@edk2.groups.io" <devel@edk2.groups.io>
Cc: Laszlo Ersek <lersek@redhat.com>,
	"Kumar, Chandana C" <chandana.c.kumar@intel.com>,
	"Zeng, Star" <star.zeng@intel.com>
Subject: Re: [Patch v3 6/6] UefiCpuPkg/RegisterCpuFeaturesLib: Start all processors simultaneously.
Date: Thu, 25 Jul 2019 08:59:12 +0000	[thread overview]
Message-ID: <734D49CCEBEEF84792F5B80ED585239D5C244F29@SHSMSX104.ccr.corp.intel.com> (raw)
In-Reply-To: <20190724070727.14976-7-eric.dong@intel.com>

Reviewed-by: Ray Ni <ray.ni@intel.com>

> -----Original Message-----
> From: Dong, Eric
> Sent: Wednesday, July 24, 2019 3:07 PM
> To: devel@edk2.groups.io
> Cc: Ni, Ray <ray.ni@intel.com>; Laszlo Ersek <lersek@redhat.com>; Kumar,
> Chandana C <chandana.c.kumar@intel.com>; Zeng, Star
> <star.zeng@intel.com>
> Subject: [Patch v3 6/6] UefiCpuPkg/RegisterCpuFeaturesLib: Start all
> processors simultaneously.
> 
> REF: https://bugzilla.tianocore.org/show_bug.cgi?id=1973
> 
> For semaphore type register, it required all processors to do the task at the
> same time.
> Current logic begins BSP's task after all APs have finished their tasks.
> This will caused set semaphore task hang if semaphore has package level
> type.
> This patch use new EDKII_PEI_MP_SERVICES2_PPI to start all processors at
> the same time to fix the potential hang issue.
> 
> Cc: Ray Ni <ray.ni@intel.com>
> Cc: Laszlo Ersek <lersek@redhat.com>
> Cc: Chandana Kumar <chandana.c.kumar@intel.com>
> Cc: Star Zeng <star.zeng@intel.com>
> Signed-off-by: Eric Dong <eric.dong@intel.com>
> ---
>  .../CpuFeaturesInitialize.c                   |  2 +-
>  .../DxeRegisterCpuFeaturesLib.c               |  6 +-
>  .../PeiRegisterCpuFeaturesLib.c               | 66 ++++++++++++++-----
>  .../PeiRegisterCpuFeaturesLib.inf             |  1 +
>  .../RegisterCpuFeatures.h                     |  2 +-
>  5 files changed, 54 insertions(+), 23 deletions(-)
> 
> diff --git
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/CpuFeaturesInitialize.c
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/CpuFeaturesInitialize.c
> index 33752c1a9f..4e97e863c7 100644
> --- a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/CpuFeaturesInitialize.c
> +++ b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/CpuFeaturesInitialize.c
> @@ -1074,7 +1074,7 @@ CpuFeaturesDetect (
>      //
>      // Wakeup all APs for data collection.
>      //
> -    StartupAPsWorker (CollectProcessorData, NULL);
> +    StartupAllAPsWorker (CollectProcessorData, NULL);
>    }
> 
>    //
> diff --git
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/DxeRegisterCpuFeaturesLib.c
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/DxeRegisterCpuFeaturesLib.c
> index f87b2892aa..e2e06e88e0 100644
> ---
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/DxeRegisterCpuFeaturesLib.c
> +++
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/DxeRegisterCpuFeaturesLi
> +++ b.c
> @@ -1,7 +1,7 @@
>  /** @file
>    CPU Register Table Library functions.
> 
> -  Copyright (c) 2017, Intel Corporation. All rights reserved.<BR>
> +  Copyright (c) 2017 - 2019, Intel Corporation. All rights
> + reserved.<BR>
>    SPDX-License-Identifier: BSD-2-Clause-Patent
> 
>  **/
> @@ -116,7 +116,7 @@ GetProcessorInformation (
>                                        to check whether procedure has done.
>  **/
>  VOID
> -StartupAPsWorker (
> +StartupAllAPsWorker (
>    IN  EFI_AP_PROCEDURE                 Procedure,
>    IN  EFI_EVENT                        MpEvent
>    )
> @@ -248,7 +248,7 @@ CpuFeaturesInitialize (
>      //
>      // Wakeup all APs for programming.
>      //
> -    StartupAPsWorker (SetProcessorRegister, MpEvent);
> +    StartupAllAPsWorker (SetProcessorRegister, MpEvent);
>    }
> 
>    //
> diff --git
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLib.c
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLib.c
> index 8ad5a40e5a..52b849ce13 100644
> ---
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLib.c
> +++
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLi
> +++ b.c
> @@ -1,7 +1,7 @@
>  /** @file
>    CPU Register Table Library functions.
> 
> -  Copyright (c) 2016, Intel Corporation. All rights reserved.<BR>
> +  Copyright (c) 2016 - 2019, Intel Corporation. All rights
> + reserved.<BR>
>    SPDX-License-Identifier: BSD-2-Clause-Patent
> 
>  **/
> @@ -12,6 +12,8 @@
>  #include <Library/PeiServicesLib.h>
>  #include <Library/PeiServicesTablePointerLib.h>
>  #include <Ppi/MpServices.h>
> +#include <Ppi/MpServices2.h>
> +
>  #include "RegisterCpuFeatures.h"
> 
>  #define REGISTER_CPU_FEATURES_GUID \
> @@ -154,7 +156,7 @@ GetProcessorInformation (
> 
>  **/
>  VOID
> -StartupAPsWorker (
> +StartupAllAPsWorker (
>    IN  EFI_AP_PROCEDURE                 Procedure,
>    IN  EFI_EVENT                        MpEvent
>    )
> @@ -180,6 +182,48 @@ StartupAPsWorker (
>    ASSERT_EFI_ERROR (Status);
>  }
> 
> +/**
> +  Worker function to execute a caller provided function on all enabled APs.
> +
> +  @param[in]  Procedure               A pointer to the function to be run on
> +                                      enabled APs of the system.
> +  @param[in]  MpEvent                 The Event used to sync the result.
> +
> +**/
> +VOID
> +StartupAllCPUsWorker (
> +  IN  EFI_AP_PROCEDURE                 Procedure
> +  )
> +{
> +  EFI_STATUS                           Status;
> +  EDKII_PEI_MP_SERVICES2_PPI           *CpuMp2Ppi;
> +  CPU_FEATURES_DATA                    *CpuFeaturesData;
> +
> +  CpuFeaturesData = GetCpuFeaturesData ();
> +
> +  //
> +  // Get MP Services2 Ppi
> +  //
> +  Status = PeiServicesLocatePpi (
> +             &gEdkiiPeiMpServices2PpiGuid,
> +             0,
> +             NULL,
> +             (VOID **)&CpuMp2Ppi
> +             );
> +  ASSERT_EFI_ERROR (Status);
> +
> +  //
> +  // Wakeup all APs for data collection.
> +  //
> +  Status = CpuMp2Ppi->StartupAllCPUs (
> +                 CpuMp2Ppi,
> +                 Procedure,
> +                 0,
> +                 CpuFeaturesData
> +                 );
> +  ASSERT_EFI_ERROR (Status);
> +}
> +
>  /**
>    Worker function to switch the requested AP to be the BSP from that point
> onward.
> 
> @@ -267,23 +311,9 @@ CpuFeaturesInitialize (
>    CpuFeaturesData->BspNumber = OldBspNumber;
> 
>    //
> -  // Known limitation: In PEI phase, CpuFeatures driver not
> -  // support async mode execute tasks. So semaphore type
> -  // register can't been used for this instance, must use
> -  // DXE type instance.
> -  //
> -
> -  if (CpuFeaturesData->NumberOfCpus > 1) {
> -    //
> -    // Wakeup all APs for programming.
> -    //
> -    StartupAPsWorker (SetProcessorRegister, NULL);
> -  }
> -
> -  //
> -  // Programming BSP
> +  // Start to program register for all CPUs.
>    //
> -  SetProcessorRegister (CpuFeaturesData);
> +  StartupAllCPUsWorker (SetProcessorRegister);
> 
>    //
>    // Switch to new BSP if required
> diff --git
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLib.in
> f
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLib.in
> f
> index 63091dfeb8..61f922bf63 100644
> ---
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLib.in
> f
> +++
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/PeiRegisterCpuFeaturesLi
> +++ b.inf
> @@ -46,6 +46,7 @@
> 
>  [Ppis]
>    gEfiPeiMpServicesPpiGuid                                             ## CONSUMES
> +  gEdkiiPeiMpServices2PpiGuid                                          ## CONSUMES
> 
>  [Pcd]
>    gUefiCpuPkgTokenSpaceGuid.PcdCpuS3DataAddress                        ##
> CONSUMES
> diff --git
> a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/RegisterCpuFeatures.h
> b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/RegisterCpuFeatures.h
> index a18f926641..a25dd69292 100644
> --- a/UefiCpuPkg/Library/RegisterCpuFeaturesLib/RegisterCpuFeatures.h
> +++ b/UefiCpuPkg/Library/RegisterCpuFeaturesLib/RegisterCpuFeatures.h
> @@ -145,7 +145,7 @@ GetProcessorInformation (
>                                        to check whether procedure has done.
>  **/
>  VOID
> -StartupAPsWorker (
> +StartupAllAPsWorker (
>    IN  EFI_AP_PROCEDURE                 Procedure,
>    IN  EFI_EVENT                        MpEvent
>    );
> --
> 2.21.0.windows.1


  reply	other threads:[~2019-07-25  8:59 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-07-24  7:07 [Patch v3 0/6] UefiCpuPkg: Enable Edkii Mp Services2 Ppi Dong, Eric
2019-07-24  7:07 ` [Patch v3 1/6] UefiCpuPkg/Include/MpInitLib.h: Add MpInitLibStartupAllCPUs API Dong, Eric
2019-07-26 10:36   ` [edk2-devel] " Laszlo Ersek
2019-07-24  7:07 ` [Patch v3 2/6] UefiCpuPkg/MpInitLib: " Dong, Eric
2019-07-26 10:36   ` [edk2-devel] " Laszlo Ersek
2019-07-24  7:07 ` [Patch v3 3/6] UefiCpuPkg/MpInitLibUp: " Dong, Eric
2019-07-25  8:53   ` [edk2-devel] " Ni, Ray
2019-07-26 10:37   ` Laszlo Ersek
2019-07-24  7:07 ` [Patch v3 4/6] UefiCpuPkg: Add new EDKII_PEI_MP_SERVICES2_PPI Dong, Eric
2019-07-25  8:53   ` Ni, Ray
2019-07-26 10:37   ` [edk2-devel] " Laszlo Ersek
2019-07-24  7:07 ` [Patch v3 5/6] UefiCpuPkg/CpuMpPei: Produce EDKII_PEI_MP_SERVICES2_PPI Dong, Eric
2019-07-25  8:55   ` Ni, Ray
2019-07-26 10:38   ` [edk2-devel] " Laszlo Ersek
2019-07-24  7:07 ` [Patch v3 6/6] UefiCpuPkg/RegisterCpuFeaturesLib: Start all processors simultaneously Dong, Eric
2019-07-25  8:59   ` Ni, Ray [this message]
2019-07-26 10:38   ` [edk2-devel] " Laszlo Ersek

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-list from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=734D49CCEBEEF84792F5B80ED585239D5C244F29@SHSMSX104.ccr.corp.intel.com \
    --to=devel@edk2.groups.io \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox