fix gc issue on isolated data args
This commit is contained in:
parent
ad9d1c39d5
commit
420382b44c
|
@ -16,19 +16,26 @@ import ./circomcompat
|
||||||
logScope:
|
logScope:
|
||||||
topics = "codex asyncprover"
|
topics = "codex asyncprover"
|
||||||
|
|
||||||
type AsyncCircomCompat* = object
|
type
|
||||||
params*: CircomCompatParams
|
AsyncCircomCompat* = object
|
||||||
circom*: CircomCompat
|
params*: CircomCompatParams
|
||||||
tp*: Taskpool
|
circom*: CircomCompat
|
||||||
|
tp*: Taskpool
|
||||||
|
|
||||||
|
AsyncCircomTask* = object
|
||||||
|
params*: CircomCompatParams
|
||||||
|
data*: ProofInputs[Poseidon2Hash]
|
||||||
|
|
||||||
var localCircom {.threadvar.}: Option[CircomCompat]
|
var localCircom {.threadvar.}: Option[CircomCompat]
|
||||||
|
|
||||||
proc proveTask(
|
proc proveTask(
|
||||||
params: CircomCompatParams, data: ProofInputs[Poseidon2Hash], results: SignalQueuePtr[?!CircomProof]
|
# params: CircomCompatParams, data: ProofInputs[Poseidon2Hash], results: SignalQueuePtr[?!CircomProof]
|
||||||
|
args: ptr AsyncCircomTask,
|
||||||
|
results: SignalQueuePtr[?!CircomProof]
|
||||||
) =
|
) =
|
||||||
|
|
||||||
var data = data
|
var data = args[].data
|
||||||
var params = params
|
var params = args[].params
|
||||||
try:
|
try:
|
||||||
echo "TASK: task: "
|
echo "TASK: task: "
|
||||||
echo "TASK: task: params: ", params.r1csPath.cstring.pointer.repr
|
echo "TASK: task: params: ", params.r1csPath.cstring.pointer.repr
|
||||||
|
@ -39,6 +46,7 @@ proc proveTask(
|
||||||
# echo "TASK: task: ", data
|
# echo "TASK: task: ", data
|
||||||
let proof = localCircom.get().prove(data)
|
let proof = localCircom.get().prove(data)
|
||||||
|
|
||||||
|
GC_fullCollect()
|
||||||
# echo "TASK: task: proof: ", proof.get.hash
|
# echo "TASK: task: proof: ", proof.get.hash
|
||||||
echo "TASK: task: proof: ", proof
|
echo "TASK: task: proof: ", proof
|
||||||
echo "TASK: task: params POST: ", params
|
echo "TASK: task: params POST: ", params
|
||||||
|
@ -54,9 +62,11 @@ proc proveTask(
|
||||||
|
|
||||||
proc spawnProveTask(
|
proc spawnProveTask(
|
||||||
tp: TaskPool,
|
tp: TaskPool,
|
||||||
params: CircomCompatParams, input: ProofInputs[Poseidon2Hash], results: SignalQueuePtr[?!CircomProof]
|
# params: CircomCompatParams, input: ProofInputs[Poseidon2Hash],
|
||||||
|
args: ptr AsyncCircomTask,
|
||||||
|
results: SignalQueuePtr[?!CircomProof]
|
||||||
) =
|
) =
|
||||||
tp.spawn proveTask(params, input, results)
|
tp.spawn proveTask(args, results)
|
||||||
|
|
||||||
proc prove*[H](
|
proc prove*[H](
|
||||||
self: AsyncCircomCompat, input: ProofInputs[H]
|
self: AsyncCircomCompat, input: ProofInputs[H]
|
||||||
|
@ -67,7 +77,9 @@ proc prove*[H](
|
||||||
return failure(qerr)
|
return failure(qerr)
|
||||||
|
|
||||||
echo "TASK: task spawn: params: ", self.params.r1csPath.cstring.pointer.repr
|
echo "TASK: task spawn: params: ", self.params.r1csPath.cstring.pointer.repr
|
||||||
self.tp.spawnProveTask(self.params, input, queue)
|
var args = (ref AsyncCircomTask)(params: self.params, data: input)
|
||||||
|
GC_ref(args)
|
||||||
|
self.tp.spawnProveTask(args[].addr, queue)
|
||||||
|
|
||||||
let taskRes = await queue.recvAsync()
|
let taskRes = await queue.recvAsync()
|
||||||
|
|
||||||
|
@ -78,6 +90,7 @@ proc prove*[H](
|
||||||
without proof =? proofRes, perr:
|
without proof =? proofRes, perr:
|
||||||
return failure(perr)
|
return failure(perr)
|
||||||
|
|
||||||
|
GC_unref(args)
|
||||||
success(proof)
|
success(proof)
|
||||||
|
|
||||||
proc verifyTask[H](
|
proc verifyTask[H](
|
||||||
|
|
|
@ -85,12 +85,13 @@ suite "Test Prover":
|
||||||
prover = Prover.new(store, circomBackend, samples)
|
prover = Prover.new(store, circomBackend, samples)
|
||||||
|
|
||||||
var proofs = newSeq[Future[?!(AnyProofInputs, AnyProof)]]()
|
var proofs = newSeq[Future[?!(AnyProofInputs, AnyProof)]]()
|
||||||
for i in 1..20:
|
for i in 1..50:
|
||||||
echo "PROVE: ", i
|
echo "PROVE: ", i
|
||||||
let
|
let
|
||||||
challenge = (1234567).toF.toBytes.toArray32
|
challenge = (1234567).toF.toBytes.toArray32
|
||||||
|
|
||||||
proofs.add(prover.prove(1, verifiable, challenge))
|
proofs.add(prover.prove(1, verifiable, challenge))
|
||||||
|
GC_fullCollect()
|
||||||
|
|
||||||
await allFutures(proofs)
|
await allFutures(proofs)
|
||||||
echo "done"
|
echo "done"
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 2e694d1a705c16d76891f075aed2305db4f3aac1
|
Subproject commit e710e4c333f367353aaa1ee82a55a47326b63a65
|
Loading…
Reference in New Issue