The CRIS tests expect that functions marked inline are always inline. With newer versions of GCC, building them results warnings like the following and spurious failures when they are run. In file included from tests/tcg/cris/check_moveq.c:5:0: tests/tcg/cris/crisutils.h:66:20: warning: inlining failed in call to 'cris_tst_cc.constprop.0': call is unlikely and code size would grow [-Winline] tests/tcg/cris/check_moveq.c:28:13: warning: called from here [-Winline] Use the always_inline attribute when building them to fix this. Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com> Signed-off-by: Rabin Vincent <rabinv@axis.com> Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
		
			
				
	
	
		
			143 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			143 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <stdio.h>
 | |
| #include <stdlib.h>
 | |
| #include <stdint.h>
 | |
| #include "sys.h"
 | |
| #include "crisutils.h"
 | |
| 
 | |
| static always_inline int cris_bound_b(int v, int b)
 | |
| {
 | |
| 	int r = v;
 | |
| 	asm ("bound.b\t%1, %0\n" : "+r" (r) : "ri" (b));
 | |
| 	return r;
 | |
| }
 | |
| 
 | |
| static always_inline int cris_bound_w(int v, int b)
 | |
| {
 | |
| 	int r = v;
 | |
| 	asm ("bound.w\t%1, %0\n" : "+r" (r) : "ri" (b));
 | |
| 	return r;
 | |
| }
 | |
| 
 | |
| static always_inline int cris_bound_d(int v, int b)
 | |
| {
 | |
| 	int r = v;
 | |
| 	asm ("bound.d\t%1, %0\n" : "+r" (r) : "ri" (b));
 | |
| 	return r;
 | |
| }
 | |
| 
 | |
| int main(void)
 | |
| {
 | |
| 	int r;
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_d(-1, 2);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 2)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_d(2, 0xffffffff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 2)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_d(0xffff, 0xffff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xffff)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_d(-1, 0xffffffff);
 | |
| 	cris_tst_cc(1, 0, 0, 0);
 | |
| 	if (r != 0xffffffff)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_d(0x78134452, 0x5432f789);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0x5432f789)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_w(-1, 2);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 2)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_w(-1, 0xffff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xffff)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_w(2, 0xffff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 2)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_w(0xfedaffff, 0xffff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xffff)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_w(0x78134452, 0xf789);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xf789)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_b(-1, 2);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 2)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_b(2, 0xff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 2)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_b(-1, 0xff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xff)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_b(0xff, 0xff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xff)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_b(0xfeda49ff, 0xff);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xff)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_b(0x78134452, 0x89);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0x89)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_w(0x78134452, 0);
 | |
| 	cris_tst_cc(0, 1, 0, 0);
 | |
| 	if (r != 0)
 | |
| 		err();
 | |
| 
 | |
| 	cris_tst_cc_init();
 | |
| 	r = cris_bound_b(0xffff, -1);
 | |
| 	cris_tst_cc(0, 0, 0, 0);
 | |
| 	if (r != 0xff)
 | |
| 		err();
 | |
| 
 | |
| 	pass();
 | |
| 	return 0;
 | |
| }
 |