summaryrefslogtreecommitdiff
path: root/drivers/gpu
diff options
context:
space:
mode:
authorAlexandre Courbot <acourbot@nvidia.com>2025-07-18 10:26:19 +0300
committerAlexandre Courbot <acourbot@nvidia.com>2025-08-15 06:02:56 +0300
commitc6bc4225279d9a6eff8aafc94347183b2babc52a (patch)
tree0dd8dcb2168696358795333f32aa1355ccdbd37a /drivers/gpu
parentfcdce54d645a0779892faaed1209105350e15d92 (diff)
downloadlinux-c6bc4225279d9a6eff8aafc94347183b2babc52a.tar.xz
gpu: nova-core: register: use #[inline(always)] for all methods
These methods should always be inlined, so use the strongest compiler hint that exists to maximize the chance they will indeed be. Reviewed-by: Daniel Almeida <daniel.almeida@collabora.com> Reviewed-by: Lyude Paul <lyude@redhat.com> Link: https://lore.kernel.org/r/20250718-nova-regs-v2-14-7b6a762aa1cd@nvidia.com Signed-off-by: Alexandre Courbot <acourbot@nvidia.com>
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/nova-core/regs/macros.rs16
1 files changed, 8 insertions, 8 deletions
diff --git a/drivers/gpu/nova-core/regs/macros.rs b/drivers/gpu/nova-core/regs/macros.rs
index 432af02b3378..200fbe847571 100644
--- a/drivers/gpu/nova-core/regs/macros.rs
+++ b/drivers/gpu/nova-core/regs/macros.rs
@@ -280,7 +280,7 @@ macro_rules! register {
#[doc="Returns the value of this field:"]
#[doc=$comment]
)?
- #[inline]
+ #[inline(always)]
pub(crate) fn $field(self) -> $res_type {
::kernel::macros::paste!(
const MASK: u32 = $name::[<$field:upper _MASK>];
@@ -296,7 +296,7 @@ macro_rules! register {
#[doc="Sets the value of this field:"]
#[doc=$comment]
)?
- #[inline]
+ #[inline(always)]
pub(crate) fn [<set_ $field>](mut self, value: $to_type) -> Self {
const MASK: u32 = $name::[<$field:upper _MASK>];
const SHIFT: u32 = $name::[<$field:upper _SHIFT>];
@@ -348,7 +348,7 @@ macro_rules! register {
pub(crate) const OFFSET: usize = $offset;
/// Read the register from its address in `io`.
- #[inline]
+ #[inline(always)]
pub(crate) fn read<const SIZE: usize, T>(io: &T) -> Self where
T: ::core::ops::Deref<Target = ::kernel::io::Io<SIZE>>,
{
@@ -356,7 +356,7 @@ macro_rules! register {
}
/// Write the value contained in `self` to the register address in `io`.
- #[inline]
+ #[inline(always)]
pub(crate) fn write<const SIZE: usize, T>(self, io: &T) where
T: ::core::ops::Deref<Target = ::kernel::io::Io<SIZE>>,
{
@@ -365,7 +365,7 @@ macro_rules! register {
/// Read the register from its address in `io` and run `f` on its value to obtain a new
/// value to write back.
- #[inline]
+ #[inline(always)]
pub(crate) fn alter<const SIZE: usize, T, F>(
io: &T,
f: F,
@@ -385,7 +385,7 @@ macro_rules! register {
impl $name {
pub(crate) const OFFSET: usize = $offset;
- #[inline]
+ #[inline(always)]
pub(crate) fn read<const SIZE: usize, T>(
io: &T,
base: usize,
@@ -395,7 +395,7 @@ macro_rules! register {
Self(io.read32(base + $offset))
}
- #[inline]
+ #[inline(always)]
pub(crate) fn write<const SIZE: usize, T>(
self,
io: &T,
@@ -406,7 +406,7 @@ macro_rules! register {
io.write32(self.0, base + $offset)
}
- #[inline]
+ #[inline(always)]
pub(crate) fn alter<const SIZE: usize, T, F>(
io: &T,
base: usize,