[PATCH v3 03/16] cacheinfo: Move cache_leaves_are_shared out of CONFIG_OF
Gavin Shan
gshan at redhat.com
Tue May 31 19:51:41 PDT 2022
Hi Sudeep,
On 5/25/22 4:14 PM, Sudeep Holla wrote:
> cache_leaves_are_shared is already used even with ACPI and PPTT. It checks
> if the cache leaves are the shared based on fw_token pointer. However it is
> defined conditionally only if CONFIG_OF is enabled which is wrong.
>
> Move the function cache_leaves_are_shared out of CONFIG_OF and keep it
> generic. It also handles the case where both OF and ACPI is not defined.
>
> Signed-off-by: Sudeep Holla <sudeep.holla at arm.com>
> ---
> drivers/base/cacheinfo.c | 20 +++++++++-----------
> 1 file changed, 9 insertions(+), 11 deletions(-)
>
With below nits fixed:
Reviewed-by: Gavin Shan <gshan at redhat.com>
> diff --git a/drivers/base/cacheinfo.c b/drivers/base/cacheinfo.c
> index c4547d8ac6f3..417e1ebf5525 100644
> --- a/drivers/base/cacheinfo.c
> +++ b/drivers/base/cacheinfo.c
> @@ -33,13 +33,21 @@ struct cpu_cacheinfo *get_cpu_cacheinfo(unsigned int cpu)
> return ci_cacheinfo(cpu);
> }
>
> -#ifdef CONFIG_OF
> static inline bool cache_leaves_are_shared(struct cacheinfo *this_leaf,
> struct cacheinfo *sib_leaf)
> {
> + /*
> + * For non DT/ACPI systems, assume unique level 1 caches,
> + * system-wide shared caches for all other levels. This will be used
> + * only if arch specific code has not populated shared_cpu_map
> + */
> + if (!IS_ENABLED(CONFIG_OF) && !(IS_ENABLED(CONFIG_ACPI)))
> + return !(this_leaf->level == 1);
> +
> return sib_leaf->fw_token == this_leaf->fw_token;
> }
>
if (!IS_ENABLED(CONFIG_OF) && !IS_ENABLED(CONFIG_ACPI))
or
if (!(IS_ENABLED(CONFIG_OF) || IS_ENABLED(CONFIG_ACPI)))
> +#ifdef CONFIG_OF
> /* OF properties to query for a given cache type */
> struct cache_type_info {
> const char *size_prop;
> @@ -193,16 +201,6 @@ static int cache_setup_of_node(unsigned int cpu)
> }
> #else
> static inline int cache_setup_of_node(unsigned int cpu) { return 0; }
> -static inline bool cache_leaves_are_shared(struct cacheinfo *this_leaf,
> - struct cacheinfo *sib_leaf)
> -{
> - /*
> - * For non-DT/ACPI systems, assume unique level 1 caches, system-wide
> - * shared caches for all other levels. This will be used only if
> - * arch specific code has not populated shared_cpu_map
> - */
> - return !(this_leaf->level == 1);
> -}
> #endif
>
> int __weak cache_setup_acpi(unsigned int cpu)
>
Thanks,
Gavin
More information about the linux-riscv
mailing list