URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 318 |
Rev 338 |
/* PR target/13685 */
|
/* PR target/13685 */
|
/* { dg-options "-Os -msse" } */
|
/* { dg-options "-Os -msse" } */
|
/* { dg-require-effective-target sse } */
|
/* { dg-require-effective-target sse } */
|
|
|
typedef float __m128 __attribute__ ((vector_size (16)));
|
typedef float __m128 __attribute__ ((vector_size (16)));
|
typedef int __m64 __attribute__ ((vector_size (8)));
|
typedef int __m64 __attribute__ ((vector_size (8)));
|
|
|
int puts (const char *s);
|
int puts (const char *s);
|
void foo (__m128 *, __m64 *, int);
|
void foo (__m128 *, __m64 *, int);
|
|
|
int main (void)
|
int main (void)
|
{
|
{
|
foo (0, 0, 0);
|
foo (0, 0, 0);
|
return 0;
|
return 0;
|
}
|
}
|
|
|
void foo (__m128 *dst, __m64 *src, int n)
|
void foo (__m128 *dst, __m64 *src, int n)
|
{
|
{
|
__m128 xmm0 = { 0 };
|
__m128 xmm0 = { 0 };
|
while (n > 64)
|
while (n > 64)
|
{
|
{
|
puts ("");
|
puts ("");
|
xmm0 = __builtin_ia32_cvtpi2ps (xmm0, *src);
|
xmm0 = __builtin_ia32_cvtpi2ps (xmm0, *src);
|
*dst = xmm0;
|
*dst = xmm0;
|
n --;
|
n --;
|
}
|
}
|
}
|
}
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.