[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PULL 10/29] hw/core: Check smp cache topology support for machine
From: |
Zhao Liu |
Subject: |
Re: [PULL 10/29] hw/core: Check smp cache topology support for machine |
Date: |
Sun, 10 Nov 2024 22:12:10 +0800 |
Hi Peter,
On Fri, Nov 08, 2024 at 07:16:50PM +0000, Peter Maydell wrote:
> Date: Fri, 8 Nov 2024 19:16:50 +0000
> From: Peter Maydell <peter.maydell@linaro.org>
> Subject: Re: [PULL 10/29] hw/core: Check smp cache topology support for
> machine
>
> On Tue, 5 Nov 2024 at 22:49, Philippe Mathieu-Daudé <philmd@linaro.org> wrote:
> >
> > From: Zhao Liu <zhao1.liu@intel.com>
> >
> > Add cache_supported flags in SMPCompatProps to allow machines to
> > configure various caches support.
> >
> > And check the compatibility of the cache properties with the
> > machine support in machine_parse_smp_cache().
>
> Hi; Coverity points out an issue in this code (CID 1565391):
>
> > bool machine_parse_smp_cache(MachineState *ms,
> > const SmpCachePropertiesList *caches,
> > Error **errp)
> > {
> > + MachineClass *mc = MACHINE_GET_CLASS(ms);
> > const SmpCachePropertiesList *node;
> > DECLARE_BITMAP(caches_bitmap, CACHE_LEVEL_AND_TYPE__MAX);
> >
> > @@ -283,6 +305,25 @@ bool machine_parse_smp_cache(MachineState *ms,
> > set_bit(node->value->cache, caches_bitmap);
> > }
> >
> > + for (int i = 0; i < CACHE_LEVEL_AND_TYPE__MAX; i++) {
> > + const SmpCacheProperties *props = &ms->smp_cache.props[i];
> > +
> > + /*
> > + * Reject non "default" topology level if the cache isn't
> > + * supported by the machine.
> > + */
> > + if (props->topology != CPU_TOPOLOGY_LEVEL_DEFAULT &&
> > + !mc->smp_props.cache_supported[props->cache]) {
> > + error_setg(errp,
> > + "%s cache topology not supported by this machine",
> > + CacheLevelAndType_str(node->value->cache));
>
> This error message looks at "node", but "node" was the iteration
> variable in the first loop in this function, so generally at
> this point it will be NULL because that is the loop termination
> condition.
>
> The code looks like it ought to be reporting an error relating
> to the 'props' variable, not 'node' ?
Thank you! My fault and you're right, here I should use "props->cache"
instead of "node->value->cache". I'll submit a patch to fix this.
Regards,
Zhao
- [PULL 04/29] hw/microblaze/s3adsp1800: Rename unimplemented MMIO region as xps_gpio, (continued)
- [PULL 04/29] hw/microblaze/s3adsp1800: Rename unimplemented MMIO region as xps_gpio, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 05/29] hw/microblaze/s3adsp1800: Declare machine type using DEFINE_TYPES macro, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 06/29] hw/core/machine: Add missing 'units.h' and 'error-report.h' headers, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 07/29] i386/cpu: Don't enumerate the "invalid" CPU topology level, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 08/29] hw/core: Make CPU topology enumeration arch-agnostic, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 09/29] qapi/qom: Define cache enumeration and properties for machine, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 10/29] hw/core: Check smp cache topology support for machine, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 11/29] hw/core: Add a helper to check the cache topology level, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 12/29] hw/ppc/e500: Prefer QOM cast, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 13/29] hw/ppc/e500: Remove unused "irqs" parameter, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 14/29] hw/ppc/e500: Add missing device tree properties to i2c controller node, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 15/29] hw/ppc/mpc8544_guts: Populate POR PLL ratio status register, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 17/29] hw/i2c/mpc_i2c: Prefer DEFINE_TYPES() macro, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 18/29] hw/pci-host/ppce500: Reuse TYPE_PPC_E500_PCI_BRIDGE define, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 21/29] hw/net/fsl_etsec/etsec: Prefer DEFINE_TYPES() macro, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 16/29] hw/i2c/mpc_i2c: Convert DPRINTF to trace events for register access, Philippe Mathieu-Daudé, 2024/11/05
- [PULL 19/29] hw/pci-host/ppce500: Prefer DEFINE_TYPES() macro, Philippe Mathieu-Daudé, 2024/11/05