diff options
Diffstat (limited to 'rust')
| -rw-r--r-- | rust/kernel/cpufreq.rs | 2 | ||||
| -rw-r--r-- | rust/kernel/cpumask.rs | 5 | ||||
| -rw-r--r-- | rust/kernel/device.rs | 5 | ||||
| -rw-r--r-- | rust/kernel/lib.rs | 15 | ||||
| -rw-r--r-- | rust/kernel/mm/virt.rs | 1 | ||||
| -rw-r--r-- | rust/kernel/opp.rs | 29 | 
6 files changed, 30 insertions, 27 deletions
| diff --git a/rust/kernel/cpufreq.rs b/rust/kernel/cpufreq.rs index afc15e72a7c3..eea57ba95f24 100644 --- a/rust/kernel/cpufreq.rs +++ b/rust/kernel/cpufreq.rs @@ -543,7 +543,7 @@ impl Policy {      pub fn cpus(&mut self) -> &mut cpumask::Cpumask {          // SAFETY: The pointer to `cpus` is valid for writing and remains valid for the lifetime of          // the returned reference. -        unsafe { cpumask::CpumaskVar::as_mut_ref(&mut self.as_mut_ref().cpus) } +        unsafe { cpumask::CpumaskVar::from_raw_mut(&mut self.as_mut_ref().cpus) }      }      /// Sets clock for the [`Policy`]. diff --git a/rust/kernel/cpumask.rs b/rust/kernel/cpumask.rs index 3fcbff438670..c1d17826ae7b 100644 --- a/rust/kernel/cpumask.rs +++ b/rust/kernel/cpumask.rs @@ -212,6 +212,7 @@ impl Cpumask {  /// }  /// assert_eq!(mask2.weight(), count);  /// ``` +#[repr(transparent)]  pub struct CpumaskVar {      #[cfg(CONFIG_CPUMASK_OFFSTACK)]      ptr: NonNull<Cpumask>, @@ -270,7 +271,7 @@ impl CpumaskVar {      ///      /// The caller must ensure that `ptr` is valid for writing and remains valid for the lifetime      /// of the returned reference. -    pub unsafe fn as_mut_ref<'a>(ptr: *mut bindings::cpumask_var_t) -> &'a mut Self { +    pub unsafe fn from_raw_mut<'a>(ptr: *mut bindings::cpumask_var_t) -> &'a mut Self {          // SAFETY: Guaranteed by the safety requirements of the function.          //          // INVARIANT: The caller ensures that `ptr` is valid for writing and remains valid for the @@ -284,7 +285,7 @@ impl CpumaskVar {      ///      /// The caller must ensure that `ptr` is valid for reading and remains valid for the lifetime      /// of the returned reference. -    pub unsafe fn as_ref<'a>(ptr: *const bindings::cpumask_var_t) -> &'a Self { +    pub unsafe fn from_raw<'a>(ptr: *const bindings::cpumask_var_t) -> &'a Self {          // SAFETY: Guaranteed by the safety requirements of the function.          //          // INVARIANT: The caller ensures that `ptr` is valid for reading and remains valid for the diff --git a/rust/kernel/device.rs b/rust/kernel/device.rs index 5902b3714a16..a1db49eb159a 100644 --- a/rust/kernel/device.rs +++ b/rust/kernel/device.rs @@ -138,7 +138,9 @@ pub mod property;  /// }  /// ```  /// -/// An example for a class device implementation is [`drm::Device`]. +/// An example for a class device implementation is +#[cfg_attr(CONFIG_DRM = "y", doc = "[`drm::Device`](kernel::drm::Device).")] +#[cfg_attr(not(CONFIG_DRM = "y"), doc = "`drm::Device`.")]  ///  /// # Invariants  /// @@ -151,7 +153,6 @@ pub mod property;  /// dropped from any thread.  ///  /// [`AlwaysRefCounted`]: kernel::types::AlwaysRefCounted -/// [`drm::Device`]: kernel::drm::Device  /// [`impl_device_context_deref`]: kernel::impl_device_context_deref  /// [`pci::Device`]: kernel::pci::Device  /// [`platform::Device`]: kernel::platform::Device diff --git a/rust/kernel/lib.rs b/rust/kernel/lib.rs index ed53169e795c..fef97f2a5098 100644 --- a/rust/kernel/lib.rs +++ b/rust/kernel/lib.rs @@ -296,7 +296,7 @@ macro_rules! asm {  /// Gets the C string file name of a [`Location`].  /// -/// If `file_with_nul()` is not available, returns a string that warns about it. +/// If `Location::file_as_c_str()` is not available, returns a string that warns about it.  ///  /// [`Location`]: core::panic::Location  /// @@ -310,8 +310,8 @@ macro_rules! asm {  ///     let caller = core::panic::Location::caller();  ///  ///     // Output: -///     // - A path like "rust/kernel/example.rs" if file_with_nul() is available. -///     // - "<Location::file_with_nul() not supported>" otherwise. +///     // - A path like "rust/kernel/example.rs" if `file_as_c_str()` is available. +///     // - "<Location::file_as_c_str() not supported>" otherwise.  ///     let caller_file = file_from_location(caller);  ///  ///     // Prints out the message with caller's file name. @@ -326,7 +326,12 @@ macro_rules! asm {  /// ```  #[inline]  pub fn file_from_location<'a>(loc: &'a core::panic::Location<'a>) -> &'a core::ffi::CStr { -    #[cfg(CONFIG_RUSTC_HAS_FILE_WITH_NUL)] +    #[cfg(CONFIG_RUSTC_HAS_FILE_AS_C_STR)] +    { +        loc.file_as_c_str() +    } + +    #[cfg(all(CONFIG_RUSTC_HAS_FILE_WITH_NUL, not(CONFIG_RUSTC_HAS_FILE_AS_C_STR)))]      {          loc.file_with_nul()      } @@ -334,6 +339,6 @@ pub fn file_from_location<'a>(loc: &'a core::panic::Location<'a>) -> &'a core::f      #[cfg(not(CONFIG_RUSTC_HAS_FILE_WITH_NUL))]      {          let _ = loc; -        c"<Location::file_with_nul() not supported>" +        c"<Location::file_as_c_str() not supported>"      }  } diff --git a/rust/kernel/mm/virt.rs b/rust/kernel/mm/virt.rs index 6086ca981b06..a1bfa4e19293 100644 --- a/rust/kernel/mm/virt.rs +++ b/rust/kernel/mm/virt.rs @@ -209,6 +209,7 @@ impl VmaMixedMap {  ///  /// For the duration of 'a, the referenced vma must be undergoing initialization in an  /// `f_ops->mmap()` hook. +#[repr(transparent)]  pub struct VmaNew {      vma: VmaRef,  } diff --git a/rust/kernel/opp.rs b/rust/kernel/opp.rs index 08126035d2c6..2c763fa9276d 100644 --- a/rust/kernel/opp.rs +++ b/rust/kernel/opp.rs @@ -12,11 +12,12 @@ use crate::{      clk::Hertz,      cpumask::{Cpumask, CpumaskVar},      device::Device, -    error::{code::*, from_err_ptr, from_result, to_result, Error, Result, VTABLE_DEFAULT_ERROR}, +    error::{code::*, from_err_ptr, from_result, to_result, Result, VTABLE_DEFAULT_ERROR},      ffi::c_ulong,      prelude::*,      str::CString, -    types::{ARef, AlwaysRefCounted, Opaque}, +    sync::aref::{ARef, AlwaysRefCounted}, +    types::Opaque,  };  #[cfg(CONFIG_CPU_FREQ)] @@ -162,7 +163,7 @@ impl From<MicroWatt> for c_ulong {  /// use kernel::device::Device;  /// use kernel::error::Result;  /// use kernel::opp::{Data, MicroVolt, Token}; -/// use kernel::types::ARef; +/// use kernel::sync::aref::ARef;  ///  /// fn create_opp(dev: &ARef<Device>, freq: Hertz, volt: MicroVolt, level: u32) -> Result<Token> {  ///     let data = Data::new(freq, volt, level, false); @@ -211,7 +212,7 @@ impl Drop for Token {  /// use kernel::device::Device;  /// use kernel::error::Result;  /// use kernel::opp::{Data, MicroVolt, Token}; -/// use kernel::types::ARef; +/// use kernel::sync::aref::ARef;  ///  /// fn create_opp(dev: &ARef<Device>, freq: Hertz, volt: MicroVolt, level: u32) -> Result<Token> {  ///     let data = Data::new(freq, volt, level, false); @@ -262,7 +263,7 @@ impl Data {  /// use kernel::clk::Hertz;  /// use kernel::error::Result;  /// use kernel::opp::{OPP, SearchType, Table}; -/// use kernel::types::ARef; +/// use kernel::sync::aref::ARef;  ///  /// fn find_opp(table: &Table, freq: Hertz) -> Result<ARef<OPP>> {  ///     let opp = table.opp_from_freq(freq, Some(true), None, SearchType::Exact)?; @@ -335,7 +336,7 @@ impl Drop for ConfigToken {  /// use kernel::error::Result;  /// use kernel::opp::{Config, ConfigOps, ConfigToken};  /// use kernel::str::CString; -/// use kernel::types::ARef; +/// use kernel::sync::aref::ARef;  /// use kernel::macros::vtable;  ///  /// #[derive(Default)] @@ -500,11 +501,8 @@ impl<T: ConfigOps + Default> Config<T> {          // requirements. The OPP core guarantees not to access fields of [`Config`] after this call          // and so we don't need to save a copy of them for future use.          let ret = unsafe { bindings::dev_pm_opp_set_config(dev.as_raw(), &mut config) }; -        if ret < 0 { -            Err(Error::from_errno(ret)) -        } else { -            Ok(ConfigToken(ret)) -        } + +        to_result(ret).map(|()| ConfigToken(ret))      }      /// Config's clk callback. @@ -581,7 +579,7 @@ impl<T: ConfigOps + Default> Config<T> {  /// use kernel::device::Device;  /// use kernel::error::Result;  /// use kernel::opp::Table; -/// use kernel::types::ARef; +/// use kernel::sync::aref::ARef;  ///  /// fn get_table(dev: &ARef<Device>, mask: &mut Cpumask, freq: Hertz) -> Result<Table> {  ///     let mut opp_table = Table::from_of_cpumask(dev, mask)?; @@ -713,11 +711,8 @@ impl Table {          // SAFETY: The requirements are satisfied by the existence of [`Device`] and its safety          // requirements.          let ret = unsafe { bindings::dev_pm_opp_get_opp_count(self.dev.as_raw()) }; -        if ret < 0 { -            Err(Error::from_errno(ret)) -        } else { -            Ok(ret as u32) -        } + +        to_result(ret).map(|()| ret as u32)      }      /// Returns max clock latency (in nanoseconds) of the [`OPP`]s in the [`Table`]. | 
