2023-12-27 12:06:17 +08:00
|
|
|
/* power_features.c - POWER feature check
|
|
|
|
* Copyright (C) 2020 Matheus Castanho <msc@linux.ibm.com>, IBM
|
2024-09-12 21:05:24 +08:00
|
|
|
* Copyright (C) 2021-2024 Mika T. Lindqvist <postmaster@raasu.org>
|
2023-12-27 12:06:17 +08:00
|
|
|
* For conditions of distribution and use, see copyright notice in zlib.h
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_AUXV_H
|
|
|
|
# include <sys/auxv.h>
|
|
|
|
#endif
|
2024-09-12 21:05:24 +08:00
|
|
|
#ifdef POWER_NEED_AUXVEC_H
|
|
|
|
# include <linux/auxvec.h>
|
|
|
|
#endif
|
2023-12-27 12:06:17 +08:00
|
|
|
#ifdef __FreeBSD__
|
|
|
|
# include <machine/cpu.h>
|
|
|
|
#endif
|
2024-09-12 21:05:24 +08:00
|
|
|
#include "zbuild.h"
|
2023-12-27 12:06:17 +08:00
|
|
|
#include "power_features.h"
|
|
|
|
|
|
|
|
void Z_INTERNAL power_check_features(struct power_cpu_features *features) {
|
|
|
|
#ifdef PPC_FEATURES
|
|
|
|
unsigned long hwcap;
|
|
|
|
#ifdef __FreeBSD__
|
|
|
|
elf_aux_info(AT_HWCAP, &hwcap, sizeof(hwcap));
|
|
|
|
#else
|
|
|
|
hwcap = getauxval(AT_HWCAP);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (hwcap & PPC_FEATURE_HAS_ALTIVEC)
|
|
|
|
features->has_altivec = 1;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef POWER_FEATURES
|
|
|
|
unsigned long hwcap2;
|
|
|
|
#ifdef __FreeBSD__
|
|
|
|
elf_aux_info(AT_HWCAP2, &hwcap2, sizeof(hwcap2));
|
|
|
|
#else
|
|
|
|
hwcap2 = getauxval(AT_HWCAP2);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef POWER8_VSX
|
|
|
|
if (hwcap2 & PPC_FEATURE2_ARCH_2_07)
|
|
|
|
features->has_arch_2_07 = 1;
|
|
|
|
#endif
|
|
|
|
#ifdef POWER9
|
|
|
|
if (hwcap2 & PPC_FEATURE2_ARCH_3_00)
|
|
|
|
features->has_arch_3_00 = 1;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
}
|