xref: /linux/drivers/gpu/nova-core/fb/hal/gh100.rs (revision 9611c0ce215a66770ccbe5c126bf57ba8c31bcad)
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