public inbox for devel@edk2.groups.io
 help / color / mirror / Atom feed
From: "Chao Li" <lichao@loongson.cn>
To: devel@edk2.groups.io, ray.ni@intel.com
Cc: "Dong, Eric" <eric.dong@intel.com>,
	"Kumar, Rahul R" <rahul.r.kumar@intel.com>,
	Gerd Hoffmann <kraxel@redhat.com>,
	Leif Lindholm <quic_llindhol@quicinc.com>,
	Ard Biesheuvel <ardb+tianocore@kernel.org>,
	Sami Mujawar <sami.mujawar@arm.com>,
	Sunil V L <sunilvl@ventanamicro.com>,
	"Warkentin, Andrei" <andrei.warkentin@intel.com>
Subject: Re: [edk2-devel] [PATCH v4 12/37] UefiCpuPkg: Add CpuMmuLib.h to UefiCpuPkg
Date: Tue, 19 Dec 2023 09:59:11 +0800	[thread overview]
Message-ID: <0e0d16f2-cf43-45cc-a79c-b27d556aa0ea@loongson.cn> (raw)
In-Reply-To: <17A0932406FD861E.11381@groups.io>

[-- Attachment #1: Type: text/plain, Size: 3555 bytes --]

Hi Ray,

For the GetMemoryRegionAttributes, here are some of my plans:


Thanks,
Chao
On 2023/12/14 10:53, Chao Li wrote:
> Hi Ray,
>
> For you two comments:
>
> BTY, can you review the other UefiCpuPkg patches in this series?
>
> On 2023/12/13 下午1:17, Ni, Ray wrote:
>> Chao,
>> Thanks for providing such a cleaner lib API.
>> Only 2 comments in below:
>>
>>> +
>>> +#define EFI_MEMORY_CACHETYPE_MASK  (EFI_MEMORY_UC  | \
>>> +                                    EFI_MEMORY_WC  | \
>>> +                                    EFI_MEMORY_WT  | \
>>> +                                    EFI_MEMORY_WB  | \
>>> +                                    EFI_MEMORY_UCE   \
>>> +                                    )
>> 1. Why do you need to define the EFI_MEMORY_CACHETYPE_MASK here?
>> Can you just mention that the following APIs only return 5 bits: 
>> UC/WC/WT/WB/UCE
>> without defining the EFI_MEMORY_CACHETYPE_MASK?
> Agree, I will remove this definition in V5 and if someone uses this 
> macro, it will be private.
>>
>>> +
>>> +typedef struct {
>>> +  EFI_PHYSICAL_ADDRESS    PhysicalBase;
>>> +  EFI_VIRTUAL_ADDRESS     VirtualBase;
>>> +  UINTN                   Length;
>>> +  UINTN                   Attributes;
>>> +} MEMORY_REGION_DESCRIPTOR;
>>> +
>>> +/**
>>> +  Finds the length and memory properties of the memory region
>>> corresponding to the specified base address.
>>> +
>>> +  @param[in]  BaseAddress    To find the base address of the memory
>>> region.
>>> +  @param[in]  EndAddress     To find the end address of the memory
>>> region.
>>> +  @param[out]  RegionLength    The length of the memory region
>>> found.
>>> +  @param[out]  RegionAttributes    Properties of the memory region
>>> found.
>>> +
>>> +  @retval  EFI_SUCCESS    The corresponding memory area was
>>> successfully found
>>> +           EFI_NOT_FOUND    No memory area found
>>> +**/
>>> +EFI_STATUS
>>> +EFIAPI
>>> +GetMemoryRegionAttributes (
>>> +  IN     UINTN  BaseAddress,
>>> +  IN     UINTN  EndAddress,
>>> +  OUT    UINTN  *RegionLength,
>>> +  OUT    UINTN  *RegionAttributes
>>> +  );
>> 2. If the actual memory ranges are as follows:
>> [0 - 1M, UC]
>> [1M - 1G, WB]
>>
>> What's the result of following call:
>> a. GetMemoryRegionAttributes (512KB, 1MB)
>> b. GetMemoryRegionAttributes (512KB, 2MB)
> Yes, if the given memory region has two or more types of attributes, 
> this API may return the first attribute, I should design this API 
> again, thanks.

For this API, I think there may be two options:

*Plan A:*

It will return all of the attributes and lengths located in the region. 
We need to return a pointer to a structure that records the attributes 
and length of each part.

*Plan B:*

It only returns the attribute and length of the first part, leaving it 
up to the caller to decide to look for the next part.


I'm leaning toward plan B, what do you think?

>>
>>
>>
>>
>>
>
>
>
> 
>


-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#112662): https://edk2.groups.io/g/devel/message/112662
Mute This Topic: https://groups.io/mt/103129095/7686176
Group Owner: devel+owner@edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [rebecca@openfw.io]
-=-=-=-=-=-=-=-=-=-=-=-



[-- Attachment #2: Type: text/html, Size: 6368 bytes --]

  parent reply	other threads:[~2023-12-19  1:59 UTC|newest]

Thread overview: 75+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-12-12 13:09 [edk2-devel] [PATCH v4 00/37] Enable LoongArch virtual machine in edk2 Chao Li
2023-12-12 13:10 ` [edk2-devel] [PATCH v4 01/37] MdePkg: Add the header file named Csr.h for LoongArch64 Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 02/37] MdePkg: Add LoongArch64 FPU function set into BaseCpuLib Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 03/37] MdePkg: Add LoongArch64 exception function set into BaseLib Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 04/37] MdePkg: Add LoongArch64 local interrupt " Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 05/37] MdePkg: Add LoongArch Cpucfg function Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 06/37] MdePkg: Add read stable counter operation for LoongArch Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 07/37] MdePkg: Add CSR " Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 08/37] MdePkg: Add IOCSR " Chao Li
2023-12-12 13:11 ` [edk2-devel] [PATCH v4 09/37] MdePkg: Add a new library named PeiServicesTablePointerLibKs0 Chao Li
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 10/37] UefiCpuPkg: Add LoongArch64 CPU Timer library Chao Li
2023-12-19  6:29   ` Ni, Ray
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 11/37] UefiCpuPkg: Add CPU exception library for LoongArch Chao Li
2023-12-19  6:30   ` Ni, Ray
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 12/37] UefiCpuPkg: Add CpuMmuLib.h to UefiCpuPkg Chao Li
2023-12-13  5:17   ` Ni, Ray
2023-12-14  2:53     ` Chao Li
     [not found]     ` <17A0932406FD861E.11381@groups.io>
2023-12-19  1:59       ` Chao Li [this message]
2023-12-19  6:29         ` Ni, Ray
2023-12-19  6:56           ` Chao Li
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 13/37] UefiCpuPkg: Add LoongArch64CpuMmuLib " Chao Li
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 14/37] UefiCpuPkg: Add multiprocessor library for LoongArch64 Chao Li
2023-12-19  6:30   ` Ni, Ray
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 15/37] UefiCpuPkg: Add CpuDxe driver " Chao Li
2023-12-19  6:30   ` Ni, Ray
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 16/37] EmbeddedPkg: Add PcdPrePiCpuIoSize width for LOONGARCH64 Chao Li
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 17/37] ArmVirtPkg: Move PCD of FDT base address and FDT padding to OvmfPkg Chao Li
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 18/37] MdePkg: Add a PCD feature flag named PcdPciIoTranslationIsEnabled Chao Li
2023-12-12 13:12 ` [edk2-devel] [PATCH v4 19/37] UefiCpuPkg: Add MMIO method in CpuIo2Dxe Chao Li
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 20/37] ArmVirtPkg: Enable UefiCpuPkg version CpuIo2Dxe Chao Li
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 21/37] OvmfPkg/RiscVVirt: " Chao Li
2023-12-20  7:01   ` Sunil V L
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 22/37] OvmfPkg/RiscVVirt: Remove PciCpuIo2Dxe from RiscVVirt Chao Li
2023-12-20  7:02   ` Sunil V L
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 23/37] ArmVirtPkg: Move the FdtSerialPortAddressLib to OvmfPkg Chao Li
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 24/37] ArmVirtPkg: Move the PcdTerminalTypeGuidBuffer into OvmfPkg Chao Li
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 25/37] ArmVirtPkg: Move PlatformBootManagerLib to OvmfPkg Chao Li
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 26/37] OvmfPkg/LoongArchVirt: Add stable timer driver Chao Li
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 27/37] OvmfPkg/LoongArchVirt: Add a NULL library named CollectApResouceLibNull Chao Li
2023-12-12 13:13 ` [edk2-devel] [PATCH v4 28/37] OvmfPkg/LoongArchVirt: Add serial port hook library Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 29/37] OvmfPkg/LoongArchVirt: Add the early serial port output library Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 30/37] OvmfPkg/LoongArchVirt: Add real time clock library Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 31/37] OvmfPkg/LoongArchVirt: Add NorFlashQemuLib Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 32/37] OvmfPkg/LoongArchVirt: Add FdtQemuFwCfgLib Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 33/37] OvmfPkg/LoongArchVirt: Add reset system library Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 34/37] OvmfPkg/LoongArchVirt: Support SEC phase Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 35/37] OvmfPkg/LoongArchVirt: Support PEI phase Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 36/37] OvmfPkg/LoongArchVirt: Add build file Chao Li
2023-12-12 13:14 ` [edk2-devel] [PATCH v4 37/37] OvmfPkg/LoongArchVirt: Add self introduction file Chao Li
     [not found] ` <17A017B459AD36A8.31409@groups.io>
2023-12-19 12:59   ` [edk2-devel] [PATCH v4 09/37] MdePkg: Add a new library named PeiServicesTablePointerLibKs0 Chao Li
2023-12-19 13:01   ` Chao Li
2023-12-19 13:07     ` 回复: " gaoliming via groups.io
2023-12-20  1:20       ` Chao Li
2023-12-21  7:16         ` 回复: " gaoliming via groups.io
2023-12-21 11:18           ` Chao Li
2023-12-25  1:33             ` 回复: " gaoliming via groups.io
2023-12-27  1:43               ` Chao Li
     [not found] ` <17A017C0864F4177.31409@groups.io>
2023-12-19 13:02   ` [edk2-devel] [PATCH v4 18/37] MdePkg: Add a PCD feature flag named PcdPciIoTranslationIsEnabled Chao Li
     [not found] ` <17A017C201FEB90D.32321@groups.io>
2023-12-19 13:03   ` [edk2-devel] [PATCH v4 19/37] UefiCpuPkg: Add MMIO method in CpuIo2Dxe Chao Li
2023-12-20  1:57     ` Ni, Ray
2023-12-20  7:41       ` Ard Biesheuvel
2023-12-20  9:44         ` Ni, Ray
2023-12-20  9:54           ` Ard Biesheuvel
2023-12-20 12:28             ` Ni, Ray
2023-12-20 15:17               ` Ard Biesheuvel
2023-12-21  3:48         ` Chao Li
2023-12-21  7:31           ` Ard Biesheuvel
2023-12-21 12:11             ` Chao Li
2023-12-21 12:31               ` Ard Biesheuvel
2023-12-21 12:41                 ` Chao Li
2023-12-21 13:59                   ` Ard Biesheuvel
2023-12-22  1:14                     ` Chao Li
2023-12-22  2:37                       ` Ni, Ray
2023-12-22  9:47                         ` Ard Biesheuvel
2023-12-22  9:56                           ` Chao Li

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=0e0d16f2-cf43-45cc-a79c-b27d556aa0ea@loongson.cn \
    --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