From 3e3344bc75e41d3901d791fd6e6e4b321007b1eb Mon Sep 17 00:00:00 2001 From: LexLuthr Date: Fri, 5 Apr 2024 14:02:27 +0400 Subject: [PATCH 1/2] improve gasEstimate logging --- storage/pipeline/commit_batch.go | 8 ++++---- storage/pipeline/precommit_batch.go | 2 +- storage/pipeline/utils.go | 16 +++++++++++++++- 3 files changed, 20 insertions(+), 6 deletions(-) diff --git a/storage/pipeline/commit_batch.go b/storage/pipeline/commit_batch.go index ecb8569d0e1..e7d89076f49 100644 --- a/storage/pipeline/commit_batch.go +++ b/storage/pipeline/commit_batch.go @@ -449,9 +449,9 @@ func (b *CommitBatcher) processBatchV2(cfg sealiface.Config, sectors []abi.Secto _, err = simulateMsgGas(b.mctx, b.api, from, b.maddr, builtin.MethodsMiner.ProveCommitSectors3, needFunds, maxFee, enc.Bytes()) if err != nil && (!api.ErrorIsIn(err, []error{&api.ErrOutOfGas{}}) || len(sectors) < miner.MinAggregatedSectors*2) { - log.Errorf("simulating CommitBatch message failed (%x): %s", enc.Bytes(), err) + log.Errorf("simulating CommitBatch %s", err) res.Error = err.Error() - return []sealiface.CommitBatchRes{res}, xerrors.Errorf("simulating CommitBatch message failed: %w", err) + return []sealiface.CommitBatchRes{res}, xerrors.Errorf("simulating CommitBatch %w", err) } msgTooLarge := len(enc.Bytes()) > (messagepool.MaxMessageSize - 128) @@ -590,9 +590,9 @@ func (b *CommitBatcher) processBatchV1(cfg sealiface.Config, sectors []abi.Secto _, err = simulateMsgGas(b.mctx, b.api, from, b.maddr, builtin.MethodsMiner.ProveCommitAggregate, needFunds, maxFee, enc.Bytes()) if err != nil && (!api.ErrorIsIn(err, []error{&api.ErrOutOfGas{}}) || len(sectors) < miner.MinAggregatedSectors*2) { - log.Errorf("simulating CommitBatch message failed (%x): %s", enc.Bytes(), err) + log.Errorf("simulating CommitBatch %s", err) res.Error = err.Error() - return []sealiface.CommitBatchRes{res}, xerrors.Errorf("simulating CommitBatch message failed: %w", err) + return []sealiface.CommitBatchRes{res}, xerrors.Errorf("simulating CommitBatch %w", err) } // If we're out of gas, split the batch in half and evaluate again diff --git a/storage/pipeline/precommit_batch.go b/storage/pipeline/precommit_batch.go index 099988010db..55bead59037 100644 --- a/storage/pipeline/precommit_batch.go +++ b/storage/pipeline/precommit_batch.go @@ -291,7 +291,7 @@ func (b *PreCommitBatcher) processPreCommitBatch(cfg sealiface.Config, bf abi.To if err != nil && (!api.ErrorIsIn(err, []error{&api.ErrOutOfGas{}}) || len(entries) == 1) { res.Error = err.Error() - return []sealiface.PreCommitBatchRes{res}, xerrors.Errorf("simulating PreCommitBatch message failed: %w", err) + return []sealiface.PreCommitBatchRes{res}, xerrors.Errorf("simulating PreCommitBatch %w", err) } // If we're out of gas, split the batch in half and evaluate again diff --git a/storage/pipeline/utils.go b/storage/pipeline/utils.go index 4b99a5beadd..c515ec5d0c3 100644 --- a/storage/pipeline/utils.go +++ b/storage/pipeline/utils.go @@ -1,7 +1,10 @@ package sealing import ( + "bytes" "context" + "encoding/hex" + "fmt" "math/bits" "github.com/ipfs/go-cid" @@ -105,7 +108,18 @@ func simulateMsgGas(ctx context.Context, sa interface { Params: params, } - return sa.GasEstimateMessageGas(ctx, &msg, nil, types.EmptyTSK) + var b bytes.Buffer + err := msg.MarshalCBOR(&b) + if err != nil { + return nil, xerrors.Errorf("failed to unmarshal the signed message: %w", err) + } + s := hex.EncodeToString(b.Bytes()) + + gmsg, err := sa.GasEstimateMessageGas(ctx, &msg, nil, types.EmptyTSK) + if err != nil { + err = fmt.Errorf("message %s failed: %w", s, err) + } + return gmsg, err } func sendMsg(ctx context.Context, sa interface { From bf984466b5ef7bfdbe91cc6715daf8afcd733b41 Mon Sep 17 00:00:00 2001 From: LexLuthr Date: Fri, 5 Apr 2024 15:34:11 +0400 Subject: [PATCH 2/2] use fmt for hex --- storage/pipeline/utils.go | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/storage/pipeline/utils.go b/storage/pipeline/utils.go index c515ec5d0c3..ac519b6acef 100644 --- a/storage/pipeline/utils.go +++ b/storage/pipeline/utils.go @@ -3,7 +3,6 @@ package sealing import ( "bytes" "context" - "encoding/hex" "fmt" "math/bits" @@ -113,11 +112,10 @@ func simulateMsgGas(ctx context.Context, sa interface { if err != nil { return nil, xerrors.Errorf("failed to unmarshal the signed message: %w", err) } - s := hex.EncodeToString(b.Bytes()) gmsg, err := sa.GasEstimateMessageGas(ctx, &msg, nil, types.EmptyTSK) if err != nil { - err = fmt.Errorf("message %s failed: %w", s, err) + err = fmt.Errorf("message %x failed: %w", b.Bytes(), err) } return gmsg, err }