compiler: Improve IR/SSA printing
Этот коммит содержится в:
		
							родитель
							
								
									5acde63f88
								
							
						
					
					
						коммит
						62325eab40
					
				
					 1 изменённых файлов: 22 добавлений и 8 удалений
				
			
		
							
								
								
									
										30
									
								
								tgo.go
									
										
									
									
									
								
							
							
						
						
									
										30
									
								
								tgo.go
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -28,6 +28,7 @@ func init() {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
type Compiler struct {
 | 
			
		||||
	dumpSSA         bool
 | 
			
		||||
	triple          string
 | 
			
		||||
	mod             llvm.Module
 | 
			
		||||
	ctx             llvm.Context
 | 
			
		||||
| 
						 | 
				
			
			@ -79,8 +80,9 @@ type Phi struct {
 | 
			
		|||
	llvm llvm.Value
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func NewCompiler(pkgName, triple string) (*Compiler, error) {
 | 
			
		||||
func NewCompiler(pkgName, triple string, dumpSSA bool) (*Compiler, error) {
 | 
			
		||||
	c := &Compiler{
 | 
			
		||||
		dumpSSA:        dumpSSA,
 | 
			
		||||
		triple:         triple,
 | 
			
		||||
		itfTypeNumbers: make(map[types.Type]uint64),
 | 
			
		||||
		analysis:       NewAnalysis(),
 | 
			
		||||
| 
						 | 
				
			
			@ -575,8 +577,6 @@ func (c *Compiler) parsePackage(program *ssa.Program, pkg *ssa.Package) error {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
func (c *Compiler) parseFuncDecl(f *ssa.Function) (*Frame, error) {
 | 
			
		||||
	f.WriteTo(os.Stdout)
 | 
			
		||||
 | 
			
		||||
	frame := &Frame{
 | 
			
		||||
		fn:       f,
 | 
			
		||||
		params:   make(map[*ssa.Parameter]int),
 | 
			
		||||
| 
						 | 
				
			
			@ -717,6 +717,9 @@ func (c *Compiler) parseInitFunc(frame *Frame, f *ssa.Function) error {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
func (c *Compiler) parseFunc(frame *Frame, f *ssa.Function) error {
 | 
			
		||||
	if c.dumpSSA {
 | 
			
		||||
		fmt.Printf("\nfunc %s:\n", f)
 | 
			
		||||
	}
 | 
			
		||||
	frame.llvmFn.SetLinkage(llvm.PrivateLinkage)
 | 
			
		||||
 | 
			
		||||
	// Pre-create all basic blocks in the function.
 | 
			
		||||
| 
						 | 
				
			
			@ -771,8 +774,18 @@ func (c *Compiler) parseFunc(frame *Frame, f *ssa.Function) error {
 | 
			
		|||
 | 
			
		||||
	// Fill blocks with instructions.
 | 
			
		||||
	for _, block := range f.DomPreorder() {
 | 
			
		||||
		if c.dumpSSA {
 | 
			
		||||
			fmt.Printf("%s:\n", block.Comment)
 | 
			
		||||
		}
 | 
			
		||||
		c.builder.SetInsertPointAtEnd(frame.blocks[block])
 | 
			
		||||
		for _, instr := range block.Instrs {
 | 
			
		||||
			if c.dumpSSA {
 | 
			
		||||
				if val, ok := instr.(ssa.Value); ok && val.Name() != "" {
 | 
			
		||||
					fmt.Printf("\t%s = %s\n", val.Name(), val.String())
 | 
			
		||||
				} else {
 | 
			
		||||
					fmt.Printf("\t%s\n", instr.String())
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
			err := c.parseInstr(frame, instr)
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				return err
 | 
			
		||||
| 
						 | 
				
			
			@ -1584,7 +1597,7 @@ func (c *Compiler) EmitObject(path string) error {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
// Helper function for Compiler object.
 | 
			
		||||
func Compile(pkgName, runtimePath, outpath, target string, printIR bool) error {
 | 
			
		||||
func Compile(pkgName, runtimePath, outpath, target string, printIR, dumpSSA bool) error {
 | 
			
		||||
	var buildTags []string
 | 
			
		||||
	// TODO: put this somewhere else
 | 
			
		||||
	if target == "pca10040" {
 | 
			
		||||
| 
						 | 
				
			
			@ -1595,7 +1608,7 @@ func Compile(pkgName, runtimePath, outpath, target string, printIR bool) error {
 | 
			
		|||
		target = "avr--"
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	c, err := NewCompiler(pkgName, target)
 | 
			
		||||
	c, err := NewCompiler(pkgName, target, dumpSSA)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
| 
						 | 
				
			
			@ -1615,7 +1628,7 @@ func Compile(pkgName, runtimePath, outpath, target string, printIR bool) error {
 | 
			
		|||
		if printIR {
 | 
			
		||||
			// Run this even if c.Parse() panics.
 | 
			
		||||
			defer func() {
 | 
			
		||||
				fmt.Println("IR until the error:")
 | 
			
		||||
				fmt.Println("Generated LLVM IR:")
 | 
			
		||||
				fmt.Println(c.IR())
 | 
			
		||||
			}()
 | 
			
		||||
		}
 | 
			
		||||
| 
						 | 
				
			
			@ -1646,7 +1659,8 @@ func Compile(pkgName, runtimePath, outpath, target string, printIR bool) error {
 | 
			
		|||
 | 
			
		||||
func main() {
 | 
			
		||||
	outpath := flag.String("o", "", "output filename")
 | 
			
		||||
	printIR := flag.Bool("printir", false, "print LLVM IR after optimizing")
 | 
			
		||||
	printIR := flag.Bool("printir", false, "print LLVM IR")
 | 
			
		||||
	dumpSSA := flag.Bool("dumpssa", false, "dump internal Go SSA")
 | 
			
		||||
	runtime := flag.String("runtime", "", "runtime LLVM bitcode files (from C sources)")
 | 
			
		||||
	target := flag.String("target", llvm.DefaultTargetTriple(), "LLVM target")
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -1660,7 +1674,7 @@ func main() {
 | 
			
		|||
 | 
			
		||||
	os.Setenv("CC", "clang -target=" + *target)
 | 
			
		||||
 | 
			
		||||
	err := Compile(flag.Args()[0], *runtime, *outpath, *target, *printIR)
 | 
			
		||||
	err := Compile(flag.Args()[0], *runtime, *outpath, *target, *printIR, *dumpSSA)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		fmt.Fprintln(os.Stderr, "error:", err)
 | 
			
		||||
		os.Exit(1)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Загрузка…
	
	Создание таблицы
		
		Сослаться в новой задаче