Re: [PATCH] s390: fix detection of vector enhancements facility 1 vs. vector packed decimal facility

From: Janosch Frank
Date: Mon May 03 2021 - 10:11:46 EST


On 5/3/21 2:12 PM, David Hildenbrand wrote:
> The PoP documents:
> 134: The vector packed decimal facility is installed in the
> z/Architecture architectural mode. When bit 134 is
> one, bit 129 is also one.
> 135: The vector enhancements facility 1 is installed in
> the z/Architecture architectural mode. When bit 135
> is one, bit 129 is also one.
>
> Looks like we confuse the vector enhancements facility 1 ("EXT") with the
> Vector packed decimal facility ("BCD"). Let's fix the facility checks.
>
> Detected while working on QEMU/tcg z14 support and only unlocking
> the vector enhancements facility 1, but not the vector packed decimal
> facility.

Reviewed-by: Janosch Frank <frankja@xxxxxxxxxxxxx>

>
> Fixes: 2583b848cad0 ("s390: report new vector facilities")
> Cc: Heiko Carstens <hca@xxxxxxxxxxxxx>
> Cc: Vasily Gorbik <gor@xxxxxxxxxxxxx>
> Cc: Christian Borntraeger <borntraeger@xxxxxxxxxx>
> Cc: Sven Schnelle <svens@xxxxxxxxxxxxx>
> Cc: Alexander Egorenkov <egorenar@xxxxxxxxxxxxx>
> Cc: Niklas Schnelle <schnelle@xxxxxxxxxxxxx>
> Cc: Janosch Frank <frankja@xxxxxxxxxxxxx>
> Cc: linux-s390@xxxxxxxxxxxxxxx
> Signed-off-by: David Hildenbrand <david@xxxxxxxxxx>
> ---
> arch/s390/kernel/setup.c | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/arch/s390/kernel/setup.c b/arch/s390/kernel/setup.c
> index 72134f9f6ff5..5aab59ad5688 100644
> --- a/arch/s390/kernel/setup.c
> +++ b/arch/s390/kernel/setup.c
> @@ -937,9 +937,9 @@ static int __init setup_hwcaps(void)
> if (MACHINE_HAS_VX) {
> elf_hwcap |= HWCAP_S390_VXRS;
> if (test_facility(134))
> - elf_hwcap |= HWCAP_S390_VXRS_EXT;
> - if (test_facility(135))
> elf_hwcap |= HWCAP_S390_VXRS_BCD;
> + if (test_facility(135))
> + elf_hwcap |= HWCAP_S390_VXRS_EXT;
> if (test_facility(148))
> elf_hwcap |= HWCAP_S390_VXRS_EXT2;
> if (test_facility(152))
>