2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								// Copyright 2016 The Go Authors. All rights reserved.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Use of this source code is governed by a BSD-style  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// license that can be found in the LICENSE file.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// +build ignore  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								package  main  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  "strings"  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 11:34:43 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// Notes:  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  - Less-than-64-bit integer types live in the low portion of registers.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//    For now, the upper portion is junk; sign/zero-extension might be optimized in the future, but not yet.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  - Boolean types are zero or 1; stored in a byte, but loaded with AMOVBZ so the upper bytes of a register are zero.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//  - *const instructions may use a constant larger than the instuction can encode.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//    In this case the assembler expands to multiple instructions and uses tmp  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								//    register (R31).  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								var  regNamesPPC64  =  [ ] string {  
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// "R0", // REGZERO 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									"SP" ,  // REGSP 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"SB" ,  // REGSB 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R3" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R4" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R5" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R6" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R7" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R8" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R9" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R10" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R11" ,  // REGCTXT for closures 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R12" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R13" ,  // REGTLS 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R14" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R15" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R16" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R17" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R18" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R19" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R20" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R21" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R22" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R23" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R24" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R25" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R26" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R27" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R28" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"R29" , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									"g" ,    // REGG.  Using name "g" and setting Config.hasGReg makes it "just happen". 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									"R31" ,  // REGTMP 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									"F0" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F1" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F2" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F3" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F4" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F5" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F6" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F7" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F8" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F9" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F10" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F11" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F12" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F13" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F14" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F15" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F16" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F17" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F18" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F19" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F20" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F21" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F22" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F23" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F24" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F25" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F26" , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									"F27" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F28" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F29" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F30" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									"F31" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR0", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR1", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR2", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR3", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR4", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR5", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR6", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CR7", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// "CR", 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
									// "XER", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "LR", 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// "CTR", 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								func  init ( )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									// Make map from reg names to reg integers. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									if  len ( regNamesPPC64 )  >  64  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										panic ( "too many registers" ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									num  :=  map [ string ] int { } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									for  i ,  name  :=  range  regNamesPPC64  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										num [ name ]  =  i 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									buildReg  :=  func ( s  string )  regMask  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										m  :=  regMask ( 0 ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										for  _ ,  r  :=  range  strings . Split ( s ,  " " )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											if  n ,  ok  :=  num [ r ] ;  ok  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												m  |=  regMask ( 1 )  <<  uint ( n ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											panic ( "register "  +  r  +  " not found" ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										return  m 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									var  ( 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										gp  =  buildReg ( "R3 R4 R5 R6 R7 R8 R9 R10 R11 R12 R14 R15 R16 R17 R18 R19 R20 R21 R22 R23 R24 R25 R26 R27 R28 R29" ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fp  =  buildReg ( "F1 F2 F3 F4 F5 F6 F7 F8 F9 F10 F11 F12 F13 F14 F15 F16 F17 F18 F19 F20 F21 F22 F23 F24 F25 F26 F27 F28 F29 F30 F31" ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										sp  =  buildReg ( "SP" ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-06 13:32:52 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										sb  =  buildReg ( "SB" ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										// gr = buildReg("g") 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										//cr = buildReg("CR") 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										//ctr  = buildReg("CTR") 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//lr   = buildReg("LR") 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										tmp   =  buildReg ( "R31" ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ctxt  =  buildReg ( "R11" ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										//		tls	= buildReg("R13") 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										gp01         =  regInfo { inputs :  nil ,  outputs :  [ ] regMask { gp } } 
							 
						 
					
						
							
								
									
										
											 
										
											
												[dev.ssa] cmd/compile: replace storeconst w/ storezero, fold addressing
Because PPC lacks store-immediate, remove the instruction
that implies that it exists.  Replace it with storezero for
the special case of storing zero, because R0 is reserved zero
for Go (though the assembler knows this, do it in SSA).
Also added address folding for storezero.
(Now corrected to use right-sized stores in bulk-zero code.)
Hello.go now compiles to
genssa main
    00000 (...hello.go:7) TEXT "".main(SB), $0
    00001 (...hello.go:7) FUNCDATA $0, "".gcargs·0(SB)
    00002 (...hello.go:7) FUNCDATA $1, "".gclocals·1(SB)
v23 00003 (...hello.go:8) MOVD $go.string."Hello, World!\n"(SB), R3
v11 00004 (...hello.go:8) MOVD R3, 32(R1)
v22 00005 (...hello.go:8) MOVD $14, R3
v6  00006 (...hello.go:8) MOVD R3, 40(R1)
v20 00007 (...hello.go:8) MOVD R0, 48(R1)
v18 00008 (...hello.go:8) MOVD R0, 56(R1)
v9  00009 (...hello.go:8) MOVD R0, 64(R1)
v10 00010 (...hello.go:8) CALL fmt.Printf(SB)
b2  00011 (...hello.go:9) RET
    00012 (<unknown line number>) END
Updates #16010
Change-Id: I33cfd98c21a1617502260ac753fa8cad68c8d85a
Reviewed-on: https://go-review.googlesource.com/25151
Reviewed-by: Cherry Zhang <cherryyz@google.com>
Run-TryBot: David Chase <drchase@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
											 
										 
										
											2016-07-22 10:47:16 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										gp11         =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } ,  outputs :  [ ] regMask { gp } } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gp21         =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb ,  gp  |  sp  |  sb } ,  outputs :  [ ] regMask { gp } } 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										gp1cr        =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gp2cr        =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb ,  gp  |  sp  |  sb } } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										crgp         =  regInfo { inputs :  nil ,  outputs :  [ ] regMask { gp } } 
							 
						 
					
						
							
								
									
										
											 
										
											
												[dev.ssa] cmd/compile: replace storeconst w/ storezero, fold addressing
Because PPC lacks store-immediate, remove the instruction
that implies that it exists.  Replace it with storezero for
the special case of storing zero, because R0 is reserved zero
for Go (though the assembler knows this, do it in SSA).
Also added address folding for storezero.
(Now corrected to use right-sized stores in bulk-zero code.)
Hello.go now compiles to
genssa main
    00000 (...hello.go:7) TEXT "".main(SB), $0
    00001 (...hello.go:7) FUNCDATA $0, "".gcargs·0(SB)
    00002 (...hello.go:7) FUNCDATA $1, "".gclocals·1(SB)
v23 00003 (...hello.go:8) MOVD $go.string."Hello, World!\n"(SB), R3
v11 00004 (...hello.go:8) MOVD R3, 32(R1)
v22 00005 (...hello.go:8) MOVD $14, R3
v6  00006 (...hello.go:8) MOVD R3, 40(R1)
v20 00007 (...hello.go:8) MOVD R0, 48(R1)
v18 00008 (...hello.go:8) MOVD R0, 56(R1)
v9  00009 (...hello.go:8) MOVD R0, 64(R1)
v10 00010 (...hello.go:8) CALL fmt.Printf(SB)
b2  00011 (...hello.go:9) RET
    00012 (<unknown line number>) END
Updates #16010
Change-Id: I33cfd98c21a1617502260ac753fa8cad68c8d85a
Reviewed-on: https://go-review.googlesource.com/25151
Reviewed-by: Cherry Zhang <cherryyz@google.com>
Run-TryBot: David Chase <drchase@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
											 
										 
										
											2016-07-22 10:47:16 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										gpload       =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } ,  outputs :  [ ] regMask { gp } } 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										gpstore      =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb ,  gp  |  sp  |  sb } } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gpstorezero  =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } }  // ppc64.REGZERO is reserved zero value 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fp01         =  regInfo { inputs :  nil ,  outputs :  [ ] regMask { fp } } 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										//		fp11	   = regInfo{inputs: []regMask{fp}, outputs: []regMask{fp}} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fp21        =  regInfo { inputs :  [ ] regMask { fp ,  fp } ,  outputs :  [ ] regMask { fp } } 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										fp2cr       =  regInfo { inputs :  [ ] regMask { fp ,  fp } } 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-06 13:32:52 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										fpload      =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } ,  outputs :  [ ] regMask { fp } } 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										fpstore     =  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb ,  fp } } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										callerSave  =  regMask ( gp  |  fp ) 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									ops  :=  [ ] opData { 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "ADD" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "ADD" ,  commutative :  true } ,      // arg0 + arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "ADDconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "ADD" ,  aux :  "SymOff" } ,     // arg0 + auxInt + aux.(*gc.Sym) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FADD" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FADD" ,  commutative :  true } ,    // arg0+arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FADDS" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FADDS" ,  commutative :  true } ,  // arg0+arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SUB" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "SUB" } ,                         // arg0-arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FSUB" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FSUB" } ,                       // arg0-arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FSUBS" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FSUBS" } ,                     // arg0-arg1 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-02 13:17:09 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MULLD" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "MULLD" ,  commutative :  true } ,  // arg0*arg1 (signed 64-bit) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MULLW" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "MULLW" ,  commutative :  true } ,  // arg0*arg1 (signed 32-bit) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MULHD" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "MULHD" ,  commutative :  true } ,    // (arg0 * arg1) >> 64, signed 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MULHW" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "MULHW" ,  commutative :  true } ,    // (arg0 * arg1) >> 32, signed 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MULHDU" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "MULHDU" ,  commutative :  true } ,  // (arg0 * arg1) >> 64, unsigned 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MULHWU" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "MULHWU" ,  commutative :  true } ,  // (arg0 * arg1) >> 32, unsigned 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "FMUL" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FMUL" ,  commutative :  true } ,    // arg0*arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FMULS" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FMULS" ,  commutative :  true } ,  // arg0*arg1 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-02 13:17:09 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRAD" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "SRAD" } ,  // arg0 >>a arg1, 64 bits (all sign if arg1 & 64 != 0) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRAW" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "SRAW" } ,  // arg0 >>a arg1, 32 bits (all sign if arg1 & 32 != 0) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRD" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "SRD" } ,    // arg0 >> arg1, 64 bits  (0 if arg1 & 64 != 0) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRW" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "SRW" } ,    // arg0 >> arg1, 32 bits  (0 if arg1 & 32 != 0) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SLD" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "SLD" } ,    // arg0 << arg1, 64 bits  (0 if arg1 & 64 != 0) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SLW" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "SLW" } ,    // arg0 << arg1, 32 bits  (0 if arg1 & 32 != 0) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "ADDconstForCarry" ,  argLength :  1 ,  reg :  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } ,  clobbers :  tmp } ,  aux :  "Int16" ,  asm :  "ADDC" ,  typ :  "Flags" } ,  // _, carry := arg0 + aux 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MaskIfNotCarry" ,  argLength :  1 ,  reg :  crgp ,  asm :  "ADDME" ,  typ :  "Int64" } ,                                                                    // carry - 1 (if carry then 0 else -1) 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-02 13:17:09 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRADconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "SRAD" ,  aux :  "Int64" } ,  // arg0 >>a aux, 64 bits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRAWconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "SRAW" ,  aux :  "Int64" } ,  // arg0 >>a aux, 32 bits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRDconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "SRD" ,  aux :  "Int64" } ,    // arg0 >> aux, 64 bits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SRWconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "SRW" ,  aux :  "Int64" } ,    // arg0 >> aux, 32 bits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SLDconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "SLD" ,  aux :  "Int64" } ,    // arg0 << aux, 64 bits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "SLWconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "SLW" ,  aux :  "Int64" } ,    // arg0 << aux, 32 bits 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FDIV" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FDIV" } ,    // arg0/arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FDIVS" ,  argLength :  2 ,  reg :  fp21 ,  asm :  "FDIVS" } ,  // arg0/arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 11:34:43 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "DIVD" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "DIVD" } ,    // arg0/arg1 (signed 64-bit) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "DIVW" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "DIVW" } ,    // arg0/arg1 (signed 32-bit) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "DIVDU" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "DIVDU" } ,  // arg0/arg1 (unsigned 64-bit) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "DIVWU" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "DIVWU" } ,  // arg0/arg1 (unsigned 32-bit) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "AND" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "AND" ,  commutative :  true } ,                // arg0&arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "ANDN" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "ANDN" } ,                                 // arg0&^arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "OR" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "OR" ,  commutative :  true } ,                  // arg0|arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "ORN" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "ORN" } ,                                   // arg0|^arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "XOR" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "XOR" ,  typ :  "Int64" ,  commutative :  true } ,  // arg0^arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "EQV" ,  argLength :  2 ,  reg :  gp21 ,  asm :  "EQV" ,  typ :  "Int64" ,  commutative :  true } ,  // arg0^^arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "NEG" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "NEG" } ,                                   // -arg0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "ORconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "OR" ,  aux :  "Int64" } ,                                                                                      // arg0|aux 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "XORconst" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "XOR" ,  aux :  "Int64" } ,                                                                                    // arg0^aux 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "ANDconst" ,  argLength :  1 ,  reg :  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } ,  outputs :  [ ] regMask { gp } } ,  asm :  "ANDCC" ,  aux :  "Int64" ,  clobberFlags :  true } ,  // arg0&aux // and-immediate sets CC on PPC, always. 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 11:34:43 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVBreg" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "MOVB" ,  typ :  "Int64" } ,                       // sign extend int8 to int64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVBZreg" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "MOVBZ" ,  typ :  "Int64" } ,                     // zero extend uint8 to uint64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVHreg" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "MOVH" ,  typ :  "Int64" } ,                       // sign extend int16 to int64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVHZreg" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "MOVHZ" ,  typ :  "Int64" } ,                     // zero extend uint16 to uint64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVWreg" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "MOVW" ,  typ :  "Int64" } ,                       // sign extend int32 to int64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVWZreg" ,  argLength :  1 ,  reg :  gp11 ,  asm :  "MOVWZ" ,  typ :  "Int64" } ,                     // zero extend uint32 to uint64 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-27 13:54:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "MOVBload" ,  argLength :  2 ,  reg :  gpload ,  asm :  "MOVB" ,  aux :  "SymOff" ,  typ :  "Int8" } ,      // sign extend int8 to int64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVBZload" ,  argLength :  2 ,  reg :  gpload ,  asm :  "MOVBZ" ,  aux :  "SymOff" ,  typ :  "UInt8" } ,   // zero extend uint8 to uint64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVHload" ,  argLength :  2 ,  reg :  gpload ,  asm :  "MOVH" ,  aux :  "SymOff" ,  typ :  "Int16" } ,     // sign extend int16 to int64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVHZload" ,  argLength :  2 ,  reg :  gpload ,  asm :  "MOVHZ" ,  aux :  "SymOff" ,  typ :  "UInt16" } ,  // zero extend uint16 to uint64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVWload" ,  argLength :  2 ,  reg :  gpload ,  asm :  "MOVW" ,  aux :  "SymOff" ,  typ :  "Int32" } ,     // sign extend int32 to int64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVWZload" ,  argLength :  2 ,  reg :  gpload ,  asm :  "MOVWZ" ,  aux :  "SymOff" ,  typ :  "UInt32" } ,  // zero extend uint32 to uint64 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVDload" ,  argLength :  2 ,  reg :  gpload ,  asm :  "MOVD" ,  aux :  "SymOff" ,  typ :  "Int64" } , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 11:34:43 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "FMOVDload" ,  argLength :  2 ,  reg :  fpload ,  asm :  "FMOVD" ,  typ :  "Float64" } , 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ name :  "FMOVSload" ,  argLength :  2 ,  reg :  fpload ,  asm :  "FMOVS" ,  typ :  "Float32" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVBstore" ,  argLength :  3 ,  reg :  gpstore ,  asm :  "MOVB" ,  aux :  "SymOff" ,  typ :  "Mem" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVHstore" ,  argLength :  3 ,  reg :  gpstore ,  asm :  "MOVH" ,  aux :  "SymOff" ,  typ :  "Mem" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVWstore" ,  argLength :  3 ,  reg :  gpstore ,  asm :  "MOVW" ,  aux :  "SymOff" ,  typ :  "Mem" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVDstore" ,  argLength :  3 ,  reg :  gpstore ,  asm :  "MOVD" ,  aux :  "SymOff" ,  typ :  "Mem" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FMOVDstore" ,  argLength :  3 ,  reg :  fpstore ,  asm :  "FMOVD" ,  aux :  "SymOff" ,  typ :  "Mem" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FMOVSstore" ,  argLength :  3 ,  reg :  fpstore ,  asm :  "FMOVS" ,  aux :  "SymOff" ,  typ :  "Mem" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
											 
										
											
												[dev.ssa] cmd/compile: replace storeconst w/ storezero, fold addressing
Because PPC lacks store-immediate, remove the instruction
that implies that it exists.  Replace it with storezero for
the special case of storing zero, because R0 is reserved zero
for Go (though the assembler knows this, do it in SSA).
Also added address folding for storezero.
(Now corrected to use right-sized stores in bulk-zero code.)
Hello.go now compiles to
genssa main
    00000 (...hello.go:7) TEXT "".main(SB), $0
    00001 (...hello.go:7) FUNCDATA $0, "".gcargs·0(SB)
    00002 (...hello.go:7) FUNCDATA $1, "".gclocals·1(SB)
v23 00003 (...hello.go:8) MOVD $go.string."Hello, World!\n"(SB), R3
v11 00004 (...hello.go:8) MOVD R3, 32(R1)
v22 00005 (...hello.go:8) MOVD $14, R3
v6  00006 (...hello.go:8) MOVD R3, 40(R1)
v20 00007 (...hello.go:8) MOVD R0, 48(R1)
v18 00008 (...hello.go:8) MOVD R0, 56(R1)
v9  00009 (...hello.go:8) MOVD R0, 64(R1)
v10 00010 (...hello.go:8) CALL fmt.Printf(SB)
b2  00011 (...hello.go:9) RET
    00012 (<unknown line number>) END
Updates #16010
Change-Id: I33cfd98c21a1617502260ac753fa8cad68c8d85a
Reviewed-on: https://go-review.googlesource.com/25151
Reviewed-by: Cherry Zhang <cherryyz@google.com>
Run-TryBot: David Chase <drchase@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
											 
										 
										
											2016-07-22 10:47:16 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "MOVBstorezero" ,  argLength :  2 ,  reg :  gpstorezero ,  asm :  "MOVB" ,  aux :  "SymOff" ,  typ :  "Mem" } ,  // store zero byte to arg0+aux.  arg1=mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVHstorezero" ,  argLength :  2 ,  reg :  gpstorezero ,  asm :  "MOVH" ,  aux :  "SymOff" ,  typ :  "Mem" } ,  // store zero 2 bytes to ... 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVWstorezero" ,  argLength :  2 ,  reg :  gpstorezero ,  asm :  "MOVW" ,  aux :  "SymOff" ,  typ :  "Mem" } ,  // store zero 4 bytes to ... 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVDstorezero" ,  argLength :  2 ,  reg :  gpstorezero ,  asm :  "MOVD" ,  aux :  "SymOff" ,  typ :  "Mem" } ,  // store zero 8 bytes to ... 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-07-06 13:32:52 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "MOVDaddr" ,  argLength :  1 ,  reg :  regInfo { inputs :  [ ] regMask { sp  |  sb } ,  outputs :  [ ] regMask { gp } } ,  aux :  "SymOff" ,  asm :  "MOVD" ,  rematerializeable :  true } ,  // arg0 + auxInt + aux.(*gc.Sym), arg0=SP/SB 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVDconst" ,  argLength :  0 ,  reg :  gp01 ,  aux :  "Int64" ,  asm :  "MOVD" ,  rematerializeable :  true } ,      // 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVWconst" ,  argLength :  0 ,  reg :  gp01 ,  aux :  "Int32" ,  asm :  "MOVW" ,  rematerializeable :  true } ,      // 32 low bits of auxint 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FMOVDconst" ,  argLength :  0 ,  reg :  fp01 ,  aux :  "Float64" ,  asm :  "FMOVD" ,  rematerializeable :  true } ,  // 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FMOVSconst" ,  argLength :  0 ,  reg :  fp01 ,  aux :  "Float32" ,  asm :  "FMOVS" ,  rematerializeable :  true } ,  // 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FCMPU" ,  argLength :  2 ,  reg :  fp2cr ,  asm :  "FCMPU" ,  typ :  "Flags" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CMP" ,  argLength :  2 ,  reg :  gp2cr ,  asm :  "CMP" ,  typ :  "Flags" } ,      // arg0 compare to arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CMPU" ,  argLength :  2 ,  reg :  gp2cr ,  asm :  "CMPU" ,  typ :  "Flags" } ,    // arg0 compare to arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CMPW" ,  argLength :  2 ,  reg :  gp2cr ,  asm :  "CMPW" ,  typ :  "Flags" } ,    // arg0 compare to arg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CMPWU" ,  argLength :  2 ,  reg :  gp2cr ,  asm :  "CMPWU" ,  typ :  "Flags" } ,  // arg0 compare to arg1 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-02 13:17:09 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "CMPconst" ,  argLength :  1 ,  reg :  gp1cr ,  asm :  "CMP" ,  aux :  "Int64" ,  typ :  "Flags" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CMPUconst" ,  argLength :  1 ,  reg :  gp1cr ,  asm :  "CMPU" ,  aux :  "Int64" ,  typ :  "Flags" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CMPWconst" ,  argLength :  1 ,  reg :  gp1cr ,  asm :  "CMPW" ,  aux :  "Int32" ,  typ :  "Flags" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CMPWUconst" ,  argLength :  1 ,  reg :  gp1cr ,  asm :  "CMPWU" ,  aux :  "Int32" ,  typ :  "Flags" } , 
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// pseudo-ops 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "Equal" ,  argLength :  1 ,  reg :  crgp } ,         // bool, true flags encode x==y false otherwise. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "NotEqual" ,  argLength :  1 ,  reg :  crgp } ,      // bool, true flags encode x!=y false otherwise. 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-02 13:17:09 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "LessThan" ,  argLength :  1 ,  reg :  crgp } ,      // bool, true flags encode  x<y false otherwise. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "LessEqual" ,  argLength :  1 ,  reg :  crgp } ,     // bool, true flags encode  x<=y false otherwise. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "GreaterThan" ,  argLength :  1 ,  reg :  crgp } ,   // bool, true flags encode  x>y false otherwise. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "GreaterEqual" ,  argLength :  1 ,  reg :  crgp } ,  // bool, true flags encode  x>=y false otherwise. 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Scheduler ensures LoweredGetClosurePtr occurs only in entry block, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// and sorts it to the very beginning of the block to prevent other 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// use of the closure pointer. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "LoweredGetClosurePtr" ,  reg :  regInfo { outputs :  [ ] regMask { ctxt } } } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//arg0=ptr,arg1=mem, returns void.  Faults if ptr is nil. 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "LoweredNilCheck" ,  argLength :  2 ,  reg :  regInfo { inputs :  [ ] regMask { gp  |  sp  |  sb } ,  clobbers :  tmp } ,  clobberFlags :  true } , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Convert pointer to integer, takes a memory operand for ordering. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "MOVDconvert" ,  argLength :  2 ,  reg :  gp11 ,  asm :  "MOVD" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										{ name :  "CALLstatic" ,  argLength :  1 ,  reg :  regInfo { clobbers :  callerSave } ,  aux :  "SymOff" ,  clobberFlags :  true } ,                                       // call static function aux.(*gc.Sym).  arg0=mem, auxint=argsize, returns mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CALLclosure" ,  argLength :  3 ,  reg :  regInfo { inputs :  [ ] regMask { gp  |  sp ,  ctxt ,  0 } ,  clobbers :  callerSave } ,  aux :  "Int64" ,  clobberFlags :  true } ,  // call function via closure.  arg0=codeptr, arg1=closure, arg2=mem, auxint=argsize, returns mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CALLdefer" ,  argLength :  1 ,  reg :  regInfo { clobbers :  callerSave } ,  aux :  "Int64" ,  clobberFlags :  true } ,                                         // call deferproc.  arg0=mem, auxint=argsize, returns mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CALLgo" ,  argLength :  1 ,  reg :  regInfo { clobbers :  callerSave } ,  aux :  "Int64" ,  clobberFlags :  true } ,                                            // call newproc.  arg0=mem, auxint=argsize, returns mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "CALLinter" ,  argLength :  2 ,  reg :  regInfo { inputs :  [ ] regMask { gp } ,  clobbers :  callerSave } ,  aux :  "Int64" ,  clobberFlags :  true } ,                  // call fn by pointer.  arg0=codeptr, arg1=mem, auxint=argsize, returns mem 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-26 09:24:18 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-07-27 13:54:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										// large or unaligned zeroing 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// arg0 = address of memory to zero (in R3, changed as side effect) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// arg1 = address of the last element to zero 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// arg2 = mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// returns mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//  ADD -8,R3,R3 // intermediate value not valid GC ptr, cannot expose to opt+GC 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//	MOVDU	R0, 8(R3) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//	CMP	R3, Rarg1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//	BLE	-2(PC) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											name :       "LoweredZero" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											aux :        "Int64" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											argLength :  3 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reg :  regInfo { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												inputs :    [ ] regMask { buildReg ( "R3" ) ,  gp } , 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												clobbers :  buildReg ( "R3" ) , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-27 13:54:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} , 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											clobberFlags :  true , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											typ :           "Mem" , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-27 13:54:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// large or unaligned move 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// arg0 = address of dst memory (in R3, changed as side effect) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// arg1 = address of src memory (in R4, changed as side effect) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// arg2 = address of the last element of src 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// arg3 = mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// returns mem 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//  ADD -8,R3,R3 // intermediate value not valid GC ptr, cannot expose to opt+GC 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//  ADD -8,R4,R4 // intermediate value not valid GC ptr, cannot expose to opt+GC 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//	MOVDU	8(R4), Rtmp 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//	MOVDU	Rtmp, 8(R3) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//	CMP	R4, Rarg2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										//	BLT	-3(PC) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											name :       "LoweredMove" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											aux :        "Int64" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											argLength :  4 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											reg :  regInfo { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
												inputs :    [ ] regMask { buildReg ( "R3" ) ,  buildReg ( "R4" ) ,  gp } , 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
												clobbers :  buildReg ( "R3 R4" ) , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-27 13:54:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											} , 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-04 06:57:34 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
											clobberFlags :  true , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
											typ :           "Mem" , 
							 
						 
					
						
							
								
									
										
										
										
											2016-07-27 13:54:07 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
										} , 
							 
						 
					
						
							
								
									
										
										
										
											2016-08-02 13:17:09 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// (InvertFlags (CMP a b)) == (CMP b a) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// So if we want (LessThan (CMP a b)) but we can't do that because a is a constant, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// then we do (LessThan (InvertFlags (CMP b a))) instead. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Rewrites will convert this to (GreaterThan (CMP b a)). 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// InvertFlags is a pseudo-op which can't appear in assembly output. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "InvertFlags" ,  argLength :  1 } ,  // reverse direction of arg0 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// Constant flag values. For any comparison, there are 3 possible 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// outcomes: either the three from the signed total order (<,==,>) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// or the three from the unsigned total order, depending on which 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// comparison operation was used (CMP or CMPU -- PPC is different from 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// the other architectures, which have a single comparison producing 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// both signed and unsigned comparison results.) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// These ops are for temporary use by rewrite rules. They 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										// cannot appear in the generated assembly. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FlagEQ" } ,  // equal 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FlagLT" } ,  // signed < or unsigned < 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "FlagGT" } ,  // signed > or unsigned > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2016-06-24 14:37:17 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									blocks  :=  [ ] blockData { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "EQ" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "NE" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "LT" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "LE" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "GT" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "GE" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "ULT" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "ULE" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "UGT" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										{ name :  "UGE" } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									archs  =  append ( archs ,  arch { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										name :             "PPC64" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										pkg :              "cmd/internal/obj/ppc64" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										genfile :          "../../ppc64/ssa.go" , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										ops :              ops , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										blocks :           blocks , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										regnames :         regNamesPPC64 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										gpregmask :        gp , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										fpregmask :        fp , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
										framepointerreg :  int8 ( num [ "SP" ] ) , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
									} ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}