[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [RFC PATCH 12/19] arm/gic: Add VPENDBASER/VPROPBASER accessors


  • To: Mykyta Poturai <Mykyta_Poturai@xxxxxxxx>
  • From: Mykola Kvach <xakep.amatop@xxxxxxxxx>
  • Date: Wed, 18 Feb 2026 13:30:00 +0200
  • Arc-authentication-results: i=1; mx.google.com; arc=none
  • Arc-message-signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20240605; h=content-transfer-encoding:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=Cs08etBiNYUYlD0ODZUoYef1Y/MZqFHenbZZSUV9sQI=; fh=S1TgsMYO/ju21WOcmYTQxMlAU8ImCjuw50drwKkfBt8=; b=QK9HiIPi22OCkMT3fjV/N+07+dfmbx5V45FnhZJK9zyCcGlYinxPwoiXm5ge8sMENb lQQBljo6twYG39/faNlsluUU4I20RMCIfO5bPOso9LiVKXSG6wzzBzXliXjlUksvuAcY gs4b0jkGl5MxLI6B+/FNeZJqa71dDS48NLVeqf9lXhPTK+mjY4A1/hkCuHiJNXXwROYW Tk8gMVfESZ5fBSiSlh0A1HWX3DZ84+O2oVPuufSsQlggN5xiibIjVlFI4D8mBBKFrS/Q JkCsDOER/QjHkzVjCdxL76QsaF+lzO8zOriwHniRD4gT0I/IRokqrDzJN1ssHR0ffDQw TZag==; darn=lists.xenproject.org
  • Arc-seal: i=1; a=rsa-sha256; t=1771414283; cv=none; d=google.com; s=arc-20240605; b=A65kJh32mXSBGmgaxA8thhfjaStrut5+hJ46vvgP4LgDgsKSojGskvwq9cTRdmc8Ti b6a2FsCpI5dUAt3ppuacFJd1enafxfLnefGPkj9t/skju8wqV7K9kcevItL193cZn2NQ 5RDrFF5DfvCXPHnMcaDSTaHy+DdUy7T2GNI48/wtH/zsiVsnahxKiIZQOI3GhOYkAhfd zspQqwRbcIxNvVlle03Ud/ZZL+D7NIIWlhwfNEZbFqBNl9Ff7KJLObcxncVkSK31AWAh LNIHMzYawn8BZ/PfP442VEFN2S71J7sV+Y09XyTfb3KElF0cVP4dPtJjtpb6p92+eK5L fJ/A==
  • Cc: "xen-devel@xxxxxxxxxxxxxxxxxxxx" <xen-devel@xxxxxxxxxxxxxxxxxxxx>, Stefano Stabellini <sstabellini@xxxxxxxxxx>, Julien Grall <julien@xxxxxxx>, Bertrand Marquis <bertrand.marquis@xxxxxxx>, Michal Orzel <michal.orzel@xxxxxxx>, Volodymyr Babchuk <Volodymyr_Babchuk@xxxxxxxx>
  • Delivery-date: Wed, 18 Feb 2026 11:31:27 +0000
  • List-id: Xen developer discussion <xen-devel.lists.xenproject.org>

Hi Mykyta,

Thank you for the patch!

On Mon, Feb 2, 2026 at 6:14 PM Mykyta Poturai <Mykyta_Poturai@xxxxxxxx> wrote:
>
> Implement accessors for GICv4 registers VPENDBASER and VPROPBASER.
> VPENDBASER access needs special handling to clear the Valid bit before
> writing a new value.
>
> Signed-off-by: Mykyta Poturai <mykyta_poturai@xxxxxxxx>
> ---
>  xen/arch/arm/include/asm/gic_v4_its.h | 38 +++++++++++++++++++++++++++
>  1 file changed, 38 insertions(+)
>
> diff --git a/xen/arch/arm/include/asm/gic_v4_its.h 
> b/xen/arch/arm/include/asm/gic_v4_its.h
> index fb0ef37bbe..ba81b25bde 100644
> --- a/xen/arch/arm/include/asm/gic_v4_its.h
> +++ b/xen/arch/arm/include/asm/gic_v4_its.h
> @@ -17,6 +17,8 @@
>   * along with this program; If not, see <http://www.gnu.org/licenses/>.
>   */
>
> +#include <asm/arm64/io.h>
> +
>  #ifndef __ASM_ARM_GICV4_ITS_H__
>  #define __ASM_ARM_GICV4_ITS_H__
>
> @@ -50,6 +52,42 @@ struct event_vlpi_map {
>  };
>
>  void gicv4_its_vpeid_allocator_init(void);
> +
> +#define GICR_VPROPBASER                              0x0070
> +#define GICR_VPENDBASER                              0x0078
> +
> +#define GICR_VPENDBASER_Dirty                   (1UL << 60)
> +#define GICR_VPENDBASER_PendingLast             (1UL << 61)
> +#define GICR_VPENDBASER_IDAI                    (1UL << 62)
> +#define GICR_VPENDBASER_Valid                   (1UL << 63)
> +
> +#define GICR_VPENDBASER_OUTER_CACHEABILITY_SHIFT         56
> +#define GICR_VPENDBASER_SHAREABILITY_SHIFT               10
> +#define GICR_VPENDBASER_INNER_CACHEABILITY_SHIFT          7
> +
> +#define gits_read_vpropbaser(c)         readq_relaxed(c)
> +#define gits_write_vpropbaser(v, c)     {writeq_relaxed(v, c);}
> +
> +/*
> + * GICR_VPENDBASER - the Valid bit must be cleared before changing
> + * anything else.
> + */
> +static inline void gits_write_vpendbaser(uint64_t val, void __iomem *addr)
> +{
> +    uint64_t tmp;
> +
> +    tmp = readq_relaxed(addr);
> +    while ( tmp & GICR_VPENDBASER_Valid )

The loop clearing GICR_VPENDBASER_Valid has no timeout.
If the bit never clears, we can spin forever. Please add a bounded
retry (and warn on timeout), similar to other polling paths.


Best regards,
Mykola

> +    {
> +        tmp &= ~GICR_VPENDBASER_Valid;
> +        writeq_relaxed(tmp, addr);
> +        tmp = readq_relaxed(addr);
> +    }
> +
> +    writeq_relaxed(val, addr);
> +}
> +#define gits_read_vpendbaser(c)     readq_relaxed(c)
> +
>  #endif
>
>  /*
> --
> 2.51.2



 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.