From adde9ce11876e1dcfaba6f5266cecd780f88b51c Mon Sep 17 00:00:00 2001 From: Steven Date: Wed, 25 Oct 2023 15:04:13 +0800 Subject: [PATCH] fix (libzkp): free Rust CString by `from_raw` (potential memory leak) (#539) * Free Rust CString by `from_raw`. * Update params version. --- params/version.go | 2 +- rollup/circuitcapacitychecker/impl.go | 8 ++++---- rollup/circuitcapacitychecker/libzkp/libzkp.h | 1 + rollup/circuitcapacitychecker/libzkp/src/lib.rs | 13 ++++++++++++- 4 files changed, 18 insertions(+), 6 deletions(-) diff --git a/params/version.go b/params/version.go index 5a335dccfd3f..b9ce0476d866 100644 --- a/params/version.go +++ b/params/version.go @@ -24,7 +24,7 @@ import ( const ( VersionMajor = 5 // Major version component of the current release VersionMinor = 0 // Minor version component of the current release - VersionPatch = 1 // Patch version component of the current release + VersionPatch = 2 // Patch version component of the current release VersionMeta = "mainnet" // Version metadata to append to the version string ) diff --git a/rollup/circuitcapacitychecker/impl.go b/rollup/circuitcapacitychecker/impl.go index 766a9e4130e3..d1f463470b8f 100644 --- a/rollup/circuitcapacitychecker/impl.go +++ b/rollup/circuitcapacitychecker/impl.go @@ -79,7 +79,7 @@ func (ccc *CircuitCapacityChecker) ApplyTransaction(traces *types.BlockTrace) (* log.Debug("start to check circuit capacity for tx", "id", ccc.ID, "TxHash", traces.Transactions[0].TxHash) rawResult := C.apply_tx(C.uint64_t(ccc.ID), tracesStr) defer func() { - C.free(unsafe.Pointer(rawResult)) + C.free_c_chars(rawResult) }() log.Debug("check circuit capacity for tx done", "id", ccc.ID, "TxHash", traces.Transactions[0].TxHash) @@ -125,7 +125,7 @@ func (ccc *CircuitCapacityChecker) ApplyBlock(traces *types.BlockTrace) (*types. log.Debug("start to check circuit capacity for block", "id", ccc.ID, "blockNumber", traces.Header.Number, "blockHash", traces.Header.Hash()) rawResult := C.apply_block(C.uint64_t(ccc.ID), tracesStr) defer func() { - C.free(unsafe.Pointer(rawResult)) + C.free_c_chars(rawResult) }() log.Debug("check circuit capacity for block done", "id", ccc.ID, "blockNumber", traces.Header.Number, "blockHash", traces.Header.Hash()) @@ -157,7 +157,7 @@ func (ccc *CircuitCapacityChecker) CheckTxNum(expected int) (bool, uint64, error log.Debug("ccc get_tx_num start", "id", ccc.ID) rawResult := C.get_tx_num(C.uint64_t(ccc.ID)) defer func() { - C.free(unsafe.Pointer(rawResult)) + C.free_c_chars(rawResult) }() log.Debug("ccc get_tx_num end", "id", ccc.ID) @@ -180,7 +180,7 @@ func (ccc *CircuitCapacityChecker) SetLightMode(lightMode bool) error { log.Debug("ccc set_light_mode start", "id", ccc.ID) rawResult := C.set_light_mode(C.uint64_t(ccc.ID), C.bool(lightMode)) defer func() { - C.free(unsafe.Pointer(rawResult)) + C.free_c_chars(rawResult) }() log.Debug("ccc set_light_mode end", "id", ccc.ID) diff --git a/rollup/circuitcapacitychecker/libzkp/libzkp.h b/rollup/circuitcapacitychecker/libzkp/libzkp.h index 184f33cd7f27..268a3e5a5460 100644 --- a/rollup/circuitcapacitychecker/libzkp/libzkp.h +++ b/rollup/circuitcapacitychecker/libzkp/libzkp.h @@ -8,3 +8,4 @@ char* apply_tx(uint64_t id, char *tx_traces); char* apply_block(uint64_t id, char *block_trace); char* get_tx_num(uint64_t id); char* set_light_mode(uint64_t id, bool light_mode); +void free_c_chars(char* ptr); diff --git a/rollup/circuitcapacitychecker/libzkp/src/lib.rs b/rollup/circuitcapacitychecker/libzkp/src/lib.rs index 6583de48c2ab..a2504950de75 100644 --- a/rollup/circuitcapacitychecker/libzkp/src/lib.rs +++ b/rollup/circuitcapacitychecker/libzkp/src/lib.rs @@ -259,11 +259,22 @@ pub mod checker { } } -pub(crate) mod utils { +pub mod utils { use std::ffi::{CStr, CString}; use std::os::raw::c_char; use std::str::Utf8Error; + /// # Safety + #[no_mangle] + pub unsafe extern "C" fn free_c_chars(ptr: *mut c_char) { + if ptr.is_null() { + log::warn!("Try to free an empty pointer!"); + return; + } + + let _ = CString::from_raw(ptr); + } + #[allow(dead_code)] pub(crate) fn c_char_to_str(c: *const c_char) -> Result<&'static str, Utf8Error> { let cstr = unsafe { CStr::from_ptr(c) };