OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [gcc.dg/] [vmx/] [eg-5.c] - Rev 689

Compare with Previous | Blame | View Log

#include "harness.h"
 
static vector float
matvecmul4 (vector float c0, vector float c1, vector float c2,
	    vector float c3, vector float v)
{
  /* Set result to a vector of f32 0's */
  vector float result = ((vector float){0.,0.,0.,0.});
 
  result  = vec_madd (c0, vec_splat (v, 0), result);
  result  = vec_madd (c1, vec_splat (v, 1), result);
  result  = vec_madd (c2, vec_splat (v, 2), result);
  result  = vec_madd (c3, vec_splat (v, 3), result);
 
  return result;
}
 
static void test()
{
  check(vec_all_eq(matvecmul4(((vector float){2,3,5,7}),
			      ((vector float){11,13,17,19}),
			      ((vector float){23,29,31,37}),
			      ((vector float){41,43,47,53}),
			      ((vector float){59,61,67,71})),
		   ((vector float){5241, 5966, 6746, 7814})),
	"matvecmul4");
}
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.