summaryrefslogtreecommitdiff
path: root/drivers/gpu/nova-core/fsp/hal/gh100.rs
blob: 291acaf2845a7e9e6ad784d420f7ed5d0010e472 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// SPDX-License-Identifier: GPL-2.0
// SPDX-FileCopyrightText: Copyright (c) 2026 NVIDIA CORPORATION & AFFILIATES. All rights reserved.

use kernel::io::Io;

use crate::{
    driver::Bar0,
    fsp::hal::FspHal,
    regs, //
};

struct Gh100;

/// Reads the FSP secure boot status from the Hopper/GB10x thermal scratch register.
pub(super) fn fsp_boot_status_gh100(bar: Bar0<'_>) -> u32 {
    bar.read(regs::gh100::NV_THERM_I2CS_SCRATCH_FSP_BOOT_COMPLETE)
        .fsp_boot_complete()
        .into()
}

impl FspHal for Gh100 {
    fn fsp_boot_status(&self, bar: Bar0<'_>) -> u32 {
        fsp_boot_status_gh100(bar)
    }

    fn cot_version(&self) -> u16 {
        1
    }
}

const GH100: Gh100 = Gh100;
pub(super) const GH100_HAL: &dyn FspHal = &GH100;