From 4f18c6e55049d858c62e87d2605dd41c06956e4e Mon Sep 17 00:00:00 2001 From: Anup Patel Date: Tue, 28 Apr 2020 09:35:32 +0530 Subject: [PATCH] platform: generic: Add Sifive FU540 TLB flush range limit override We need to override the remote TLB flush range limit for SiFive FU540 so we add platform override to achieve this. Signed-off-by: Anup Patel Reviewed-by: Atish Patra --- platform/generic/objects.mk | 1 + platform/generic/platform.c | 6 +++++- platform/generic/sifive_fu540.c | 33 +++++++++++++++++++++++++++++++++ 3 files changed, 39 insertions(+), 1 deletion(-) create mode 100644 platform/generic/sifive_fu540.c diff --git a/platform/generic/objects.mk b/platform/generic/objects.mk index 5ed44373..d6c8a42d 100644 --- a/platform/generic/objects.mk +++ b/platform/generic/objects.mk @@ -8,3 +8,4 @@ # platform-objs-y += platform.o +platform-objs-y += sifive_fu540.o diff --git a/platform/generic/platform.c b/platform/generic/platform.c index cb16cc44..7b4a0aef 100644 --- a/platform/generic/platform.c +++ b/platform/generic/platform.c @@ -21,7 +21,11 @@ #include #include -static const struct platform_override *special_platforms[] = { }; +extern const struct platform_override sifive_fu540; + +static const struct platform_override *special_platforms[] = { + &sifive_fu540, +}; static const struct platform_override *generic_plat = NULL; static const struct fdt_match *generic_plat_match = NULL; diff --git a/platform/generic/sifive_fu540.c b/platform/generic/sifive_fu540.c new file mode 100644 index 00000000..9ddafa0e --- /dev/null +++ b/platform/generic/sifive_fu540.c @@ -0,0 +1,33 @@ +/* + * SPDX-License-Identifier: BSD-2-Clause + * + * Copyright (c) 2020 Western Digital Corporation or its affiliates. + * + * Authors: + * Anup Patel + */ + +#include +#include + +static u64 sifive_fu540_tlbr_flush_limit(const struct fdt_match *match) +{ + /* + * The sfence.vma by virtual address does not work on + * SiFive FU540 so we return remote TLB flush limit as zero. + */ + return 0; +} + +static const struct fdt_match sifive_fu540_match[] = { + { .compatible = "sifive,fu540" }, + { .compatible = "sifive,fu540g" }, + { .compatible = "sifive,fu540-c000" }, + { .compatible = "sifive,hifive-unleashed-a00" }, + { }, +}; + +const struct platform_override sifive_fu540 = { + .match_table = sifive_fu540_match, + .tlbr_flush_limit = sifive_fu540_tlbr_flush_limit, +};