| 
									
										
										
										
											2010-01-06 23:39:22 -05:00
										 |  |  | ! Copyright (C) 2008, 2010 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: namespaces accessors math.order assocs kernel sequences | 
					
						
							| 
									
										
										
										
											2009-08-07 18:44:50 -04:00
										 |  |  | combinators make classes words cpu.architecture layouts | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  | compiler.cfg.instructions compiler.cfg.registers | 
					
						
							|  |  |  | compiler.cfg.stack-frame ;
 | 
					
						
							|  |  |  | IN: compiler.cfg.build-stack-frame | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: frame-required? | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: compute-stack-frame* ( insn -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : request-stack-frame ( stack-frame -- )
 | 
					
						
							| 
									
										
										
										
											2009-07-19 21:12:04 -04:00
										 |  |  |     frame-required? on
 | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  |     stack-frame [ max-stack-frame ] change ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-30 05:52:01 -04:00
										 |  |  | UNION: stack-frame-insn | 
					
						
							|  |  |  |     ##alien-invoke | 
					
						
							|  |  |  |     ##alien-indirect | 
					
						
							| 
									
										
										
										
											2010-01-06 23:39:22 -05:00
										 |  |  |     ##alien-assembly | 
					
						
							| 
									
										
										
										
											2009-08-30 05:52:01 -04:00
										 |  |  |     ##alien-callback ;
 | 
					
						
							| 
									
										
										
										
											2009-07-19 21:12:04 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-30 05:52:01 -04:00
										 |  |  | M: stack-frame-insn compute-stack-frame* | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  |     stack-frame>> request-stack-frame ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-15 07:20:09 -05:00
										 |  |  | M: ##call compute-stack-frame* drop frame-required? on ;
 | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-05 06:27:49 -04:00
										 |  |  | M: ##gc compute-stack-frame* | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  |     frame-required? on
 | 
					
						
							| 
									
										
										
										
											2009-10-20 06:02:42 -04:00
										 |  |  |     stack-frame new
 | 
					
						
							|  |  |  |         swap tagged-values>> length cells >>gc-root-size | 
					
						
							|  |  |  |         t >>calls-vm? | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  |     request-stack-frame ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-07 18:44:50 -04:00
										 |  |  | M: _spill-area-size compute-stack-frame* | 
					
						
							|  |  |  |     n>> stack-frame get (>>spill-area-size) ;
 | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: insn compute-stack-frame* | 
					
						
							|  |  |  |     class frame-required? word-prop [ | 
					
						
							|  |  |  |         frame-required? on
 | 
					
						
							|  |  |  |     ] when ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | \ _spill t frame-required? set-word-prop | 
					
						
							| 
									
										
										
										
											2009-08-30 05:52:01 -04:00
										 |  |  | \ ##unary-float-function t frame-required? set-word-prop | 
					
						
							|  |  |  | \ ##binary-float-function t frame-required? set-word-prop | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : compute-stack-frame ( insns -- )
 | 
					
						
							|  |  |  |     frame-required? off
 | 
					
						
							| 
									
										
										
										
											2009-08-07 18:44:50 -04:00
										 |  |  |     stack-frame new stack-frame set
 | 
					
						
							| 
									
										
										
										
											2009-06-02 19:23:47 -04:00
										 |  |  |     [ compute-stack-frame* ] each
 | 
					
						
							|  |  |  |     stack-frame get dup stack-frame-size >>total-size drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: insert-pro/epilogues* ( insn -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##prologue insert-pro/epilogues* | 
					
						
							|  |  |  |     drop frame-required? get [ stack-frame get _prologue ] when ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: ##epilogue insert-pro/epilogues* | 
					
						
							|  |  |  |     drop frame-required? get [ stack-frame get _epilogue ] when ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: insn insert-pro/epilogues* , ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : insert-pro/epilogues ( insns -- insns )
 | 
					
						
							|  |  |  |     [ [ insert-pro/epilogues* ] each ] { } make ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : build-stack-frame ( mr -- mr )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             [ compute-stack-frame ] | 
					
						
							|  |  |  |             [ insert-pro/epilogues ] | 
					
						
							|  |  |  |             bi
 | 
					
						
							|  |  |  |         ] change-instructions | 
					
						
							|  |  |  |     ] with-scope ;
 |