Hi Andrei Warkentin:
         Thank you very much for your attention!

> -----原始邮件-----
> 发件人: "Andrei Warkentin" <andrei.warken...@intel.com>
> 发送时间: 2023-12-27 05:12:07 (星期三)
> 收件人: 王洋 <wangy...@bosc.ac.cn>, "devel@edk2.groups.io" <devel@edk2.groups.io>, 
> "suni...@ventanamicro.com" <suni...@ventanamicro.com>, "Gao, Liming" 
> <gaolim...@byosoft.com.cn>, "Kinney, Michael D" <michael.d.kin...@intel.com>, 
> "Liu, Zhiguang" <zhiguang....@intel.com>
> 抄送: 
> 主题: Re: [edk2-devel] [Resend PATCH] MdePkg/BaseLib:Fix boot DxeCore hang on 
> riscv platform
> 
> I'd go for using "mv" over add with immediate of zero.

I agree.

> 
> Also the REG_S/REG_L business doesn't really help with legibility. Why not 
> just use sd and ld? I get that you're copying from 
> RiscVSetJumpLongJump.S...which seems like another issue.

Yes, but with modifications.Fixed the problem scenario described by my commit.

> 
> If the function is called SwitchStack, why are you restoring all the other 
> regs? Following the AArch64 version is probably a better idea. Just don't 
> take a BASE_LIBRARY_JUMP_BUFFER  as a parameter, take EntryPoint, Context, 
> Context2 and NewStack. And you can even take these in the order of Context, 
> Context2, EntryPoint, NewStack to avoid the extra movement of values in 
> registers.

Thank you very much for your suggestion;I think your suggestion is more logical.
I have tested the patch you suggested, and it can also work. 
I will second V2 of the patch based on your suggestion.
Thank you very much for your suggestion.

Regards,

Yang

> 
> A
> 
> > -----Original Message-----
> > From: 王洋 <wangy...@bosc.ac.cn>
> > Sent: Sunday, December 24, 2023 8:47 PM
> > To: devel@edk2.groups.io; suni...@ventanamicro.com; Warkentin, Andrei
> > <andrei.warken...@intel.com>; Gao, Liming <gaolim...@byosoft.com.cn>;
> > Kinney, Michael D <michael.d.kin...@intel.com>; Liu, Zhiguang
> > <zhiguang....@intel.com>
> > Subject: [Resend PATCH] MdePkg/BaseLib:Fix boot DxeCore hang on riscv
> > platform
> > 
> > From f15d405067860a8087c5eb4080bc3e08ca5e0e21 Mon Sep 17 00:00:00
> > 2001
> > From: wangyang <wangy...@bosc.ac.cn>
> > Date: Wed, 20 Dec 2023 20:27:42 +0800
> > Subject: [PATCH] MdePkg/BaseLib:Fix boot DxeCore hang on riscv platform
> > 
> > For scene of
> > HandOffToDxeCore()->SwitchStack(DxeCoreEntryPoint)->
> > InternalSwitchStack()->LongJump(),Variable HobList.Raw will be passed (from
> > *Context1 to register a0) to
> > DxeMain() in parameter *HobStart.
> > 
> > However, meanwhile the function LongJump() overrides register a0 with a1 
> > (-1)
> > due to commit (ea628f28e5 "RISCV: Fix InternalLongJump to return correct
> > value"), then cause hang.
> > 
> > Replacing calling LongJump() with new InternalSwitchStackAsm() to pass 
> > addres
> > data in register s0 to register a0 could fix this issue (just like the 
> > solution in
> > MdePkg/Library/BaseLib/LoongArch64/SwitchStack.S)
> > 
> > Signed-off-by: Yang Wang <wangy...@bosc.ac.cn>
> > Reviewed-by: Ran Wang <wang...@bosc.ac.cn> Cc:Andrei Warkentin
> > <andrei.warken...@intel.com> Cc:Liming Gao <gaolim...@byosoft.com.cn>
> > Cc:Michael D Kinney <michael.d.kin...@intel.com> Cc:Sunil V L
> > <suni...@ventanamicro.com> Cc:Zhiguang Liu <zhiguang....@intel.com>
> > ---
> >  .../BaseLib/RiscV64/InternalSwitchStack.c     |  7 +++-
> >  MdePkg/Library/BaseLib/RiscV64/SwitchStack.S  | 40 +++++++++++++++++++
> >  2 files changed, 46 insertions(+), 1 deletion(-)  create mode 100644
> > MdePkg/Library/BaseLib/RiscV64/SwitchStack.S
> > 
> > diff --git a/MdePkg/Library/BaseLib/RiscV64/InternalSwitchStack.c
> > b/MdePkg/Library/BaseLib/RiscV64/InternalSwitchStack.c
> > index b78424c163..c60fbdb896 100644
> > --- a/MdePkg/Library/BaseLib/RiscV64/InternalSwitchStack.c
> > +++ b/MdePkg/Library/BaseLib/RiscV64/InternalSwitchStack.c
> > @@ -8,6 +8,11 @@
> > 
> >  #include "BaseLibInternals.h"
> > 
> > +UINTN
> > +EFIAPI
> > +InternalSwitchStackAsm (
> > +  IN     BASE_LIBRARY_JUMP_BUFFER  *JumpBuffer
> > +  );
> >  /**
> >    Transfers control to a function starting with a new stack.
> > 
> > @@ -48,6 +53,6 @@ InternalSwitchStack (
> >    JumpBuffer.SP = (UINTN)NewStack - sizeof (VOID *);
> >    JumpBuffer.S0 = (UINT64)(UINTN)Context1;
> >    JumpBuffer.S1 = (UINT64)(UINTN)Context2;
> > -  LongJump (&JumpBuffer, (UINTN)-1);
> > +  InternalSwitchStackAsm (&JumpBuffer);
> >    ASSERT (FALSE);
> >  }
> > diff --git a/MdePkg/Library/BaseLib/RiscV64/SwitchStack.S
> > b/MdePkg/Library/BaseLib/RiscV64/SwitchStack.S
> > new file mode 100644
> > index 0000000000..59b8d60e7e
> > --- /dev/null
> > +++ b/MdePkg/Library/BaseLib/RiscV64/SwitchStack.S
> > @@ -0,0 +1,40 @@
> > +//---------------------------------------------------------------------
> > +---------
> > +//
> > +// InternalSwitchStackAsm for RISC-V
> > +//
> > +// Copyright (c) 2023, Bosc Corporation. All rights reserved.<BR> // //
> > +SPDX-License-Identifier: BSD-2-Clause-Patent //
> > +//---------------------------------------------------------------------
> > +---------
> > +# define REG_S  sd
> > +# define REG_L  ld
> > +# define SZREG  8
> > +.align 3
> > +
> > +/**
> > +  This allows the caller to switch the stack and goes to the new entry
> > +point
> > +
> > +  @param  JumpBuffer    A pointer to CPU context buffer.
> > +**/
> > +
> > +    .globl InternalSwitchStackAsm
> > +InternalSwitchStackAsm:
> > +  REG_L ra,  0*SZREG(a0)
> > +  REG_L s0,  1*SZREG(a0)
> > +  REG_L s1,  2*SZREG(a0)
> > +  REG_L s2,  3*SZREG(a0)
> > +  REG_L s3,  4*SZREG(a0)
> > +  REG_L s4,  5*SZREG(a0)
> > +  REG_L s5,  6*SZREG(a0)
> > +  REG_L s6,  7*SZREG(a0)
> > +  REG_L s7,  8*SZREG(a0)
> > +  REG_L s8,  9*SZREG(a0)
> > +  REG_L s9,  10*SZREG(a0)
> > +  REG_L s10, 11*SZREG(a0)
> > +  REG_L s11, 12*SZREG(a0)
> > +  REG_L sp,  13*SZREG(a0)
> > +
> > +  add   a0, s0, 0
> > +  add   a1, s1, 0
> > +  ret
> > --
> > 2.25.1
> 
> 
> 
> 
> 


-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#112938): https://edk2.groups.io/g/devel/message/112938
Mute This Topic: https://groups.io/mt/103369618/21656
Group Owner: devel+ow...@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [arch...@mail-archive.com]
-=-=-=-=-=-=-=-=-=-=-=-


Reply via email to