From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from huawei.com (huawei.com [45.249.212.35]) by mx.groups.io with SMTP id smtpd.web11.9024.1589884140727652385 for ; Tue, 19 May 2020 03:29:01 -0700 Authentication-Results: mx.groups.io; dkim=missing; spf=pass (domain: huawei.com, ip: 45.249.212.35, mailfrom: huangming23@huawei.com) Received: from DGGEMS409-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 630EFA0E8C232A32AC7E; Tue, 19 May 2020 18:28:57 +0800 (CST) Received: from [127.0.0.1] (10.78.51.60) by DGGEMS409-HUB.china.huawei.com (10.3.19.209) with Microsoft SMTP Server id 14.3.487.0; Tue, 19 May 2020 18:28:47 +0800 Subject: Re: [RFC edk2-platforms v1 1/2] Hisilicon/Library: Move two functions to RtcHelperLib To: Leif Lindholm CC: , , , , , References: <1589809044-59210-1-git-send-email-huangming23@huawei.com> <1589809044-59210-2-git-send-email-huangming23@huawei.com> <20200518180302.GH10467@vanye> From: Ming Huang Message-ID: Date: Tue, 19 May 2020 18:28:47 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.3.0 MIME-Version: 1.0 In-Reply-To: <20200518180302.GH10467@vanye> X-Originating-IP: [10.78.51.60] X-CFilter-Loop: Reflected Content-Type: text/plain; charset="gbk" Content-Transfer-Encoding: quoted-printable =D4=DA 2020/5/19 2:03, Leif Lindholm =D0=B4=B5=C0: > On Mon, May 18, 2020 at 21:37:23 +0800, Ming Huang wrote: >> The functions of acquiring ownership of RTC will be used for other >> RTC library, so move them to RtcHelperLib. >> >> Contributed-under: TianoCore Contribution Agreement 1.1 >> Signed-off-by: Ming Huang >> --- >> Platform/Hisilicon/D06/D06.dsc = | 1 + >> Silicon/Hisilicon/Include/Library/RtcHelperLib.h = | 28 ++++++ >> Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83RealTimeClockL= ib.c | 80 +---------------- >> Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83RealTimeClockL= ib.inf | 1 + >> Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.c = | 94 ++++++++++++++++++++ >> Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.inf = | 32 +++++++ >> 6 files changed, 157 insertions(+), 79 deletions(-) >> >> diff --git a/Platform/Hisilicon/D06/D06.dsc b/Platform/Hisilicon/D06/D= 06.dsc >> index 000a4ee..eb20224 100644 >> --- a/Platform/Hisilicon/D06/D06.dsc >> +++ b/Platform/Hisilicon/D06/D06.dsc >> @@ -54,6 +54,7 @@ >> CpldIoLib|Silicon/Hisilicon/Library/CpldIoLib/CpldIoLib.inf >> =20 >> TimeBaseLib|EmbeddedPkg/Library/TimeBaseLib/TimeBaseLib.inf >> + RtcHelperLib|Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.in= f >> RealTimeClockLib|Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M= 41T83RealTimeClockLib.inf >> OemMiscLib|Platform/Hisilicon/D06/Library/OemMiscLibD06/OemMiscLibD= 06.inf >> OemAddressMapLib|Platform/Hisilicon/D06/Library/OemAddressMapD06/Oe= mAddressMapD06.inf >> diff --git a/Silicon/Hisilicon/Include/Library/RtcHelperLib.h b/Silico= n/Hisilicon/Include/Library/RtcHelperLib.h >> new file mode 100644 >> index 0000000..d6c1d39 >> --- /dev/null >> +++ b/Silicon/Hisilicon/Include/Library/RtcHelperLib.h >> @@ -0,0 +1,28 @@ >> +/** @file >> + >> + Copyright (c) 2018, Hisilicon Limited. All rights reserved.
>> + Copyright (c) 2018, Linaro Limited. All rights reserved.
>> + >> + SPDX-License-Identifier: BSD-2-Clause-Patent >> + >> +**/ >> + >> +#ifndef __RTC_HELPER_LIB_H__ >> +#define __RTC_HELPER_LIB_H__ >=20 > Please drop leading __ from macros. Those are reserved for toolchain > use. Ok >=20 >> + >> +// The delay is need for cpld and I2C. This is a empirical value. Mem= oryFence is no need. >> +#define RTC_DELAY_30_MS 30000 >> +// The delay is need for cpld and I2C. This is a empirical value. Mem= oryFence is no need. >> +#define RTC_DELAY_2_MACROSECOND 2 >=20 > I guess MACROSECOND is a > typo for MICROSECOND? Yes, this is a typo. >=20 > But we are now duplicating these macros between M41T83RealTimeClock.h > and RtcHelperLib.h. And M41T83RealTimeClock.h still holds a bunch of > other _MACROSECOND #defines. >=20 > Could we move all of the macro definitions to this file instead? > Could we also fix the spelling, in a patch preceding this one? Ok, modify in v2. Thanks, Ming >=20 > / > Leif >=20 >> + >> +EFI_STATUS >> +SwitchRtcI2cChannelAndLock ( >> + VOID >> + ); >> + >> +VOID >> +ReleaseOwnershipOfRtc ( >> + VOID >> + ); >> + >> +#endif >> diff --git a/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83Re= alTimeClockLib.c b/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T8= 3RealTimeClockLib.c >> index 5131ce7..e3fecac 100644 >> --- a/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83RealTimeC= lockLib.c >> +++ b/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83RealTimeC= lockLib.c >> @@ -11,10 +11,9 @@ >> #include >> #include >> #include >> -#include >> -#include >> #include >> #include >> +#include >> #include >> #include >> #include >> @@ -26,70 +25,6 @@ extern I2C_DEVICE gRtcDevice; >> =20 >> STATIC EFI_LOCK mRtcLock; >> =20 >> -EFI_STATUS >> -SwitchRtcI2cChannelAndLock ( >> - VOID >> - ) >> -{ >> - UINT8 Temp; >> - UINT8 Count; >> - >> - for (Count =3D 0; Count < 100; Count++) { >> - // To get the other side's state is idle first >> - Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> - if ((Temp & BIT3) !=3D 0) { >> - (VOID) MicroSecondDelay (RTC_DELAY_30_MS); >> - // Try 100 times, if BMC has not released the bus, return preem= ption failed >> - if (Count =3D=3D 99) { >> - if (!EfiAtRuntime ()) { >> - DEBUG ((DEBUG_ERROR, "[%a]:[%dL] Clear cpu_i2c_rtc_state 10= 0 times fail!\n", >> - __FUNCTION__, __LINE__)); >> - } >> - return EFI_DEVICE_ERROR; >> - } >> - continue; >> - } >> - >> - // if BMC free the bus, can be set 1 preemption >> - Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> - Temp =3D Temp | CPU_GET_I2C_CONTROL; >> - // CPU occupied RTC I2C State >> - WriteCpldReg (CPLD_I2C_SWITCH_FLAG, Temp); >> - (VOID) MicroSecondDelay (RTC_DELAY_2_MACROSECOND); >> - Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> - // Is preempt success >> - if(CPU_GET_I2C_CONTROL =3D=3D (Temp & CPU_GET_I2C_CONTROL)) { >> - break; >> - } >> - if (Count =3D=3D 99) { >> - if (!EfiAtRuntime ()) { >> - DEBUG((DEBUG_ERROR, "[%a]:[%dL] Clear cpu_i2c_rtc_state fail= !!! \n", >> - __FUNCTION__, __LINE__)); >> - } >> - return EFI_DEVICE_ERROR; >> - } >> - (VOID) MicroSecondDelay (RTC_DELAY_30_MS); >> - } >> - >> - //Polling BMC RTC I2C status >> - for (Count =3D 0; Count < 100; Count++) { >> - Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> - if ((Temp & BIT3) =3D=3D 0) { >> - return EFI_SUCCESS; >> - } >> - (VOID) MicroSecondDelay (RTC_DELAY_30_MS); >> - } >> - >> - //If the BMC occupies the RTC I2C Channel, write back the CPU side = is idle >> - // or the subsequent BMC will not preempt >> - Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> - Temp =3D Temp & (~CPU_GET_I2C_CONTROL); >> - WriteCpldReg (CPLD_I2C_SWITCH_FLAG, Temp); >> - >> - return EFI_NOT_READY; >> -} >> - >> - >> /** >> Read RTC content through its registers. >> =20 >> @@ -136,19 +71,6 @@ RtcWrite ( >> return Status; >> } >> =20 >> -VOID >> -ReleaseOwnershipOfRtc ( >> - VOID >> - ) >> -{ >> - UINT8 Temp; >> - >> - Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> - Temp =3D Temp & ~CPU_GET_I2C_CONTROL; >> - WriteCpldReg (CPLD_I2C_SWITCH_FLAG, Temp); >> -} >> - >> - >> EFI_STATUS >> InitializeM41T83 ( >> VOID >> diff --git a/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83Re= alTimeClockLib.inf b/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41= T83RealTimeClockLib.inf >> index 9344c6d..5970c0e 100644 >> --- a/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83RealTimeC= lockLib.inf >> +++ b/Silicon/Hisilicon/Library/M41T83RealTimeClockLib/M41T83RealTimeC= lockLib.inf >> @@ -31,6 +31,7 @@ >> I2CLib >> IoLib >> PcdLib >> + RtcHelperLib >> TimeBaseLib >> TimerLib >> UefiLib >> diff --git a/Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.c b/S= ilicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.c >> new file mode 100644 >> index 0000000..bc8e6c5 >> --- /dev/null >> +++ b/Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.c >> @@ -0,0 +1,94 @@ >> +/** @file >> + >> + Copyright (c) 2020, Hisilicon Limited. All rights reserved.
>> + >> + SPDX-License-Identifier: BSD-2-Clause-Patent >> + >> +**/ >> + >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> + >> +EFI_STATUS >> +SwitchRtcI2cChannelAndLock ( >> + VOID >> + ) >> +{ >> + UINT8 Temp; >> + UINT8 Count; >> + >> + for (Count =3D 0; Count < 100; Count++) { >> + // To get the other side's state is idle first >> + Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> + if ((Temp & BIT3) !=3D 0) { >> + (VOID) MicroSecondDelay (RTC_DELAY_30_MS); >> + // Try 100 times, if BMC has not released the bus, return preem= ption failed >> + if (Count =3D=3D 99) { >> + if (!EfiAtRuntime ()) { >> + DEBUG ((DEBUG_ERROR, "[%a]:[%dL] Clear cpu_i2c_rtc_state 10= 0 times fail!\n", >> + __FUNCTION__, __LINE__)); >> + } >> + return EFI_DEVICE_ERROR; >> + } >> + continue; >> + } >> + >> + // if BMC free the bus, can be set 1 preemption >> + Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> + Temp =3D Temp | CPU_GET_I2C_CONTROL; >> + // CPU occupied RTC I2C State >> + WriteCpldReg (CPLD_I2C_SWITCH_FLAG, Temp); >> + (VOID)MicroSecondDelay (RTC_DELAY_2_MACROSECOND); >> + Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> + // Is preempt success >> + if (CPU_GET_I2C_CONTROL =3D=3D (Temp & CPU_GET_I2C_CONTROL)) { >> + break; >> + } >> + if (Count =3D=3D 99) { >> + if (!EfiAtRuntime ()) { >> + DEBUG ((DEBUG_ERROR, "[%a]:[%dL] Clear cpu_i2c_rtc_state fai= l !!! \n", >> + __FUNCTION__, __LINE__)); >> + } >> + return EFI_DEVICE_ERROR; >> + } >> + (VOID)MicroSecondDelay (RTC_DELAY_30_MS); >> + } >> + >> + //Polling BMC RTC I2C status >> + for (Count =3D 0; Count < 100; Count++) { >> + Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> + if ((Temp & BIT3) =3D=3D 0) { >> + return EFI_SUCCESS; >> + } >> + (VOID)MicroSecondDelay (RTC_DELAY_30_MS); >> + } >> + >> + //If the BMC occupies the RTC I2C Channel, write back the CPU side = is idle >> + // or the subsequent BMC will not preempt >> + Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> + Temp =3D Temp & (~CPU_GET_I2C_CONTROL); >> + WriteCpldReg (CPLD_I2C_SWITCH_FLAG, Temp); >> + >> + return EFI_NOT_READY; >> +} >> + >> +VOID >> +ReleaseOwnershipOfRtc ( >> + VOID >> + ) >> +{ >> + UINT8 Temp; >> + >> + Temp =3D ReadCpldReg (CPLD_I2C_SWITCH_FLAG); >> + Temp =3D Temp & ~CPU_GET_I2C_CONTROL; >> + WriteCpldReg (CPLD_I2C_SWITCH_FLAG, Temp); >> + return ; >> +} >> diff --git a/Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.inf b= /Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.inf >> new file mode 100644 >> index 0000000..1a36e64 >> --- /dev/null >> +++ b/Silicon/Hisilicon/Library/RtcHelperLib/RtcHelperLib.inf >> @@ -0,0 +1,32 @@ >> +#/** @file >> +# >> +# Copyright (c) 2020, Hisilicon Limited. All rights reserved.
>> +# >> +# SPDX-License-Identifier: BSD-2-Clause-Patent >> +# >> +#**/ >> + >> +[Defines] >> + INF_VERSION =3D 0x0001001A >> + BASE_NAME =3D RtcHelperLib >> + FILE_GUID =3D 5cb1a98f-2408-4fef-b68f-d5d04ff6= a91f >> + MODULE_TYPE =3D BASE >> + VERSION_STRING =3D 1.0 >> + LIBRARY_CLASS =3D RtcHelperLib >> + >> +[Sources.common] >> + RtcHelperLib.c >> + >> +[Packages] >> + EmbeddedPkg/EmbeddedPkg.dec >> + MdePkg/MdePkg.dec >> + Platform/Hisilicon/D06/D06.dec >> + Silicon/Hisilicon/HisiPkg.dec >> + >> +[LibraryClasses] >> + CpldIoLib >> + DebugLib >> + IoLib >> + >> +[Depex] >> + TRUE >> --=20 >> 2.8.1 >> >=20 > . >=20