| 
									
										
										
										
											2008-10-19 02:10:21 -04:00
										 |  |  | ! Copyright (C) 2008 Slava Pestov. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-10-22 22:59:07 -04:00
										 |  |  | USING: accessors classes kernel math namespaces combinators | 
					
						
							|  |  |  | compiler.cfg.instructions compiler.cfg.value-numbering.graph ;
 | 
					
						
							| 
									
										
										
										
											2008-10-19 02:10:21 -04:00
										 |  |  | IN: compiler.cfg.value-numbering.expressions | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-22 22:59:07 -04:00
										 |  |  | ! Referentially-transparent expressions | 
					
						
							| 
									
										
										
										
											2008-10-19 02:10:21 -04:00
										 |  |  | TUPLE: expr op ;
 | 
					
						
							|  |  |  | TUPLE: unary-expr < expr in ;
 | 
					
						
							| 
									
										
										
										
											2008-10-22 22:59:07 -04:00
										 |  |  | TUPLE: binary-expr < expr in1 in2 ;
 | 
					
						
							|  |  |  | TUPLE: commutative-expr < binary-expr ;
 | 
					
						
							|  |  |  | TUPLE: compare-expr < binary-expr cc ;
 | 
					
						
							|  |  |  | TUPLE: constant-expr < expr value ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <constant> ( constant -- expr )
 | 
					
						
							|  |  |  |     f swap constant-expr boa ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: constant-expr equal? | 
					
						
							|  |  |  |     over constant-expr? [ | 
					
						
							|  |  |  |         [ [ value>> ] bi@ = ] | 
					
						
							|  |  |  |         [ [ value>> class ] bi@ = ] 2bi
 | 
					
						
							|  |  |  |         and
 | 
					
						
							|  |  |  |     ] [ 2drop f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: input-expr-counter | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : next-input-expr ( -- n )
 | 
					
						
							|  |  |  |     input-expr-counter [ dup 1 + ] change ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Expressions whose values are inputs to the basic block. We | 
					
						
							|  |  |  | ! can eliminate a second computation having the same 'n' as | 
					
						
							|  |  |  | ! the first one; we can also eliminate input-exprs whose | 
					
						
							|  |  |  | ! result is not used. | 
					
						
							|  |  |  | TUPLE: input-expr < expr n ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : constant>vn ( constant -- vn ) <constant> expr>vn ; inline
 | 
					
						
							| 
									
										
										
										
											2008-10-19 02:10:21 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | GENERIC: >expr ( insn -- expr )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-22 22:59:07 -04:00
										 |  |  | M: ##load-immediate >expr val>> <constant> ;
 | 
					
						
							| 
									
										
										
										
											2008-10-19 02:10:21 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-22 22:59:07 -04:00
										 |  |  | M: ##load-indirect >expr obj>> <constant> ;
 | 
					
						
							| 
									
										
										
										
											2008-10-19 02:10:21 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: ##unary >expr | 
					
						
							|  |  |  |     [ class ] [ src>> vreg>vn ] bi unary-expr boa ;
 | 
					
						
							| 
									
										
										
										
											2008-10-22 22:59:07 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: ##binary >expr | 
					
						
							|  |  |  |     [ class ] [ src1>> vreg>vn ] [ src2>> vreg>vn ] tri
 | 
					
						
							|  |  |  |     binary-expr boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##binary-imm >expr | 
					
						
							|  |  |  |     [ class ] [ src1>> vreg>vn ] [ src2>> constant>vn ] tri
 | 
					
						
							|  |  |  |     binary-expr boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##commutative >expr | 
					
						
							|  |  |  |     [ class ] [ src1>> vreg>vn ] [ src2>> vreg>vn ] tri
 | 
					
						
							|  |  |  |     commutative-expr boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##commutative-imm >expr | 
					
						
							|  |  |  |     [ class ] [ src1>> vreg>vn ] [ src2>> constant>vn ] tri
 | 
					
						
							|  |  |  |     commutative-expr boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : compare>expr ( insn -- expr )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         [ class ] | 
					
						
							|  |  |  |         [ src1>> vreg>vn ] | 
					
						
							|  |  |  |         [ src2>> vreg>vn ] | 
					
						
							|  |  |  |         [ cc>> ] | 
					
						
							|  |  |  |     } cleave compare-expr boa ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##compare >expr compare>expr ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : compare-imm>expr ( insn -- expr )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         [ class ] | 
					
						
							|  |  |  |         [ src1>> vreg>vn ] | 
					
						
							|  |  |  |         [ src2>> constant>vn ] | 
					
						
							|  |  |  |         [ cc>> ] | 
					
						
							|  |  |  |     } cleave compare-expr boa ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##compare-imm >expr compare-imm>expr ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##compare-float >expr compare>expr ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##flushable >expr class next-input-expr input-expr boa ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : init-expressions ( -- )
 | 
					
						
							|  |  |  |     0 input-expr-counter set ;
 |