[Coins-compiler-users] SIMD instruction generation

Zurück zum Archiv-Index

Ikuo Nakata nakat****@kamak*****
2009年 6月 15日 (月) 10:25:34 JST


Hi, Daniel,

You can find examples of TMD expressions for parallel instructions in
   lines 605-679 of coins/backend/gen/x86.tmd .

For example,

(defrule void (PARALLEL
	       (SET I64
		    (MEM I64 (SUB I32 (REG I32 "%esp") (INTCONST I32 8)))
		    mrcq)
	       (SET I32
		    (REG I32 "%esp")
		    (SUB I32 (REG I32 "%esp") (INTCONST I32 8))))
   (code (pushl (qhigh $1))
	(pushl (qlow $1)))
   (cost 2))

Ikuo Nakata

On 2009/06/15, at 5:46, Daniel Shapiro wrote:

> Thanks Tan,
>
> I am curious how the parallel instruction can be used in instruction  
> selection. I have 2 questions:
>
> Question 1:
>
> Assuming proper syntax, will the LIR expression (PARALLEL (SET A = B 
> +C), (SET D = E + F)) be emitted as 2 instructions? Is there a TMD  
> expression and corresponding java rule to force this parallel  
> instruction to be emitted as the following assembly:
>
> padd a,d, b,c,e,f;
>
> Also, the order of a,d, b,c,e,f is important and must be  
> deterministic.
>
> Question 2:
>
> Is there a way to build an instruction where 4 inputs feed 2 outputs?
>
> Example:
>
> parallel
> ((set output1=x+b+c),
> (set output2=y+b+c))
>
> I am trying to emit an instruction
>
> padd output1,output2, x,y,b,c;
>
> And again, the order of output1,output2, x,y,b,c is important and  
> must be deterministic.
>
> Thank you for your help in understanding the backend,
>
> -Daniel
>
> 2009/6/14 Tan Watanabe <tan****@watan*****>
> Hi, Daniel,
>
>
> At 23:58 09/06/09, you wrote:
> p.s. I have a quick question:
>
> can I have instructions in TMD that have more than 2 input registers?
>
> also
>
> can I have instructions in TMD that have more than 1 output register?
>
> The LIR epxression
>
>    (PARALLEL  x1, x2, ... xn)
>
> may have more than 2 input registers when it contains more than 1  
> subexpression.
> It may have also more than 1 output registers when it contains more  
> than 1
> SET expression.
>
> The LIR expression
>
>    (CALL x1 (x2…xn) (y1…ym))
>
> may also have more than 2 input registers and more than 1 output  
> registers
> but it is used to call a subprogram.
>
>
> Thanks,
>
>
> --
> Daniel Shapiro, <http://B.A.Sc>B.A.Sc ., <http://M.A.Sc>M.A.Sc.,  
> Ph.D. (Candidate)
>
> Tan Watanabe <tan****@watan*****>
>
>
>
> -- 
> Daniel Shapiro, B.A.Sc ., M.A.Sc., Ph.D. (Candidate)
>
> School of Information Technology and Engineering (SITE), University  
> of Ottawa
> Tel: (613) 562-5800 ext. 2192
> Office: SITE4009C
> Email: dshap092 -at- site.uottawa.ca
> Website: site.uottawa.ca/~dshap092/
> Research Group: carg.site.uottawa.ca/
> _______________________________________________
> Coins-compiler-users mailing list
> Coins****@lists*****
> http://lists.sourceforge.jp/mailman/listinfo/coins-compiler-users

中田 育男
nakat****@kamak*****



-------------- next part --------------
HTMLの添付ファイルを保管しました...
Download 



Coins-compiler-users メーリングリストの案内
Zurück zum Archiv-Index