asyncio: fix unreasonable return type of promise.Next()
This commit is contained in:
@@ -21,7 +21,9 @@ func UseGenInts() int {
|
|||||||
co := WrapGenInts()
|
co := WrapGenInts()
|
||||||
r := 0
|
r := 0
|
||||||
for !co.Done() {
|
for !co.Done() {
|
||||||
r += co.Next()
|
v := co.Value()
|
||||||
|
r += v
|
||||||
|
co.Next()
|
||||||
}
|
}
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,50 +19,58 @@ entry:
|
|||||||
%promise = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 16)
|
%promise = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 16)
|
||||||
%id = call token @llvm.coro.id(i32 0, ptr null, ptr null, ptr null)
|
%id = call token @llvm.coro.id(i32 0, ptr null, ptr null, ptr null)
|
||||||
%need.dyn.alloc = call i1 @llvm.coro.alloc(token %id)
|
%need.dyn.alloc = call i1 @llvm.coro.alloc(token %id)
|
||||||
br i1 %need.dyn.alloc, label %alloc, label %_llgo_4
|
br i1 %need.dyn.alloc, label %alloc, label %_llgo_5
|
||||||
|
|
||||||
alloc: ; preds = %entry
|
alloc: ; preds = %entry
|
||||||
%frame.size = call i64 @llvm.coro.size.i64()
|
%frame.size = call i64 @llvm.coro.size.i64()
|
||||||
%frame = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 %frame.size)
|
%frame = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 %frame.size)
|
||||||
br label %_llgo_4
|
br label %_llgo_5
|
||||||
|
|
||||||
clean: ; preds = %_llgo_7, %_llgo_6, %_llgo_5, %_llgo_4
|
clean: ; preds = %_llgo_8, %_llgo_7, %_llgo_6, %_llgo_5
|
||||||
%0 = call ptr @llvm.coro.free(token %id, ptr %hdl)
|
%0 = call ptr @llvm.coro.free(token %id, ptr %hdl)
|
||||||
br label %suspend
|
br label %suspend
|
||||||
|
|
||||||
suspend: ; preds = %_llgo_6, %_llgo_5, %_llgo_4, %clean
|
suspend: ; preds = %_llgo_8, %_llgo_7, %_llgo_6, %_llgo_5, %clean
|
||||||
%1 = call i1 @llvm.coro.end(ptr %hdl, i1 false, token none)
|
%1 = call i1 @llvm.coro.end(ptr %hdl, i1 false, token none)
|
||||||
ret ptr %promise
|
ret ptr %promise
|
||||||
|
|
||||||
_llgo_4: ; preds = %alloc, %entry
|
trap: ; preds = %_llgo_8
|
||||||
|
call void @llvm.trap()
|
||||||
|
unreachable
|
||||||
|
|
||||||
|
_llgo_5: ; preds = %alloc, %entry
|
||||||
%frame1 = phi ptr [ null, %entry ], [ %frame, %alloc ]
|
%frame1 = phi ptr [ null, %entry ], [ %frame, %alloc ]
|
||||||
%hdl = call ptr @llvm.coro.begin(token %id, ptr %frame1)
|
%hdl = call ptr @llvm.coro.begin(token %id, ptr %frame1)
|
||||||
store ptr %hdl, ptr %promise, align 8
|
store ptr %hdl, ptr %promise, align 8
|
||||||
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 1)
|
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 1)
|
||||||
%2 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
%2 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
||||||
switch i8 %2, label %suspend [
|
switch i8 %2, label %suspend [
|
||||||
i8 0, label %_llgo_5
|
|
||||||
i8 1, label %clean
|
|
||||||
]
|
|
||||||
|
|
||||||
_llgo_5: ; preds = %_llgo_4
|
|
||||||
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 2)
|
|
||||||
%3 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
|
||||||
switch i8 %3, label %suspend [
|
|
||||||
i8 0, label %_llgo_6
|
i8 0, label %_llgo_6
|
||||||
i8 1, label %clean
|
i8 1, label %clean
|
||||||
]
|
]
|
||||||
|
|
||||||
_llgo_6: ; preds = %_llgo_5
|
_llgo_6: ; preds = %_llgo_5
|
||||||
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 3)
|
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 2)
|
||||||
%4 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
%3 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
||||||
switch i8 %4, label %suspend [
|
switch i8 %3, label %suspend [
|
||||||
i8 0, label %_llgo_7
|
i8 0, label %_llgo_7
|
||||||
i8 1, label %clean
|
i8 1, label %clean
|
||||||
]
|
]
|
||||||
|
|
||||||
_llgo_7: ; preds = %_llgo_6
|
_llgo_7: ; preds = %_llgo_6
|
||||||
br label %clean
|
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 3)
|
||||||
|
%4 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
||||||
|
switch i8 %4, label %suspend [
|
||||||
|
i8 0, label %_llgo_8
|
||||||
|
i8 1, label %clean
|
||||||
|
]
|
||||||
|
|
||||||
|
_llgo_8: ; preds = %_llgo_7
|
||||||
|
%5 = call i8 @llvm.coro.suspend(token %id, i1 true)
|
||||||
|
switch i8 %5, label %suspend [
|
||||||
|
i8 0, label %trap
|
||||||
|
i8 1, label %clean
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
define ptr @"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer"() #0 {
|
define ptr @"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer"() #0 {
|
||||||
@@ -70,22 +78,26 @@ entry:
|
|||||||
%promise = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 16)
|
%promise = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 16)
|
||||||
%id = call token @llvm.coro.id(i32 0, ptr null, ptr null, ptr null)
|
%id = call token @llvm.coro.id(i32 0, ptr null, ptr null, ptr null)
|
||||||
%need.dyn.alloc = call i1 @llvm.coro.alloc(token %id)
|
%need.dyn.alloc = call i1 @llvm.coro.alloc(token %id)
|
||||||
br i1 %need.dyn.alloc, label %alloc, label %_llgo_4
|
br i1 %need.dyn.alloc, label %alloc, label %_llgo_5
|
||||||
|
|
||||||
alloc: ; preds = %entry
|
alloc: ; preds = %entry
|
||||||
%frame.size = call i64 @llvm.coro.size.i64()
|
%frame.size = call i64 @llvm.coro.size.i64()
|
||||||
%frame = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 %frame.size)
|
%frame = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 %frame.size)
|
||||||
br label %_llgo_4
|
br label %_llgo_5
|
||||||
|
|
||||||
clean: ; preds = %_llgo_5, %_llgo_8
|
clean: ; preds = %_llgo_6, %_llgo_9
|
||||||
%0 = call ptr @llvm.coro.free(token %id, ptr %hdl)
|
%0 = call ptr @llvm.coro.free(token %id, ptr %hdl)
|
||||||
br label %suspend
|
br label %suspend
|
||||||
|
|
||||||
suspend: ; preds = %_llgo_8, %clean
|
suspend: ; preds = %_llgo_6, %_llgo_9, %clean
|
||||||
%1 = call i1 @llvm.coro.end(ptr %hdl, i1 false, token none)
|
%1 = call i1 @llvm.coro.end(ptr %hdl, i1 false, token none)
|
||||||
ret ptr %promise
|
ret ptr %promise
|
||||||
|
|
||||||
_llgo_4: ; preds = %alloc, %entry
|
trap: ; preds = %_llgo_6
|
||||||
|
call void @llvm.trap()
|
||||||
|
unreachable
|
||||||
|
|
||||||
|
_llgo_5: ; preds = %alloc, %entry
|
||||||
%frame1 = phi ptr [ null, %entry ], [ %frame, %alloc ]
|
%frame1 = phi ptr [ null, %entry ], [ %frame, %alloc ]
|
||||||
%hdl = call ptr @llvm.coro.begin(token %id, ptr %frame1)
|
%hdl = call ptr @llvm.coro.begin(token %id, ptr %frame1)
|
||||||
store ptr %hdl, ptr %promise, align 8
|
store ptr %hdl, ptr %promise, align 8
|
||||||
@@ -102,16 +114,16 @@ _llgo_4: ; preds = %alloc, %entry
|
|||||||
%10 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 2
|
%10 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 2
|
||||||
store ptr %5, ptr %10, align 8
|
store ptr %5, ptr %10, align 8
|
||||||
%11 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 3
|
%11 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 3
|
||||||
store ptr blockaddress(@"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer", %_llgo_6), ptr %11, align 8
|
store ptr blockaddress(@"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer", %_llgo_7), ptr %11, align 8
|
||||||
%12 = call i32 @pthread_setspecific(i32 %4, ptr %7)
|
%12 = call i32 @pthread_setspecific(i32 %4, ptr %7)
|
||||||
%13 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 1
|
%13 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 1
|
||||||
%14 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 3
|
%14 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 3
|
||||||
%15 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 4
|
%15 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, i32 0, i32 4
|
||||||
%16 = call i32 @sigsetjmp(ptr %6, i32 0)
|
%16 = call i32 @sigsetjmp(ptr %6, i32 0)
|
||||||
%17 = icmp eq i32 %16, 0
|
%17 = icmp eq i32 %16, 0
|
||||||
br i1 %17, label %_llgo_8, label %_llgo_9
|
br i1 %17, label %_llgo_9, label %_llgo_10
|
||||||
|
|
||||||
_llgo_5: ; preds = %_llgo_8, %_llgo_7
|
_llgo_6: ; preds = %_llgo_9, %_llgo_8
|
||||||
%18 = alloca %"github.com/goplus/llgo/internal/runtime.String", align 8
|
%18 = alloca %"github.com/goplus/llgo/internal/runtime.String", align 8
|
||||||
%19 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.String", ptr %18, i32 0, i32 0
|
%19 = getelementptr inbounds %"github.com/goplus/llgo/internal/runtime.String", ptr %18, i32 0, i32 0
|
||||||
store ptr @0, ptr %19, align 8
|
store ptr @0, ptr %19, align 8
|
||||||
@@ -130,37 +142,41 @@ _llgo_5: ; preds = %_llgo_8, %_llgo_7
|
|||||||
call void @"github.com/goplus/llgo/internal/runtime.Panic"(%"github.com/goplus/llgo/internal/runtime.eface" %27)
|
call void @"github.com/goplus/llgo/internal/runtime.Panic"(%"github.com/goplus/llgo/internal/runtime.eface" %27)
|
||||||
unreachable
|
unreachable
|
||||||
%28 = load ptr, ptr %3, align 8
|
%28 = load ptr, ptr %3, align 8
|
||||||
br label %clean
|
%29 = call i8 @llvm.coro.suspend(token %id, i1 true)
|
||||||
|
switch i8 %29, label %suspend [
|
||||||
_llgo_6: ; preds = %_llgo_9
|
i8 0, label %trap
|
||||||
store ptr blockaddress(@"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer", %_llgo_7), ptr %14, align 8
|
|
||||||
%29 = load i64, ptr %13, align 4
|
|
||||||
call void @"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer$1"()
|
|
||||||
%30 = load %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, align 8
|
|
||||||
%31 = extractvalue %"github.com/goplus/llgo/internal/runtime.Defer" %30, 2
|
|
||||||
%32 = call i32 @pthread_setspecific(i32 %4, ptr %31)
|
|
||||||
%33 = load ptr, ptr %15, align 8
|
|
||||||
indirectbr ptr %33, [label %_llgo_7]
|
|
||||||
|
|
||||||
_llgo_7: ; preds = %_llgo_9, %_llgo_6
|
|
||||||
call void @"github.com/goplus/llgo/internal/runtime.Rethrow"(ptr %5)
|
|
||||||
br label %_llgo_5
|
|
||||||
|
|
||||||
_llgo_8: ; preds = %_llgo_4
|
|
||||||
%34 = load ptr, ptr %3, align 8
|
|
||||||
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 1)
|
|
||||||
%35 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
|
||||||
switch i8 %35, label %suspend [
|
|
||||||
i8 0, label %_llgo_5
|
|
||||||
i8 1, label %clean
|
i8 1, label %clean
|
||||||
]
|
]
|
||||||
|
|
||||||
_llgo_9: ; preds = %_llgo_4
|
_llgo_7: ; preds = %_llgo_10
|
||||||
store ptr blockaddress(@"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer", %_llgo_7), ptr %15, align 8
|
store ptr blockaddress(@"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer", %_llgo_8), ptr %14, align 8
|
||||||
%36 = load ptr, ptr %14, align 8
|
%30 = load i64, ptr %13, align 4
|
||||||
indirectbr ptr %36, [label %_llgo_7, label %_llgo_6]
|
call void @"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer$1"()
|
||||||
|
%31 = load %"github.com/goplus/llgo/internal/runtime.Defer", ptr %7, align 8
|
||||||
|
%32 = extractvalue %"github.com/goplus/llgo/internal/runtime.Defer" %31, 2
|
||||||
|
%33 = call i32 @pthread_setspecific(i32 %4, ptr %32)
|
||||||
|
%34 = load ptr, ptr %15, align 8
|
||||||
|
indirectbr ptr %34, [label %_llgo_8]
|
||||||
|
|
||||||
_llgo_10: ; No predecessors!
|
_llgo_8: ; preds = %_llgo_10, %_llgo_7
|
||||||
|
call void @"github.com/goplus/llgo/internal/runtime.Rethrow"(ptr %5)
|
||||||
|
br label %_llgo_6
|
||||||
|
|
||||||
|
_llgo_9: ; preds = %_llgo_5
|
||||||
|
%35 = load ptr, ptr %3, align 8
|
||||||
|
call void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %promise, i64 1)
|
||||||
|
%36 = call i8 @llvm.coro.suspend(token %id, i1 false)
|
||||||
|
switch i8 %36, label %suspend [
|
||||||
|
i8 0, label %_llgo_6
|
||||||
|
i8 1, label %clean
|
||||||
|
]
|
||||||
|
|
||||||
|
_llgo_10: ; preds = %_llgo_5
|
||||||
|
store ptr blockaddress(@"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer", %_llgo_8), ptr %15, align 8
|
||||||
|
%37 = load ptr, ptr %14, align 8
|
||||||
|
indirectbr ptr %37, [label %_llgo_8, label %_llgo_7]
|
||||||
|
|
||||||
|
_llgo_11: ; No predecessors!
|
||||||
}
|
}
|
||||||
|
|
||||||
define void @"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer$1"() {
|
define void @"github.com/goplus/llgo/cl/_testdata/async.GenIntsWithDefer$1"() {
|
||||||
@@ -212,8 +228,9 @@ _llgo_0:
|
|||||||
br label %_llgo_3
|
br label %_llgo_3
|
||||||
|
|
||||||
_llgo_1: ; preds = %_llgo_3
|
_llgo_1: ; preds = %_llgo_3
|
||||||
%1 = call i64 @"github.com/goplus/llgo/x/async.(*Promise).Next[int]"(ptr %0)
|
%1 = call i64 @"github.com/goplus/llgo/x/async.(*Promise).Value[int]"(ptr %0)
|
||||||
%2 = add i64 %3, %1
|
%2 = add i64 %3, %1
|
||||||
|
call void @"github.com/goplus/llgo/x/async.(*Promise).Next[int]"(ptr %0)
|
||||||
br label %_llgo_3
|
br label %_llgo_3
|
||||||
|
|
||||||
_llgo_2: ; preds = %_llgo_3
|
_llgo_2: ; preds = %_llgo_3
|
||||||
@@ -230,27 +247,35 @@ entry:
|
|||||||
%promise = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 16)
|
%promise = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 16)
|
||||||
%id = call token @llvm.coro.id(i32 0, ptr null, ptr null, ptr null)
|
%id = call token @llvm.coro.id(i32 0, ptr null, ptr null, ptr null)
|
||||||
%need.dyn.alloc = call i1 @llvm.coro.alloc(token %id)
|
%need.dyn.alloc = call i1 @llvm.coro.alloc(token %id)
|
||||||
br i1 %need.dyn.alloc, label %alloc, label %_llgo_4
|
br i1 %need.dyn.alloc, label %alloc, label %_llgo_5
|
||||||
|
|
||||||
alloc: ; preds = %entry
|
alloc: ; preds = %entry
|
||||||
%frame.size = call i64 @llvm.coro.size.i64()
|
%frame.size = call i64 @llvm.coro.size.i64()
|
||||||
%frame = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 %frame.size)
|
%frame = call ptr @"github.com/goplus/llgo/internal/runtime.AllocZ"(i64 %frame.size)
|
||||||
br label %_llgo_4
|
br label %_llgo_5
|
||||||
|
|
||||||
clean: ; preds = %_llgo_4
|
clean: ; preds = %_llgo_5
|
||||||
%0 = call ptr @llvm.coro.free(token %id, ptr %hdl)
|
%0 = call ptr @llvm.coro.free(token %id, ptr %hdl)
|
||||||
br label %suspend
|
br label %suspend
|
||||||
|
|
||||||
suspend: ; preds = %clean
|
suspend: ; preds = %_llgo_5, %clean
|
||||||
%1 = call i1 @llvm.coro.end(ptr %hdl, i1 false, token none)
|
%1 = call i1 @llvm.coro.end(ptr %hdl, i1 false, token none)
|
||||||
ret ptr %promise
|
ret ptr %promise
|
||||||
|
|
||||||
_llgo_4: ; preds = %alloc, %entry
|
trap: ; preds = %_llgo_5
|
||||||
|
call void @llvm.trap()
|
||||||
|
unreachable
|
||||||
|
|
||||||
|
_llgo_5: ; preds = %alloc, %entry
|
||||||
%frame1 = phi ptr [ null, %entry ], [ %frame, %alloc ]
|
%frame1 = phi ptr [ null, %entry ], [ %frame, %alloc ]
|
||||||
%hdl = call ptr @llvm.coro.begin(token %id, ptr %frame1)
|
%hdl = call ptr @llvm.coro.begin(token %id, ptr %frame1)
|
||||||
store ptr %hdl, ptr %promise, align 8
|
store ptr %hdl, ptr %promise, align 8
|
||||||
%2 = call ptr @"github.com/goplus/llgo/cl/_testdata/async.GenInts"()
|
%2 = call ptr @"github.com/goplus/llgo/cl/_testdata/async.GenInts"()
|
||||||
br label %clean
|
%3 = call i8 @llvm.coro.suspend(token %id, i1 true)
|
||||||
|
switch i8 %3, label %suspend [
|
||||||
|
i8 0, label %trap
|
||||||
|
i8 1, label %clean
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
define void @"github.com/goplus/llgo/cl/_testdata/async.init"() {
|
define void @"github.com/goplus/llgo/cl/_testdata/async.init"() {
|
||||||
@@ -288,6 +313,9 @@ declare ptr @llvm.coro.free(token, ptr nocapture readonly) #4
|
|||||||
; Function Attrs: nounwind
|
; Function Attrs: nounwind
|
||||||
declare i1 @llvm.coro.end(ptr, i1, token) #2
|
declare i1 @llvm.coro.end(ptr, i1, token) #2
|
||||||
|
|
||||||
|
; Function Attrs: cold noreturn nounwind memory(inaccessiblemem: write)
|
||||||
|
declare void @llvm.trap() #5
|
||||||
|
|
||||||
define void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %0, i64 %1) {
|
define void @"github.com/goplus/llgo/x/async.(*Promise).setValue[int]"(ptr %0, i64 %1) {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
%2 = getelementptr inbounds %"github.com/goplus/llgo/x/async.Promise[int]", ptr %0, i32 0, i32 1
|
%2 = getelementptr inbounds %"github.com/goplus/llgo/x/async.Promise[int]", ptr %0, i32 0, i32 1
|
||||||
@@ -355,20 +383,25 @@ _llgo_0:
|
|||||||
ret i1 %6
|
ret i1 %6
|
||||||
}
|
}
|
||||||
|
|
||||||
define i64 @"github.com/goplus/llgo/x/async.(*Promise).Next[int]"(ptr %0) {
|
define i64 @"github.com/goplus/llgo/x/async.(*Promise).Value[int]"(ptr %0) {
|
||||||
|
_llgo_0:
|
||||||
|
%1 = getelementptr inbounds %"github.com/goplus/llgo/x/async.Promise[int]", ptr %0, i32 0, i32 1
|
||||||
|
%2 = load i64, ptr %1, align 4
|
||||||
|
ret i64 %2
|
||||||
|
}
|
||||||
|
|
||||||
|
define void @"github.com/goplus/llgo/x/async.(*Promise).Next[int]"(ptr %0) {
|
||||||
_llgo_0:
|
_llgo_0:
|
||||||
%1 = getelementptr inbounds %"github.com/goplus/llgo/x/async.Promise[int]", ptr %0, i32 0, i32 0
|
%1 = getelementptr inbounds %"github.com/goplus/llgo/x/async.Promise[int]", ptr %0, i32 0, i32 0
|
||||||
%2 = load ptr, ptr %1, align 8
|
%2 = load ptr, ptr %1, align 8
|
||||||
call void @llvm.coro.resume(ptr %2)
|
call void @llvm.coro.resume(ptr %2)
|
||||||
%3 = getelementptr inbounds %"github.com/goplus/llgo/x/async.Promise[int]", ptr %0, i32 0, i32 1
|
ret void
|
||||||
%4 = load i64, ptr %3, align 4
|
|
||||||
ret i64 %4
|
|
||||||
}
|
}
|
||||||
|
|
||||||
declare void @fmt.init()
|
declare void @fmt.init()
|
||||||
|
|
||||||
; Function Attrs: nounwind memory(argmem: readwrite)
|
; Function Attrs: nounwind memory(argmem: readwrite)
|
||||||
declare i1 @llvm.coro.done(ptr nocapture readonly) #5
|
declare i1 @llvm.coro.done(ptr nocapture readonly) #6
|
||||||
|
|
||||||
declare void @llvm.coro.resume(ptr)
|
declare void @llvm.coro.resume(ptr)
|
||||||
|
|
||||||
@@ -379,4 +412,5 @@ attributes #1 = { nocallback nofree nosync nounwind willreturn memory(argmem: re
|
|||||||
attributes #2 = { nounwind }
|
attributes #2 = { nounwind }
|
||||||
attributes #3 = { nounwind memory(none) }
|
attributes #3 = { nounwind memory(none) }
|
||||||
attributes #4 = { nounwind memory(argmem: read) }
|
attributes #4 = { nounwind memory(argmem: read) }
|
||||||
attributes #5 = { nounwind memory(argmem: readwrite) }
|
attributes #5 = { cold noreturn nounwind memory(inaccessiblemem: write) }
|
||||||
|
attributes #6 = { nounwind memory(argmem: readwrite) }
|
||||||
|
|||||||
@@ -54,9 +54,8 @@ func (p *Promise[TOut]) Resume() {
|
|||||||
coResume(p.hdl)
|
coResume(p.hdl)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Promise[TOut]) Next() TOut {
|
func (p *Promise[TOut]) Next() {
|
||||||
coResume(p.hdl)
|
coResume(p.hdl)
|
||||||
return p.value
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(lijie): should merge to Yield()
|
// TODO(lijie): should merge to Yield()
|
||||||
|
|||||||
Reference in New Issue
Block a user