diff options
author | Chelsea Holland Komlo <me@chelseakomlo.com> | 2017-10-11 15:21:20 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2017-10-27 10:02:08 -0400 |
commit | be583a34a3815c2c10e86094ab0610e4b7f9c869 (patch) | |
tree | be9ffef37a21f54a81e628c1911c9171bbeef202 /src/rust | |
parent | 0c04b54d4d78f7f3117948358b3d05e644fa1aeb (diff) | |
download | tor-be583a34a3815c2c10e86094ab0610e4b7f9c869.tar.gz tor-be583a34a3815c2c10e86094ab0610e4b7f9c869.zip |
use tor allocator for string allocation in rust
Diffstat (limited to 'src/rust')
-rw-r--r-- | src/rust/Cargo.lock | 15 | ||||
-rw-r--r-- | src/rust/Cargo.toml | 2 | ||||
-rw-r--r-- | src/rust/c_string/Cargo.toml | 13 | ||||
-rw-r--r-- | src/rust/c_string/ffi.rs | 19 | ||||
-rw-r--r-- | src/rust/c_string/include.am | 12 | ||||
-rw-r--r-- | src/rust/external/external.rs | 9 | ||||
-rw-r--r-- | src/rust/include.am | 1 | ||||
-rw-r--r-- | src/rust/protover/Cargo.toml | 3 | ||||
-rw-r--r-- | src/rust/protover/ffi.rs | 62 | ||||
-rw-r--r-- | src/rust/protover/lib.rs | 1 | ||||
-rw-r--r-- | src/rust/protover/protover.rs | 2 |
11 files changed, 39 insertions, 100 deletions
diff --git a/src/rust/Cargo.lock b/src/rust/Cargo.lock index aa91ea355c..56cb9d76ba 100644 --- a/src/rust/Cargo.lock +++ b/src/rust/Cargo.lock @@ -6,13 +6,6 @@ dependencies = [ ] [[package]] -name = "c_string" -version = "0.0.1" -dependencies = [ - "libc 0.2.22 (registry+https://github.com/rust-lang/crates.io-index)", -] - -[[package]] name = "external" version = "0.0.1" dependencies = [ @@ -31,6 +24,7 @@ dependencies = [ "external 0.0.1", "libc 0.2.22 (registry+https://github.com/rust-lang/crates.io-index)", "smartlist 0.0.1", + "tor_allocate 0.0.1", "tor_util 0.0.1", ] @@ -41,5 +35,12 @@ dependencies = [ "libc 0.2.22 (registry+https://github.com/rust-lang/crates.io-index)", ] +[[package]] +name = "tor_allocate" +version = "0.0.1" +dependencies = [ + "libc 0.2.22 (registry+https://github.com/rust-lang/crates.io-index)", +] + [metadata] "checksum libc 0.2.22 (registry+https://github.com/rust-lang/crates.io-index)" = "babb8281da88cba992fa1f4ddec7d63ed96280a1a53ec9b919fd37b53d71e502" diff --git a/src/rust/Cargo.toml b/src/rust/Cargo.toml index 6943627e38..5d4292bbd3 100644 --- a/src/rust/Cargo.toml +++ b/src/rust/Cargo.toml @@ -1,5 +1,5 @@ [workspace] -members = ["tor_util", "protover", "smartlist", "external", "c_string"] +members = ["tor_util", "protover", "smartlist", "external", "tor_allocate"] [profile.release] debug = true diff --git a/src/rust/c_string/Cargo.toml b/src/rust/c_string/Cargo.toml deleted file mode 100644 index dc7504856b..0000000000 --- a/src/rust/c_string/Cargo.toml +++ /dev/null @@ -1,13 +0,0 @@ -[package] -authors = ["The Tor Project"] -version = "0.0.1" -name = "c_string" - -[dependencies] -libc = "0.2.22" - -[lib] -name = "c_string" -path = "ffi.rs" -crate_type = ["rlib", "staticlib"] - diff --git a/src/rust/c_string/ffi.rs b/src/rust/c_string/ffi.rs deleted file mode 100644 index edce250829..0000000000 --- a/src/rust/c_string/ffi.rs +++ /dev/null @@ -1,19 +0,0 @@ -//! FFI functions, only to be called from C. -//! -//! This module provides the ability for C to free strings that have been -//! allocated in Rust. - -extern crate libc; - -use libc::c_char; -use std::ffi::CString; - -/// This allows strings allocated in Rust to be freed in Rust. Every string -/// sent across the Rust/C FFI boundary should utilize this function for -/// freeing strings allocated in Rust. -#[no_mangle] -pub extern "C" fn free_rust_str(ptr: *mut c_char) { - if !ptr.is_null() { - unsafe { CString::from_raw(ptr) }; - } -} diff --git a/src/rust/c_string/include.am b/src/rust/c_string/include.am deleted file mode 100644 index 8e9229ae6a..0000000000 --- a/src/rust/c_string/include.am +++ /dev/null @@ -1,12 +0,0 @@ -EXTRA_DIST +=\ - src/rust/c_string/Cargo.toml \ - src/rust/c_string/ffi.rs - -src/rust/target/release/@TOR_RUST_C_STRING_STATIC_NAME@: FORCE - ( cd "$(abs_top_srcdir)/src/rust/c_string" ; \ - CARGO_TARGET_DIR="$(abs_top_builddir)/src/rust/target" \ - CARGO_HOME="$(abs_top_builddir)/src/rust" \ - $(CARGO) build --release --quiet $(CARGO_ONLINE) ) - -FORCE: - diff --git a/src/rust/external/external.rs b/src/rust/external/external.rs index f3267949c7..09d80cb2ba 100644 --- a/src/rust/external/external.rs +++ b/src/rust/external/external.rs @@ -16,14 +16,15 @@ pub fn c_tor_version_as_new_as(platform: &str, cutoff: &str) -> bool { Ok(n) => n, Err(_) => return false, }; + let c_cutoff = match CString::new(cutoff) { Ok(n) => n, Err(_) => return false, }; - let result: c_int; - unsafe { - result = tor_version_as_new_as(c_platform.as_ptr(), c_cutoff.as_ptr()); - } + let result: c_int = unsafe { + tor_version_as_new_as(c_platform.as_ptr(), c_cutoff.as_ptr()) + }; + result == 1 } diff --git a/src/rust/include.am b/src/rust/include.am index cba92c28aa..716d46f4cc 100644 --- a/src/rust/include.am +++ b/src/rust/include.am @@ -1,6 +1,5 @@ include src/rust/tor_util/include.am include src/rust/protover/include.am -include src/rust/c_string/include.am EXTRA_DIST +=\ src/rust/Cargo.toml \ diff --git a/src/rust/protover/Cargo.toml b/src/rust/protover/Cargo.toml index a8f794f838..04d2f2ed7d 100644 --- a/src/rust/protover/Cargo.toml +++ b/src/rust/protover/Cargo.toml @@ -15,6 +15,9 @@ path = "../external" [dependencies.tor_util] path = "../tor_util" +[dependencies.tor_allocate] +path = "../tor_allocate" + [lib] name = "protover" path = "lib.rs" diff --git a/src/rust/protover/ffi.rs b/src/rust/protover/ffi.rs index 7365d7cd8f..539b6c0bac 100644 --- a/src/rust/protover/ffi.rs +++ b/src/rust/protover/ffi.rs @@ -8,6 +8,7 @@ use std::ffi::CString; use protover::*; use smartlist::*; +use tor_allocate::allocate_string; /// Translate C enums to Rust Proto enums, using the integer value of the C /// enum to map to its associated Rust enum @@ -32,7 +33,7 @@ fn translate_to_rust(c_proto: uint32_t) -> Result<Proto, &'static str> { /// Provide an interface for C to translate arguments and return types for /// protover::all_supported #[no_mangle] -pub extern "C" fn rust_protover_all_supported( +pub extern "C" fn protover_all_supported( c_relay_version: *const c_char, missing_out: *mut *mut c_char, ) -> c_int { @@ -43,10 +44,7 @@ pub extern "C" fn rust_protover_all_supported( // Require an unsafe block to read the version from a C string. The pointer // is checked above to ensure it is not null. - let c_str: &CStr; - unsafe { - c_str = CStr::from_ptr(c_relay_version); - } + let c_str: &CStr = unsafe { CStr::from_ptr(c_relay_version) }; let relay_version = match c_str.to_str() { Ok(n) => n, @@ -71,7 +69,7 @@ pub extern "C" fn rust_protover_all_supported( /// Provide an interface for C to translate arguments and return types for /// protover::list_supports_protocol #[no_mangle] -pub extern "C" fn rust_protocol_list_supports_protocol( +pub extern "C" fn protocol_list_supports_protocol( c_protocol_list: *const c_char, c_protocol: uint32_t, version: uint32_t, @@ -82,10 +80,7 @@ pub extern "C" fn rust_protocol_list_supports_protocol( // Require an unsafe block to read the version from a C string. The pointer // is checked above to ensure it is not null. - let c_str: &CStr; - unsafe { - c_str = CStr::from_ptr(c_protocol_list); - } + let c_str: &CStr = unsafe { CStr::from_ptr(c_protocol_list) }; let protocol_list = match c_str.to_str() { Ok(n) => n, @@ -106,7 +101,7 @@ pub extern "C" fn rust_protocol_list_supports_protocol( /// Provide an interface for C to translate arguments and return types for /// protover::get_supported_protocols #[no_mangle] -pub extern "C" fn rust_protover_get_supported_protocols() -> *mut c_char { +pub extern "C" fn protover_get_supported_protocols() -> *mut c_char { // Not handling errors when unwrapping as the content is controlled // and is an empty string let empty = CString::new("").unwrap(); @@ -123,38 +118,29 @@ pub extern "C" fn rust_protover_get_supported_protocols() -> *mut c_char { /// Provide an interface for C to translate arguments and return types for /// protover::compute_vote #[no_mangle] -pub extern "C" fn rust_protover_compute_vote( +pub extern "C" fn protover_compute_vote( list: *const Stringlist, threshold: c_int, ) -> *mut c_char { - // Not handling errors when unwrapping as the content is controlled - // and is an empty string - let empty = CString::new("").unwrap(); if list.is_null() { - return empty.into_raw(); + let mut empty = String::new(); + return allocate_string(&mut empty); } // Dereference of raw pointer requires an unsafe block. The pointer is // checked above to ensure it is not null. - let data: Vec<String>; - unsafe { - data = (*list).get_list(); - } + let data: Vec<String> = unsafe { (*list).get_list() }; - let vote = compute_vote(data, threshold); - let c_vote = match CString::new(vote) { - Ok(n) => n, - Err(_) => return empty.into_raw(), - }; + let mut vote = compute_vote(data, threshold); - c_vote.into_raw() + allocate_string(&mut vote) } /// Provide an interface for C to translate arguments and return types for /// protover::is_supported_here #[no_mangle] -pub extern "C" fn rust_protover_is_supported_here( +pub extern "C" fn protover_is_supported_here( c_protocol: uint32_t, version: uint32_t, ) -> c_int { @@ -171,35 +157,27 @@ pub extern "C" fn rust_protover_is_supported_here( /// Provide an interface for C to translate arguments and return types for /// protover::compute_for_old_tor #[no_mangle] -pub extern "C" fn rust_protover_compute_for_old_tor( +pub extern "C" fn protover_compute_for_old_tor( version: *const c_char, ) -> *mut c_char { // Not handling errors when unwrapping as the content is controlled // and is an empty string - let empty = CString::new("").unwrap(); + let mut empty = String::new(); if version.is_null() { - return empty.into_raw(); + return allocate_string(&mut empty); } // Require an unsafe block to read the version from a C string. The pointer // is checked above to ensure it is not null. - let c_str: &CStr; - unsafe { - c_str = CStr::from_ptr(version); - } + let c_str: &CStr = unsafe { CStr::from_ptr(version) }; let version = match c_str.to_str() { Ok(n) => n, - Err(_) => return empty.into_raw(), + Err(_) => return allocate_string(&mut empty), }; - let supported = compute_for_old_tor(&version); + let mut supported = compute_for_old_tor(&version); - let c_supported = match CString::new(supported) { - Ok(n) => n, - Err(_) => return empty.into_raw(), - }; - - c_supported.into_raw() + allocate_string(&mut supported) } diff --git a/src/rust/protover/lib.rs b/src/rust/protover/lib.rs index 89378c7b7e..620191f88d 100644 --- a/src/rust/protover/lib.rs +++ b/src/rust/protover/lib.rs @@ -27,6 +27,7 @@ extern crate libc; extern crate smartlist; extern crate external; +extern crate tor_allocate; mod protover; pub mod ffi; diff --git a/src/rust/protover/protover.rs b/src/rust/protover/protover.rs index 0893362cec..f85d16b73c 100644 --- a/src/rust/protover/protover.rs +++ b/src/rust/protover/protover.rs @@ -364,7 +364,7 @@ fn expand_version_range(range: &str) -> Result<Vec<u32>, &'static str> { "cannot parse protocol range upper bound", ))?; - Ok((lower...higher).collect()) + Ok((lower..=higher).collect()) } /// Checks to see if there is a continuous range of integers, starting at the |