ssa: fix newSlice.type & const
This commit is contained in:
11
cl/_testdata/builtin/in.go
Normal file
11
cl/_testdata/builtin/in.go
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
var a int64 = 1<<63 - 1
|
||||||
|
var b int64 = -1 << 63
|
||||||
|
var c uint64 = 1<<64 - 1
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
var a = []int{1, 2, 3, 4}
|
||||||
|
_ = len(a)
|
||||||
|
_ = len([]int{1, 2, 3, 4})
|
||||||
|
}
|
||||||
59
cl/_testdata/builtin/out.ll
Normal file
59
cl/_testdata/builtin/out.ll
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
; ModuleID = 'main'
|
||||||
|
source_filename = "main"
|
||||||
|
|
||||||
|
%"github.com/goplus/llgo/internal/runtime.Slice" = type { ptr, i64, i64 }
|
||||||
|
|
||||||
|
@main.a = global ptr null
|
||||||
|
@main.b = global ptr null
|
||||||
|
@main.c = global ptr null
|
||||||
|
@"main.init$guard" = global ptr null
|
||||||
|
|
||||||
|
define void @main.init() {
|
||||||
|
_llgo_0:
|
||||||
|
%0 = load i1, ptr @"main.init$guard", align 1
|
||||||
|
br i1 %0, label %_llgo_2, label %_llgo_1
|
||||||
|
|
||||||
|
_llgo_1: ; preds = %_llgo_0
|
||||||
|
store i1 true, ptr @"main.init$guard", align 1
|
||||||
|
store i64 9223372036854775807, ptr @main.a, align 4
|
||||||
|
store i64 -9223372036854775808, ptr @main.b, align 4
|
||||||
|
store i64 -1, ptr @main.c, align 4
|
||||||
|
br label %_llgo_2
|
||||||
|
|
||||||
|
_llgo_2: ; preds = %_llgo_1, %_llgo_0
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
|
define void @main() {
|
||||||
|
_llgo_0:
|
||||||
|
call void @main.init()
|
||||||
|
%0 = call ptr @"github.com/goplus/llgo/internal/runtime.Alloc"(i64 16)
|
||||||
|
%1 = getelementptr inbounds i64, ptr %0, i64 0
|
||||||
|
store i64 1, ptr %1, align 4
|
||||||
|
%2 = getelementptr inbounds i64, ptr %0, i64 1
|
||||||
|
store i64 2, ptr %2, align 4
|
||||||
|
%3 = getelementptr inbounds i64, ptr %0, i64 2
|
||||||
|
store i64 3, ptr %3, align 4
|
||||||
|
%4 = getelementptr inbounds i64, ptr %0, i64 3
|
||||||
|
store i64 4, ptr %4, align 4
|
||||||
|
%5 = call %"github.com/goplus/llgo/internal/runtime.Slice" @"github.com/goplus/llgo/internal/runtime.NewSlice"(i64 4, i64 4)
|
||||||
|
%6 = call i64 @"github.com/goplus/llgo/internal/runtime.SliceLen"(%"github.com/goplus/llgo/internal/runtime.Slice" %5)
|
||||||
|
%7 = call ptr @"github.com/goplus/llgo/internal/runtime.Alloc"(i64 16)
|
||||||
|
%8 = getelementptr inbounds i64, ptr %7, i64 0
|
||||||
|
store i64 1, ptr %8, align 4
|
||||||
|
%9 = getelementptr inbounds i64, ptr %7, i64 1
|
||||||
|
store i64 2, ptr %9, align 4
|
||||||
|
%10 = getelementptr inbounds i64, ptr %7, i64 2
|
||||||
|
store i64 3, ptr %10, align 4
|
||||||
|
%11 = getelementptr inbounds i64, ptr %7, i64 3
|
||||||
|
store i64 4, ptr %11, align 4
|
||||||
|
%12 = call %"github.com/goplus/llgo/internal/runtime.Slice" @"github.com/goplus/llgo/internal/runtime.NewSlice"(i64 4, i64 4)
|
||||||
|
%13 = call i64 @"github.com/goplus/llgo/internal/runtime.SliceLen"(%"github.com/goplus/llgo/internal/runtime.Slice" %12)
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
|
declare ptr @"github.com/goplus/llgo/internal/runtime.Alloc"(i64)
|
||||||
|
|
||||||
|
declare %"github.com/goplus/llgo/internal/runtime.Slice" @"github.com/goplus/llgo/internal/runtime.NewSlice"(ptr, i64, i64)
|
||||||
|
|
||||||
|
declare i64 @"github.com/goplus/llgo/internal/runtime.SliceLen"(%"github.com/goplus/llgo/internal/runtime.Slice")
|
||||||
15
ssa/expr.go
15
ssa/expr.go
@@ -136,16 +136,14 @@ func (b Builder) Const(v constant.Value, typ Type) Expr {
|
|||||||
switch {
|
switch {
|
||||||
case kind == types.Bool:
|
case kind == types.Bool:
|
||||||
return prog.BoolVal(constant.BoolVal(v))
|
return prog.BoolVal(constant.BoolVal(v))
|
||||||
case kind >= types.Int && kind <= types.Uintptr:
|
case kind >= types.Int && kind <= types.Int64:
|
||||||
if v, exact := constant.Int64Val(v); exact {
|
if v, exact := constant.Int64Val(v); exact {
|
||||||
return prog.IntVal(uint64(v), typ)
|
return prog.IntVal(uint64(v), typ)
|
||||||
}
|
}
|
||||||
panic("todo")
|
case kind >= types.Uint && kind <= types.Uintptr:
|
||||||
/*
|
if v, exact := constant.Uint64Val(v); exact {
|
||||||
if v, exact := constant.Uint64Val(v); exact {
|
return prog.IntVal(v, typ)
|
||||||
return prog.IntVal(v, typ)
|
}
|
||||||
}
|
|
||||||
*/
|
|
||||||
case kind == types.Float32 || kind == types.Float64:
|
case kind == types.Float32 || kind == types.Float64:
|
||||||
if v, exact := constant.Float64Val(v); exact {
|
if v, exact := constant.Float64Val(v); exact {
|
||||||
return prog.FloatVal(v, typ)
|
return prog.FloatVal(v, typ)
|
||||||
@@ -460,7 +458,8 @@ func (b Builder) Slice(x, low, high, max Expr) (ret Expr) {
|
|||||||
ret.Type = prog.Type(types.NewSlice(te.Elem()))
|
ret.Type = prog.Type(types.NewSlice(te.Elem()))
|
||||||
if low.IsNil() && high.IsNil() && max.IsNil() {
|
if low.IsNil() && high.IsNil() && max.IsNil() {
|
||||||
n := prog.Val(int(te.Len()))
|
n := prog.Val(int(te.Len()))
|
||||||
return b.InlineCall(pkg.rtFunc("NewSlice"), n, n)
|
ret.impl = b.InlineCall(pkg.rtFunc("NewSlice"), n, n).impl
|
||||||
|
return ret
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user