/* * SPDX-FileCopyrightText: Copyright (c) 2021-2022 NVIDIA CORPORATION & AFFILIATES. All rights reserved. * SPDX-License-Identifier: MIT * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. */ #pragma once #include // // This file was generated with FINN, an NVIDIA coding tool. // Source file: ctrl/ctrl0090.finn // // NV0080_CTRL_GR_TPC_PARTITION_MODE #include "ctrl/ctrl0080/ctrl0080gr.h" /*! * This file defines control call interfaces for the KernelGraphicsContext * objects Each channel running within a TSG contains a HW context represented * by the above object(s). GR permits multiple channels to share a single * context, and these APIs operate upon that context and may be issued from any * TSG, channel, or context handle. */ /* * NV0090_CTRL_CMD_NULL * * @brief This command does nothing. * * @return NV_OK */ #define NV0090_CTRL_CMD_NULL (0x900100) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x0" */ /*! * NV0090_CTRL_CMD_SET_TPC_PARTITION_MODE * NV0090_CTRL_CMD_GET_TPC_PARTITION_MODE * * @brief sets or gets the TPC partition mode for this context * * @param[in/out] mode Partitioning mode enum value * @param[in/out] bEnableAllTpcs Flag to enable all TPCs by default * * @return NV_OK on success * NV_ERR_OBJECT_NOT_FOUND if issued on non-GR ctx */ typedef struct NV0090_CTRL_TPC_PARTITION_MODE_PARAMS { NV0080_CTRL_GR_TPC_PARTITION_MODE mode; NvBool bEnableAllTpcs; } NV0090_CTRL_TPC_PARTITION_MODE_PARAMS; #define NV0090_CTRL_CMD_SET_TPC_PARTITION_MODE (0x900101) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x1" */ #define NV0090_CTRL_CMD_INTERNAL_SET_TPC_PARTITION_MODE (0x900102) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x2" */ #define NV0090_CTRL_CMD_GET_TPC_PARTITION_MODE (0x900103) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x3" */ #define NV0090_CTRL_CMD_INTERNAL_GET_TPC_PARTITION_MODE (0x900104) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x4" */ /** * NV0090_CTRL_GET_MMU_DEBUG_MODE * * @brief retrieve the current MMU debug mode for the grctx according to the HW * * @param[out] bMode current MMU debug mode */ typedef struct NV0090_CTRL_GET_MMU_DEBUG_MODE_PARAMS { NvBool bMode; } NV0090_CTRL_GET_MMU_DEBUG_MODE_PARAMS; #define NV0090_CTRL_CMD_GET_MMU_DEBUG_MODE (0x900105) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x5" */ #define NV0090_CTRL_CMD_INTERNAL_GET_MMU_DEBUG_MODE (0x900106) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x6" */ /** * NV0090_CTRL_PROGRAM_VIDEMEM_PROMOTE * * @brief This control call is used to set the promotion policies to vidmem through * per-TSG config * * If the request is for less bytes than the current PROMOTE setting, then * the request is promoted. For example if the request size is for 32B and * 64B promotion is turned on for that unit, then the request to FB will be * for all the bytes to the 64B aligned address. * * @param[in] l1 * An input parameter which represents VIDMEM_L1_PROMOTE[17:16]. * @param[in] t1 * An input parameter which represents VIDMEM_T1_PROMOTE[19:18]. * * @return NV_OK on success, or * NV_ERR_INVALID_ARGUMENT or * NV_ERR_INVALID_STATE */ typedef enum NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_SIZE { NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_SIZE_NONE = 0, NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_SIZE_64B = 1, NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_SIZE_128B = 2, } NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_SIZE; typedef struct NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_FIELD { NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_SIZE size; } NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_FIELD; #define NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_PARAMS_MESSAGE_ID (0x9U) typedef struct NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_PARAMS { NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_FIELD l1; NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_FIELD t1; } NV0090_CTRL_PROGRAM_VIDMEM_PROMOTE_PARAMS; #define NV0090_CTRL_CMD_PROGRAM_VIDMEM_PROMOTE (0x900107) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x7" */ #define NV0090_CTRL_CMD_INTERNAL_PROGRAM_VIDMEM_PROMOTE (0x900108) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0x8" */ /* * NV0090_CTRL_SET_LG_SECTOR_PROMOTION * * This command toggles the type of LG sector promotion used by writing to NV_PTPC_PRI_SM_L1TAG_CTRL_SECTOR_PROMOTE_GLOBAL and NV_PTPC_PRI_SM_L1TAG_CTRL2_SECTOR_PROMOTE_GLOBAL_EXT * * promoType[IN] * This parameter specifies what kind of sector promotion to perform * */ typedef enum NV0090_CTRL_SET_LG_SECTOR_PROMOTION_TYPE { NV0090_CTRL_SET_LG_SECTOR_PROMOTION_NONE = 0, NV0090_CTRL_SET_LG_SECTOR_PROMOTION_64B = 1, NV0090_CTRL_SET_LG_SECTOR_PROMOTION_128B = 2, } NV0090_CTRL_SET_LG_SECTOR_PROMOTION_TYPE; #define NV0090_CTRL_SET_LG_SECTOR_PROMOTION_PARAMS_MESSAGE_ID (0xAU) typedef struct NV0090_CTRL_SET_LG_SECTOR_PROMOTION_PARAMS { NV0090_CTRL_SET_LG_SECTOR_PROMOTION_TYPE promoType; } NV0090_CTRL_SET_LG_SECTOR_PROMOTION_PARAMS; #define NV0090_CTRL_CMD_SET_LG_SECTOR_PROMOTION (0x90010bU) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0xB" */ #define NV0090_CTRL_CMD_INTERNAL_SET_LG_SECTOR_PROMOTION (0x90010cU) /* finn: Evaluated from "(FINN_NV0090_KERNEL_GRAPHICS_CONTEXT_INTERFACE_ID << 8) | 0xC" */