Viewing file: attr-crypto.c (1.05 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* { dg-do compile } */ /* Make sure we can force fpu=vfp before switching using the pragma. */ /* { dg-skip-if "-mpure-code supports M-profile only" { *-*-* } { "-mpure-code" } } */ /* { dg-require-effective-target arm_fp_ok } */ /* { dg-options "-O2 -march=armv8-a" } */ /* { dg-add-options arm_fp } */
/* Reset fpu to a value compatible with the next pragmas. */ #pragma GCC target ("fpu=vfp") #pragma GCC push_options
#pragma GCC target ("fpu=crypto-neon-fp-armv8")
#ifndef __ARM_FEATURE_CRYPTO #error __ARM_FEATURE_CRYPTO not defined. #endif
#ifndef __ARM_NEON #error __ARM_NEON not defined. #endif
#if !defined(__ARM_FP) || (__ARM_FP != 14) #error __ARM_FP #endif
#include "arm_neon.h"
int foo (void) { uint32x4_t a = {0xd, 0xe, 0xa, 0xd}; uint32x4_t b = {0, 1, 2, 3};
uint32x4_t res = vsha256su0q_u32 (a, b); return res[0]; }
#pragma GCC pop_options
/* Check that the FP version is correctly reset. */
#if !defined(__ARM_FP) || (__ARM_FP != 12) #error __ARM_FP #endif
/* { dg-final { scan-assembler "sha256su0.32\tq\[0-9\]+, q\[0-9\]+" } } */
|