it works fine.
Thanks,
Chen
On 03/05/2015 02:07 PM, Fan, Jeff wrote:
> Please try the following updating to check if compiling error gone.
>
> Index: CpuMp.c
> ===================================================================
> --- CpuMp.c (revision 17009)
> +++ CpuMp.c (working copy)
> @@ -1157,7 +1157,7 @@
> UINTN ProcessorNumber;
> CPU_DATA_BLOCK *CpuData;
> EFI_AP_PROCEDURE Procedure;
> - VOID *ProcedureArgument;
> + volatile VOID *ProcedureArgument;
>
> AsmApDoneWithCommonStack ();
>
> @@ -1190,7 +1190,7 @@
> ReleaseMpSpinLock (CpuData);
>
> if (Procedure != NULL) {
> - Procedure (ProcedureArgument);
> + Procedure ((VOID *) ProcedureArgument);
>
> GetMpSpinLock (CpuData);
> CpuData->Procedure = NULL;
> Index: CpuMp.h
> ===================================================================
> --- CpuMp.h (revision 17009)
> +++ CpuMp.h (working copy)
> @@ -93,8 +93,8 @@
> INTN LockSelf;
> volatile CPU_STATE State;
>
> - EFI_AP_PROCEDURE Procedure;
> - VOID *Parameter;
> + volatile EFI_AP_PROCEDURE Procedure;
> + volatile VOID * Parameter;
> BOOLEAN *Finished;
> INTN Timeout;
> EFI_EVENT WaitEvent;
>
> Jeff
> -----Original Message-----
> From: Chen Fan [mailto:[email protected]]
> Sent: Thursday, March 05, 2015 1:07 PM
> To: Fan, Jeff; [email protected]
> Cc: Justen, Jordan L
> Subject: Re: [v3 4/4] UefiCpuPkg/MpSerivce: add volatile qualifiers
>
>
> On 03/05/2015 01:09 PM, Fan, Jeff wrote:
>> Please align the volatile's position as below.
>> + volatile EFI_AP_PROCEDURE Procedure;
>> + volatile VOID* Parameter;
> For Parameter should:
> VOID* volatile Parameter;
>
> otherwise, will cause compile error.
> UefiCpuPkg/CpuDxe/CpuMp.c:1228:23: error: assignment discards 'volatile'
> qualifier from pointer target type
>
> Thanks,
> Chen
>
>> -----Original Message-----
>> From: Chen Fan [mailto:[email protected]]
>> Sent: Thursday, March 05, 2015 11:55 AM
>> To: [email protected]
>> Cc: Fan, Jeff; Justen, Jordan L
>> Subject: [v3 4/4] UefiCpuPkg/MpSerivce: add volatile qualifiers
>>
>> For avoid the compiler optimizing the code, we let Parameter and Procedure
>> in CpuData volatile.
>>
>> Contributed-under: TianoCore Contribution Agreement 1.0
>> Signed-off-by: Chen Fan <[email protected]>
>> ---
>> UefiCpuPkg/CpuDxe/CpuMp.h | 4 ++--
>> 1 file changed, 2 insertions(+), 2 deletions(-)
>>
>> diff --git a/UefiCpuPkg/CpuDxe/CpuMp.h b/UefiCpuPkg/CpuDxe/CpuMp.h index
>> cb3460f..deafbc7 100644
>> --- a/UefiCpuPkg/CpuDxe/CpuMp.h
>> +++ b/UefiCpuPkg/CpuDxe/CpuMp.h
>> @@ -94,8 +94,8 @@ typedef struct {
>> INTN LockSelf;
>> volatile CPU_STATE State;
>>
>> - EFI_AP_PROCEDURE Procedure;
>> - VOID *Parameter;
>> + volatile EFI_AP_PROCEDURE Procedure;
>> + VOID* volatile Parameter;
>> BOOLEAN *Finished;
>> INTN Timeout;
>> EFI_EVENT WaitEvent;
>> --
>> 1.9.3
>>
>> .
>>
> .
>
------------------------------------------------------------------------------
Dive into the World of Parallel Programming The Go Parallel Website, sponsored
by Intel and developed in partnership with Slashdot Media, is your hub for all
things parallel software development, from weekly thought leadership blogs to
news, videos, case studies, tutorials and more. Take a look and join the
conversation now. http://goparallel.sourceforge.net/
_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/edk2-devel