/*
 * Copyright (c) 2018-2020 Atmosphère-NX
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
#pragma once
#include 
namespace ams::pkg1 {
    enum BootloaderState {
        BootloaderState_Start            = 0,
        BootloaderState_LoadedBootConfig = 1,
        BootloaderState_InitializedDram  = 2,
        BootloaderState_LoadedPackage2   = 3,
        BootloaderState_Done             = 4,
    };
    enum SecureMonitorState {
        SecureMonitorState_Start       = 0,
        SecureMonitorState_Initialized = 1,
    };
    struct BctParameters {
        u32 bootloader_version;
        u32 bootloader_start_block;
        u32 bootloader_start_page;
        u32 bootloader_attributes;
    };
    static_assert(util::is_pod::value && sizeof(BctParameters) == 0x10);
    struct SecureMonitorParameters {
        u32 bootloader_start_time;
        u32 bootloader_end_time;
        u32 secmon_start_time;
        u32 secmon_end_time;
        BctParameters bct_params;
        u32 deprecated_boot_reason_value;
        u8  deprecated_boot_reason_state;
        u8 reserved[0xD3];
        u32 bootloader_state;
        u32 secmon_state;
        u8 reserved2[0x100];
    };
    static_assert(util::is_pod::value);
    static_assert(sizeof(SecureMonitorParameters) == 0x200);
    static_assert(offsetof(SecureMonitorParameters, bct_params)       == 0x10);
    static_assert(offsetof(SecureMonitorParameters, bootloader_state) == 0xF8);
    static_assert(offsetof(SecureMonitorParameters, secmon_state) == 0xFC);
    enum BootloaderAttribute {
        BootloaderAttribute_None         = (0u << 0),
        BootloaderAttribute_RecoveryBoot = (1u << 0),
        BootloaderAttribute_RestrictedSmcShift = 1,
        BootloaderAttribute_RestrictedSmcMask  = (0xFu << BootloaderAttribute_RestrictedSmcShift),
    };
}