// SPDX-License-Identifier: GPL-2.0 struct Ga100; use kernel::prelude::*; use crate::driver::Bar0; use crate::fb::hal::FbHal; use crate::regs; use super::tu102::FLUSH_SYSMEM_ADDR_SHIFT; pub(super) fn read_sysmem_flush_page_ga100(bar: &Bar0) -> u64 { u64::from(regs::NV_PFB_NISO_FLUSH_SYSMEM_ADDR::read(bar).adr_39_08()) << FLUSH_SYSMEM_ADDR_SHIFT | u64::from(regs::NV_PFB_NISO_FLUSH_SYSMEM_ADDR_HI::read(bar).adr_63_40()) << FLUSH_SYSMEM_ADDR_SHIFT_HI } pub(super) fn write_sysmem_flush_page_ga100(bar: &Bar0, addr: u64) { regs::NV_PFB_NISO_FLUSH_SYSMEM_ADDR_HI::default() .set_adr_63_40((addr >> FLUSH_SYSMEM_ADDR_SHIFT_HI) as u32) .write(bar); regs::NV_PFB_NISO_FLUSH_SYSMEM_ADDR::default() .set_adr_39_08((addr >> FLUSH_SYSMEM_ADDR_SHIFT) as u32) .write(bar); } pub(super) fn display_enabled_ga100(bar: &Bar0) -> bool { !regs::ga100::NV_FUSE_STATUS_OPT_DISPLAY::read(bar).display_disabled() } /// Shift applied to the sysmem address before it is written into /// `NV_PFB_NISO_FLUSH_SYSMEM_ADDR_HI`, const FLUSH_SYSMEM_ADDR_SHIFT_HI: u32 = 40; impl FbHal for Ga100 { fn read_sysmem_flush_page(&self, bar: &Bar0) -> u64 { read_sysmem_flush_page_ga100(bar) } fn write_sysmem_flush_page(&self, bar: &Bar0, addr: u64) -> Result { write_sysmem_flush_page_ga100(bar, addr); Ok(()) } fn supports_display(&self, bar: &Bar0) -> bool { display_enabled_ga100(bar) } fn vidmem_size(&self, bar: &Bar0) -> u64 { super::tu102::vidmem_size_gp102(bar) } } const GA100: Ga100 = Ga100; pub(super) const GA100_HAL: &dyn FbHal = &GA100;