mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 06:44:00 -04:00
Convert all FUSE registers to use the kernel's register macro and update the code accordingly. Reviewed-by: Eliot Courtney <ecourtney@nvidia.com> Reviewed-by: Gary Guo <gary@garyguo.net> Acked-by: Danilo Krummrich <dakr@kernel.org> Link: https://patch.msgid.link/20260325-b4-nova-register-v4-6-bdf172f0f6ca@nvidia.com Signed-off-by: Alexandre Courbot <acourbot@nvidia.com>
63 lines
1.6 KiB
Rust
63 lines
1.6 KiB
Rust
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
use kernel::{
|
|
io::Io,
|
|
prelude::*, //
|
|
};
|
|
|
|
use crate::{
|
|
driver::Bar0,
|
|
fb::hal::FbHal,
|
|
regs, //
|
|
};
|
|
|
|
/// Shift applied to the sysmem address before it is written into `NV_PFB_NISO_FLUSH_SYSMEM_ADDR`,
|
|
/// to be used by HALs.
|
|
pub(super) const FLUSH_SYSMEM_ADDR_SHIFT: u32 = 8;
|
|
|
|
pub(super) fn read_sysmem_flush_page_gm107(bar: &Bar0) -> u64 {
|
|
u64::from(bar.read(regs::NV_PFB_NISO_FLUSH_SYSMEM_ADDR).adr_39_08()) << FLUSH_SYSMEM_ADDR_SHIFT
|
|
}
|
|
|
|
pub(super) fn write_sysmem_flush_page_gm107(bar: &Bar0, addr: u64) -> Result {
|
|
// Check that the address doesn't overflow the receiving 32-bit register.
|
|
u32::try_from(addr >> FLUSH_SYSMEM_ADDR_SHIFT)
|
|
.map_err(|_| EINVAL)
|
|
.map(|addr| {
|
|
bar.write_reg(regs::NV_PFB_NISO_FLUSH_SYSMEM_ADDR::zeroed().with_adr_39_08(addr))
|
|
})
|
|
}
|
|
|
|
pub(super) fn display_enabled_gm107(bar: &Bar0) -> bool {
|
|
!bar.read(regs::gm107::NV_FUSE_STATUS_OPT_DISPLAY)
|
|
.display_disabled()
|
|
}
|
|
|
|
pub(super) fn vidmem_size_gp102(bar: &Bar0) -> u64 {
|
|
bar.read(regs::NV_PFB_PRI_MMU_LOCAL_MEMORY_RANGE)
|
|
.usable_fb_size()
|
|
}
|
|
|
|
struct Tu102;
|
|
|
|
impl FbHal for Tu102 {
|
|
fn read_sysmem_flush_page(&self, bar: &Bar0) -> u64 {
|
|
read_sysmem_flush_page_gm107(bar)
|
|
}
|
|
|
|
fn write_sysmem_flush_page(&self, bar: &Bar0, addr: u64) -> Result {
|
|
write_sysmem_flush_page_gm107(bar, addr)
|
|
}
|
|
|
|
fn supports_display(&self, bar: &Bar0) -> bool {
|
|
display_enabled_gm107(bar)
|
|
}
|
|
|
|
fn vidmem_size(&self, bar: &Bar0) -> u64 {
|
|
vidmem_size_gp102(bar)
|
|
}
|
|
}
|
|
|
|
const TU102: Tu102 = Tu102;
|
|
pub(super) const TU102_HAL: &dyn FbHal = &TU102;
|