Re: [PATCH 1/6] platform/x86/intel/tpmi: Add additional TPMI header fields
From: srinivas pandruvada
Date: Thu Nov 30 2023 - 09:10:26 EST
On Thu, 2023-11-30 at 14:33 +0200, Ilpo Järvinen wrote:
> On Tue, 28 Nov 2023, Srinivas Pandruvada wrote:
>
> > TPMI information header added additional fields in version 2. Some
> > of the
> > reserved fields in version 1 are used to define new fields.
> > Parse new fields and export as part of platform data. These fields
> > include:
> > - PCI segment ID
> > - Partition ID of the package, useful when more than one Intel VSEC
> > PCI
> > device per package
> > - cdie_mask: Mask of all compute dies in this partition
> >
> > Signed-off-by: Srinivas Pandruvada
> > <srinivas.pandruvada@xxxxxxxxxxxxxxx>
> > ---
> > drivers/platform/x86/intel/tpmi.c | 11 ++++++++++-
> > include/linux/intel_tpmi.h | 6 ++++++
> > 2 files changed, 16 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/platform/x86/intel/tpmi.c
> > b/drivers/platform/x86/intel/tpmi.c
> > index 311abcac894a..c89aa4d14bea 100644
> > --- a/drivers/platform/x86/intel/tpmi.c
> > +++ b/drivers/platform/x86/intel/tpmi.c
> > @@ -128,6 +128,9 @@ struct intel_tpmi_info {
> > * @dev: PCI device number
> > * @bus: PCI bus number
> > * @pkg: CPU Package id
> > + * @segment: PCI segment id
> > + * @partition: Package Partition id
> > + * @cdie_mask: Bitmap of compute dies in the current partition
> > * @reserved: Reserved for future use
> > * @lock: When set to 1 the register is locked and becomes
> > read-only
> > * until next reset. Not for use by the OS driver.
> > @@ -139,7 +142,10 @@ struct tpmi_info_header {
> > u64 dev:5;
> > u64 bus:8;
> > u64 pkg:8;
> > - u64 reserved:39;
> > + u64 segment:8;
> > + u64 partition:2;
> > + u64 cdie_mask:16;
> > + u64 reserved:13;
> > u64 lock:1;
> > } __packed;
> > @@ -684,6 +690,9 @@ static int tpmi_process_info(struct
> > intel_tpmi_info *tpmi_info,
> > tpmi_info->plat_info.bus_number = header.bus;
> > tpmi_info->plat_info.device_number = header.dev;
> > tpmi_info->plat_info.function_number = header.fn;
> > + tpmi_info->plat_info.cdie_mask = header.cdie_mask;
> > + tpmi_info->plat_info.partition = header.partition;
> > + tpmi_info->plat_info.segment = header.segment;
> >
> > iounmap(info_mem);
> >
> > diff --git a/include/linux/intel_tpmi.h
> > b/include/linux/intel_tpmi.h
> > index ee07393445f9..939663bb095f 100644
> > --- a/include/linux/intel_tpmi.h
> > +++ b/include/linux/intel_tpmi.h
> > @@ -14,7 +14,10 @@
> >
> > /**
> > * struct intel_tpmi_plat_info - Platform information for a TPMI
> > device instance
> > + * @cdie_mask: Mask of all compute dies in the partition
> > * @package_id: CPU Package id
> > + * @partition: Package partition id when multiple VSEC PCI
> > devices per package
> > + * @segment: PCI segment ID
> > * @bus_number: PCI bus number
> > * @device_number: PCI device number
> > * @function_number: PCI function number
> > @@ -23,7 +26,10 @@
> > * struct is used to return data via tpmi_get_platform_data().
> > */
> > struct intel_tpmi_plat_info {
> > + u16 cdie_mask;
> > u8 package_id;
> > + u8 partition;
> > + u8 segment;
> > u8 bus_number;
> > u8 device_number;
> > u8 function_number;
>
> I've a number of questions about this patch...
>
> - There no version check anywhere, yet commit message talks about v2?
>
No need to check, as the other fields will be 0s in v1.
> - What will those fields have in v1?
They are 0s as they were reserved for future use.
>
> - Entirely unrelated to the rest of this serie? So no users for
> these?
> Why not send this along with the patches containing the actual
> users
> so it'd have been easier to find the answers from the patches?
>
This is the core changes, so submitted as changes done in specs.
But fine to bundle with next series. I limit number of changes per
kernel release in the order of importance in the current products.
Thanks,
Srinivas