Sha256: fdfd3d5ff971b7f3781579fc10a106724cc8616beb8201caad7ae565d395d910

Contents?: true

Size: 1.77 KB

Versions: 30

Compression:

Stored size: 1.77 KB

Contents

use crate::util::access_sys_fn;
use std::ffi::CString;

/// A domain enables tagging trace data for different modules or libraries in a program. See the
/// [Domain API] documentation for more information.
///
/// [Domain API]:
///     https://www.intel.com/content/www/us/en/develop/documentation/vtune-help/top/api-support/instrumentation-and-tracing-technology-apis/instrumentation-tracing-technology-api-reference/domain-api.html
pub struct Domain(*mut ittapi_sys::__itt_domain);
impl Domain {
    /// Create a new domain. Note that, if the `ittnotify` library is not initialized, this call
    /// will succeed but the domain will be invalid; see discussion TODO.
    ///
    /// ```
    /// # use ittapi::Domain;
    /// let domain = Domain::new("test-domain");
    /// ```
    #[must_use]
    pub fn new(name: &str) -> Self {
        #[cfg(unix)]
        let create_fn = access_sys_fn!(__itt_domain_create_ptr__3_0);
        #[cfg(windows)]
        let create_fn = access_sys_fn!(__itt_domain_createA_ptr__3_0);
        let c_string =
            CString::new(name).expect("unable to create a CString; does it contain a 0 byte?");
        let domain = unsafe { create_fn(c_string.as_ptr()) };
        Self(domain)
    }

    /// Use the `__itt_domain` pointer internally.
    pub(crate) fn as_ptr(&self) -> *const ittapi_sys::__itt_domain {
        self.0 as *const _
    }
}

/// As discussed in the [ITT documentation], the `__itt_domain` structure is accessible by any
/// thread in the process.
///
/// [ITT documentation]:
///     https://www.intel.com/content/www/us/en/develop/documentation/vtune-help/top/api-support/instrumentation-and-tracing-technology-apis/instrumentation-tracing-technology-api-reference/domain-api.html
unsafe impl Sync for Domain {}

Version data entries

30 entries across 30 versions & 1 rubygems

Version Path
wasmtime-29.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-28.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-27.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-26.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-25.0.2 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-25.0.1 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-25.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-24.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-23.0.2 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-22.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-21.0.1 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-20.0.2 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-20.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-18.0.3 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-17.0.1 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-17.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-16.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-15.0.1 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-15.0.0 ./ext/cargo-vendor/ittapi-0.4.0/src/domain.rs
wasmtime-14.0.4 ./ext/cargo-vendor/ittapi-0.3.5/src/domain.rs