1fcdd74aaSJohn Hubbard // SPDX-License-Identifier: GPL-2.0 2fcdd74aaSJohn Hubbard // SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved. 3fcdd74aaSJohn Hubbard 4fcdd74aaSJohn Hubbard use kernel::{ 5fcdd74aaSJohn Hubbard prelude::*, 6fcdd74aaSJohn Hubbard sizes::SizeConstants, // 7fcdd74aaSJohn Hubbard }; 8fcdd74aaSJohn Hubbard 9fcdd74aaSJohn Hubbard use crate::{ 10fcdd74aaSJohn Hubbard driver::Bar0, 11fcdd74aaSJohn Hubbard fb::hal::FbHal, // 12fcdd74aaSJohn Hubbard }; 13fcdd74aaSJohn Hubbard 14fcdd74aaSJohn Hubbard struct Gh100; 15fcdd74aaSJohn Hubbard 16fcdd74aaSJohn Hubbard impl FbHal for Gh100 { 17*99676aedSGary Guo fn read_sysmem_flush_page(&self, bar: Bar0<'_>) -> u64 { 18fcdd74aaSJohn Hubbard super::ga100::read_sysmem_flush_page_ga100(bar) 19fcdd74aaSJohn Hubbard } 20fcdd74aaSJohn Hubbard 21*99676aedSGary Guo fn write_sysmem_flush_page(&self, bar: Bar0<'_>, addr: u64) -> Result { 22fcdd74aaSJohn Hubbard super::ga100::write_sysmem_flush_page_ga100(bar, addr); 23fcdd74aaSJohn Hubbard 24fcdd74aaSJohn Hubbard Ok(()) 25fcdd74aaSJohn Hubbard } 26fcdd74aaSJohn Hubbard 27*99676aedSGary Guo fn supports_display(&self, bar: Bar0<'_>) -> bool { 28fcdd74aaSJohn Hubbard super::ga100::display_enabled_ga100(bar) 29fcdd74aaSJohn Hubbard } 30fcdd74aaSJohn Hubbard 31*99676aedSGary Guo fn vidmem_size(&self, bar: Bar0<'_>) -> u64 { 32fcdd74aaSJohn Hubbard super::ga102::vidmem_size_ga102(bar) 33fcdd74aaSJohn Hubbard } 34fcdd74aaSJohn Hubbard 35fcdd74aaSJohn Hubbard fn pmu_reserved_size(&self) -> u32 { 36fcdd74aaSJohn Hubbard super::tu102::pmu_reserved_size_tu102() 37fcdd74aaSJohn Hubbard } 38fcdd74aaSJohn Hubbard 39fcdd74aaSJohn Hubbard fn non_wpr_heap_size(&self) -> u32 { 40fcdd74aaSJohn Hubbard // Non-WPR heap for Hopper (see Open RM: kgspCalculateFbLayout_GH100). 41fcdd74aaSJohn Hubbard u32::SZ_2M 42fcdd74aaSJohn Hubbard } 43fcdd74aaSJohn Hubbard 44fcdd74aaSJohn Hubbard fn frts_size(&self) -> u64 { 45fcdd74aaSJohn Hubbard super::tu102::frts_size_tu102() 46fcdd74aaSJohn Hubbard } 47fcdd74aaSJohn Hubbard } 48fcdd74aaSJohn Hubbard 49fcdd74aaSJohn Hubbard const GH100: Gh100 = Gh100; 50fcdd74aaSJohn Hubbard pub(super) const GH100_HAL: &dyn FbHal = &GH100; 51