Re: [PATCH v5 3/6] LoongArch: KVM: Use existing macro about interrupt bit mask
From: Huacai Chen
Date: Mon Jun 01 2026 - 09:57:46 EST
Hi, Bibo,
On Tue, May 26, 2026 at 8:53 PM Bibo Mao <maobibo@xxxxxxxxxxx> wrote:
>
> With interrupt post, register CSR_GINTC and CSR_ESTAT is used, and
> CSR_ESTAT is used for percpu interrupt injection and CSR_GINTC is for
> external hardware interrupt injection.
>
> Here use existing macro about interrupt bit of register CSR_GINTC and
> CSR_ESTAT, rather than hard coded constant value.
>
> Signed-off-by: Bibo Mao <maobibo@xxxxxxxxxxx>
> ---
> arch/loongarch/include/asm/kvm_vcpu.h | 43 ++++++++++++++++++---------
> 1 file changed, 29 insertions(+), 14 deletions(-)
>
> diff --git a/arch/loongarch/include/asm/kvm_vcpu.h b/arch/loongarch/include/asm/kvm_vcpu.h
> index 3784ab4ccdb5..efe26b04b35f 100644
> --- a/arch/loongarch/include/asm/kvm_vcpu.h
> +++ b/arch/loongarch/include/asm/kvm_vcpu.h
> @@ -10,22 +10,37 @@
> #include <asm/loongarch.h>
>
> /* Controlled by 0x5 guest estat */
> -#define CPU_SIP0 (_ULCAST_(1))
> -#define CPU_SIP1 (_ULCAST_(1) << 1)
> -#define CPU_PMU (_ULCAST_(1) << 10)
> -#define CPU_TIMER (_ULCAST_(1) << 11)
> -#define CPU_IPI (_ULCAST_(1) << 12)
> -#define CPU_AVEC (_ULCAST_(1) << 14)
> +#define CPU_SIP0 BIT(INT_SWI0)
> +#define CPU_SIP1 BIT(INT_SWI1)
> +#define CPU_HWI0 BIT(INT_HWI0)
> +#define CPU_HWI1 BIT(INT_HWI1)
> +#define CPU_HWI2 BIT(INT_HWI2)
> +#define CPU_HWI3 BIT(INT_HWI3)
> +#define CPU_HWI4 BIT(INT_HWI4)
> +#define CPU_HWI5 BIT(INT_HWI5)
> +#define CPU_HWI6 BIT(INT_HWI6)
> +#define CPU_HWI7 BIT(INT_HWI7)
> +#define CPU_PMU BIT(INT_PCOV)
> +#define CPU_TIMER BIT(INT_TI)
> +#define CPU_IPI BIT(INT_IPI)
> +#define CPU_AVEC BIT(INT_AVEC)
> +#define KVM_ESTAT_IRQ_MASK (CPU_SIP0 | CPU_SIP1 | CPU_PMU | CPU_TIMER \
> + | CPU_IPI | CPU_AVEC)
> +#define KVM_ESTAT_HWI_MASK (CPU_HWI0 | CPU_HWI1 | CPU_HWI2 | CPU_HWI3 \
> + | CPU_HWI4 | CPU_HWI5 | CPU_HWI6 | CPU_HWI7)
>
> /* Controlled by 0x52 guest exception VIP aligned to estat bit 5~12 */
> -#define CPU_IP0 (_ULCAST_(1))
> -#define CPU_IP1 (_ULCAST_(1) << 1)
> -#define CPU_IP2 (_ULCAST_(1) << 2)
> -#define CPU_IP3 (_ULCAST_(1) << 3)
> -#define CPU_IP4 (_ULCAST_(1) << 4)
> -#define CPU_IP5 (_ULCAST_(1) << 5)
> -#define CPU_IP6 (_ULCAST_(1) << 6)
> -#define CPU_IP7 (_ULCAST_(1) << 7)
> +#define GINTC_VIP_DELTA (INT_HWI0 - CSR_GINTC_VIP_SHIFT)
Don't use too many wrappers, just use INT_HWI0 instead of
GINTC_VIP_DELTA in this series is perfect. In other places INT_SWI0 is
also used for shifts.
Huacai
> +#define CPU_IP0 BIT(INT_HWI0 - GINTC_VIP_DELTA)
> +#define CPU_IP1 BIT(INT_HWI1 - GINTC_VIP_DELTA)
> +#define CPU_IP2 BIT(INT_HWI2 - GINTC_VIP_DELTA)
> +#define CPU_IP3 BIT(INT_HWI3 - GINTC_VIP_DELTA)
> +#define CPU_IP4 BIT(INT_HWI4 - GINTC_VIP_DELTA)
> +#define CPU_IP5 BIT(INT_HWI5 - GINTC_VIP_DELTA)
> +#define CPU_IP6 BIT(INT_HWI6 - GINTC_VIP_DELTA)
> +#define CPU_IP7 BIT(INT_HWI7 - GINTC_VIP_DELTA)
> +#define KVM_GINTC_IRQ_MASK (CPU_IP0 | CPU_IP1 | CPU_IP2 | CPU_IP3 \
> + | CPU_IP4 | CPU_IP5 | CPU_IP6 | CPU_IP7)
>
> #define MNSEC_PER_SEC (NSEC_PER_SEC >> 20)
>
> --
> 2.39.3
>
>