fix gc issue on isolated data args

This commit is contained in:
Jaremy Creechley 2024-06-01 22:02:57 +01:00
parent ad9d1c39d5
commit 420382b44c
No known key found for this signature in database
GPG Key ID: 4E66FB67B21D3300
3 changed files with 26 additions and 12 deletions

View File

@ -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](

View File

@ -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