190eb1077SAndy Ritger /*
2*b5bf85a8SAndy Ritger  * SPDX-FileCopyrightText: Copyright (c) 2023 NVIDIA CORPORATION & AFFILIATES. All rights reserved.
390eb1077SAndy Ritger  * SPDX-License-Identifier: MIT
490eb1077SAndy Ritger  *
590eb1077SAndy Ritger  * Permission is hereby granted, free of charge, to any person obtaining a
690eb1077SAndy Ritger  * copy of this software and associated documentation files (the "Software"),
790eb1077SAndy Ritger  * to deal in the Software without restriction, including without limitation
890eb1077SAndy Ritger  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
990eb1077SAndy Ritger  * and/or sell copies of the Software, and to permit persons to whom the
1090eb1077SAndy Ritger  * Software is furnished to do so, subject to the following conditions:
1190eb1077SAndy Ritger  *
1290eb1077SAndy Ritger  * The above copyright notice and this permission notice shall be included in
1390eb1077SAndy Ritger  * all copies or substantial portions of the Software.
1490eb1077SAndy Ritger  *
1590eb1077SAndy Ritger  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
1690eb1077SAndy Ritger  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
1790eb1077SAndy Ritger  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
1890eb1077SAndy Ritger  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
1990eb1077SAndy Ritger  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
2090eb1077SAndy Ritger  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
2190eb1077SAndy Ritger  * DEALINGS IN THE SOFTWARE.
2290eb1077SAndy Ritger  */
2390eb1077SAndy Ritger 
2490eb1077SAndy Ritger /***************************************************************************\
2590eb1077SAndy Ritger  *                                                                          *
2690eb1077SAndy Ritger  *      Kernel Ccu Api Object Module                                        *
2790eb1077SAndy Ritger  *                                                                          *
2890eb1077SAndy Ritger  \**************************************************************************/
2990eb1077SAndy Ritger 
3090eb1077SAndy Ritger #include "gpu/gpu.h"
3190eb1077SAndy Ritger #include "gpu/ccu/kernel_ccu_api.h"
3290eb1077SAndy Ritger #include "gpu/ccu/kernel_ccu.h"
3390eb1077SAndy Ritger #include "rmapi/client.h"
3490eb1077SAndy Ritger #include "gpu/mig_mgr/kernel_mig_manager.h"
3590eb1077SAndy Ritger 
3690eb1077SAndy Ritger NV_STATUS
kccuapiConstruct_IMPL(KernelCcuApi * pKernelCcuApi,CALL_CONTEXT * pCallContext,RS_RES_ALLOC_PARAMS_INTERNAL * pParams)3790eb1077SAndy Ritger kccuapiConstruct_IMPL
3890eb1077SAndy Ritger (
3990eb1077SAndy Ritger     KernelCcuApi                 *pKernelCcuApi,
4090eb1077SAndy Ritger     CALL_CONTEXT                 *pCallContext,
4190eb1077SAndy Ritger     RS_RES_ALLOC_PARAMS_INTERNAL *pParams
4290eb1077SAndy Ritger )
4390eb1077SAndy Ritger {
4490eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: Construct\n");
4590eb1077SAndy Ritger 
4690eb1077SAndy Ritger     return NV_OK;
4790eb1077SAndy Ritger }
4890eb1077SAndy Ritger 
4990eb1077SAndy Ritger void
kccuapiDestruct_IMPL(KernelCcuApi * pKernelCcuApi)5090eb1077SAndy Ritger kccuapiDestruct_IMPL
5190eb1077SAndy Ritger (
5290eb1077SAndy Ritger     KernelCcuApi *pKernelCcuApi
5390eb1077SAndy Ritger )
5490eb1077SAndy Ritger {
5590eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: Destruct\n");
5690eb1077SAndy Ritger     return;
5790eb1077SAndy Ritger }
5890eb1077SAndy Ritger 
5990eb1077SAndy Ritger static NV_STATUS
_kccuapiMemdescGet(KernelCcuApi * pKernelCcuApi,RmClient * pClient,Device * pDevice,MEMORY_DESCRIPTOR ** pMemDesc)6090eb1077SAndy Ritger _kccuapiMemdescGet
6190eb1077SAndy Ritger (
6290eb1077SAndy Ritger     KernelCcuApi      *pKernelCcuApi,
6390eb1077SAndy Ritger     RmClient          *pClient,
64*b5bf85a8SAndy Ritger     Device            *pDevice,
6590eb1077SAndy Ritger     MEMORY_DESCRIPTOR **pMemDesc
6690eb1077SAndy Ritger )
6790eb1077SAndy Ritger {
6890eb1077SAndy Ritger     MIG_INSTANCE_REF ref;
6990eb1077SAndy Ritger     NV_STATUS status      = NV_OK;
7090eb1077SAndy Ritger     OBJGPU    *pGpu       = GPU_RES_GET_GPU(pKernelCcuApi);
7190eb1077SAndy Ritger     KernelCcu *pKernelCcu = GPU_GET_KERNEL_CCU(pGpu);
7290eb1077SAndy Ritger     KernelMIGManager *pKernelMIGManager = GPU_GET_KERNEL_MIG_MANAGER(pGpu);
7390eb1077SAndy Ritger 
7490eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: Get memdesc info\n");
7590eb1077SAndy Ritger 
7690eb1077SAndy Ritger     if (pKernelCcu == NULL)
7790eb1077SAndy Ritger     {
7890eb1077SAndy Ritger         return NV_ERR_INVALID_OBJECT;
7990eb1077SAndy Ritger     }
8090eb1077SAndy Ritger 
8190eb1077SAndy Ritger     if (!IS_MIG_ENABLED(pGpu))
8290eb1077SAndy Ritger     {
8390eb1077SAndy Ritger         return kccuMemDescGetForShrBufId(pGpu, pKernelCcu, CCU_DEV_SHRBUF_ID, pMemDesc);
8490eb1077SAndy Ritger     }
8590eb1077SAndy Ritger 
8690eb1077SAndy Ritger     // In case of MIG
87*b5bf85a8SAndy Ritger     status = kmigmgrGetInstanceRefFromDevice(pGpu, pKernelMIGManager, pDevice, &ref);
8890eb1077SAndy Ritger     if (status != NV_OK)
8990eb1077SAndy Ritger     {
9090eb1077SAndy Ritger         // Check if client is allowed to query for device counters
9190eb1077SAndy Ritger         if (rmclientIsCapable(pClient, NV_RM_CAP_SYS_SMC_MONITOR))
9290eb1077SAndy Ritger         {
9390eb1077SAndy Ritger             return kccuMemDescGetForShrBufId(pGpu, pKernelCcu, CCU_DEV_SHRBUF_ID, pMemDesc);
9490eb1077SAndy Ritger         }
9590eb1077SAndy Ritger 
9690eb1077SAndy Ritger         // Permission denied
9790eb1077SAndy Ritger         return NV_ERR_INSUFFICIENT_PERMISSIONS;
9890eb1077SAndy Ritger     }
9990eb1077SAndy Ritger 
100758b4ee8SAndy Ritger     if ((ref.pKernelMIGGpuInstance == NULL) || (ref.pMIGComputeInstance == NULL))
10190eb1077SAndy Ritger     {
102758b4ee8SAndy Ritger         return NV_ERR_INVALID_POINTER;
10390eb1077SAndy Ritger     }
10490eb1077SAndy Ritger 
105758b4ee8SAndy Ritger     // Fetch the shared buffer memdesc for the computeId
106758b4ee8SAndy Ritger     return kccuMemDescGetForComputeInst(pGpu, pKernelCcu, ref.pKernelMIGGpuInstance->swizzId,
107758b4ee8SAndy Ritger                                         ref.pMIGComputeInstance->id, pMemDesc);
10890eb1077SAndy Ritger }
10990eb1077SAndy Ritger 
11090eb1077SAndy Ritger NV_STATUS
kccuapiMap_IMPL(KernelCcuApi * pKernelCcuApi,CALL_CONTEXT * pCallContext,RS_CPU_MAP_PARAMS * pParams,RsCpuMapping * pCpuMapping)11190eb1077SAndy Ritger kccuapiMap_IMPL
11290eb1077SAndy Ritger (
11390eb1077SAndy Ritger     KernelCcuApi      *pKernelCcuApi,
11490eb1077SAndy Ritger     CALL_CONTEXT      *pCallContext,
11590eb1077SAndy Ritger     RS_CPU_MAP_PARAMS *pParams,
11690eb1077SAndy Ritger     RsCpuMapping      *pCpuMapping
11790eb1077SAndy Ritger )
11890eb1077SAndy Ritger {
11990eb1077SAndy Ritger     MEMORY_DESCRIPTOR *pMemDesc = NULL;
12090eb1077SAndy Ritger     NV_STATUS status  = NV_OK;
12190eb1077SAndy Ritger     NvBool bKernel    = NV_FALSE;
12290eb1077SAndy Ritger     RmClient *pClient = dynamicCast(pCallContext->pClient, RmClient);
123*b5bf85a8SAndy Ritger     Device *pDevice   = GPU_RES_GET_DEVICE(pKernelCcuApi);
12490eb1077SAndy Ritger 
12590eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: memdesc map\n");
12690eb1077SAndy Ritger 
12790eb1077SAndy Ritger     status = rmapiValidateKernelMapping(rmclientGetCachedPrivilege(pClient),
12890eb1077SAndy Ritger                                         pCpuMapping->flags,
12990eb1077SAndy Ritger                                         &bKernel);
13090eb1077SAndy Ritger     if (status != NV_OK)
13190eb1077SAndy Ritger     {
13290eb1077SAndy Ritger         NV_PRINTF(LEVEL_ERROR, "Kernel mapping validation failed with status: 0x%x\n", status);
13390eb1077SAndy Ritger         return status;
13490eb1077SAndy Ritger     }
13590eb1077SAndy Ritger 
13690eb1077SAndy Ritger     pCpuMapping->processId = osGetCurrentProcess();
13790eb1077SAndy Ritger 
138*b5bf85a8SAndy Ritger     NV_CHECK_OK_OR_RETURN(LEVEL_ERROR, _kccuapiMemdescGet(pKernelCcuApi, pClient, pDevice, &pMemDesc));
13990eb1077SAndy Ritger 
14090eb1077SAndy Ritger     if (pMemDesc == NULL)
14190eb1077SAndy Ritger     {
14290eb1077SAndy Ritger         NV_PRINTF(LEVEL_ERROR, "Shared buffer memdesc is NULL\n");
14390eb1077SAndy Ritger         return NV_ERR_INVALID_OBJECT;
14490eb1077SAndy Ritger     }
14590eb1077SAndy Ritger 
14690eb1077SAndy Ritger     // Map entire buffer (no offsets supported)
14790eb1077SAndy Ritger     status = memdescMap(pMemDesc,
14890eb1077SAndy Ritger                         0,
14990eb1077SAndy Ritger                         pMemDesc->Size,
15090eb1077SAndy Ritger                         bKernel,
15190eb1077SAndy Ritger                         pCpuMapping->pPrivate->protect,
15290eb1077SAndy Ritger                         &pCpuMapping->pLinearAddress,
15390eb1077SAndy Ritger                         &pCpuMapping->pPrivate->pPriv);
15490eb1077SAndy Ritger     if (status != NV_OK)
15590eb1077SAndy Ritger     {
15690eb1077SAndy Ritger         NV_PRINTF(LEVEL_ERROR, "kernelCcuApi shared buffer memdescMap failed with status: 0x%x\n", status);
15790eb1077SAndy Ritger         return status;
15890eb1077SAndy Ritger     }
15990eb1077SAndy Ritger 
16090eb1077SAndy Ritger     return NV_OK;
16190eb1077SAndy Ritger }
16290eb1077SAndy Ritger 
16390eb1077SAndy Ritger NV_STATUS
kccuapiUnmap_IMPL(KernelCcuApi * pKernelCcuApi,CALL_CONTEXT * pCallContext,RsCpuMapping * pCpuMapping)16490eb1077SAndy Ritger kccuapiUnmap_IMPL
16590eb1077SAndy Ritger (
16690eb1077SAndy Ritger     KernelCcuApi *pKernelCcuApi,
16790eb1077SAndy Ritger     CALL_CONTEXT *pCallContext,
16890eb1077SAndy Ritger     RsCpuMapping *pCpuMapping
16990eb1077SAndy Ritger )
17090eb1077SAndy Ritger {
17190eb1077SAndy Ritger     NV_STATUS status = NV_OK;
17290eb1077SAndy Ritger     NvBool bKernel   = NV_FALSE;
173*b5bf85a8SAndy Ritger     Device *pDevice  = GPU_RES_GET_DEVICE(pKernelCcuApi);
17490eb1077SAndy Ritger     RmClient *pClient = dynamicCast(pCallContext->pClient, RmClient);
17590eb1077SAndy Ritger     MEMORY_DESCRIPTOR *pMemDesc = NULL;
17690eb1077SAndy Ritger 
17790eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: memdesc unmap\n");
17890eb1077SAndy Ritger 
17990eb1077SAndy Ritger     status = rmapiValidateKernelMapping(rmclientGetCachedPrivilege(pClient),
18090eb1077SAndy Ritger                                         pCpuMapping->flags,
18190eb1077SAndy Ritger                                         &bKernel);
18290eb1077SAndy Ritger     if (status != NV_OK)
18390eb1077SAndy Ritger     {
18490eb1077SAndy Ritger         NV_PRINTF(LEVEL_ERROR, "Kernel mapping validation failed with status: 0x%x\n", status);
18590eb1077SAndy Ritger         return status;
18690eb1077SAndy Ritger     }
18790eb1077SAndy Ritger 
188*b5bf85a8SAndy Ritger     NV_CHECK_OK_OR_RETURN(LEVEL_ERROR, _kccuapiMemdescGet(pKernelCcuApi, pClient, pDevice, &pMemDesc));
18990eb1077SAndy Ritger 
19090eb1077SAndy Ritger     if (pMemDesc == NULL)
19190eb1077SAndy Ritger     {
19290eb1077SAndy Ritger         NV_PRINTF(LEVEL_ERROR, "Shared buffer memdesc is NULL\n");
19390eb1077SAndy Ritger         return NV_ERR_INVALID_OBJECT;
19490eb1077SAndy Ritger     }
19590eb1077SAndy Ritger 
19690eb1077SAndy Ritger     memdescUnmap(pMemDesc,
19790eb1077SAndy Ritger                  bKernel,
19890eb1077SAndy Ritger                  pCpuMapping->processId,
19990eb1077SAndy Ritger                  pCpuMapping->pLinearAddress,
20090eb1077SAndy Ritger                  pCpuMapping->pPrivate->pPriv);
20190eb1077SAndy Ritger 
20290eb1077SAndy Ritger     return status;
20390eb1077SAndy Ritger }
20490eb1077SAndy Ritger 
20590eb1077SAndy Ritger NV_STATUS
kccuapiGetMapAddrSpace_IMPL(KernelCcuApi * pKernelCcuApi,CALL_CONTEXT * pCallContext,NvU32 mapFlags,NV_ADDRESS_SPACE * pAddrSpace)20690eb1077SAndy Ritger kccuapiGetMapAddrSpace_IMPL
20790eb1077SAndy Ritger (
20890eb1077SAndy Ritger     KernelCcuApi     *pKernelCcuApi,
20990eb1077SAndy Ritger     CALL_CONTEXT     *pCallContext,
21090eb1077SAndy Ritger     NvU32            mapFlags,
21190eb1077SAndy Ritger     NV_ADDRESS_SPACE *pAddrSpace
21290eb1077SAndy Ritger )
21390eb1077SAndy Ritger {
21490eb1077SAndy Ritger     NV_ADDRESS_SPACE addrSpace  = 0;
21590eb1077SAndy Ritger     MEMORY_DESCRIPTOR *pMemDesc = NULL;
216*b5bf85a8SAndy Ritger     Device *pDevice   = GPU_RES_GET_DEVICE(pKernelCcuApi);
21790eb1077SAndy Ritger     RmClient *pClient = dynamicCast(pCallContext->pClient, RmClient);
21890eb1077SAndy Ritger     OBJGPU    *pGpu   = GPU_RES_GET_GPU(pKernelCcuApi);
21990eb1077SAndy Ritger 
22090eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: get memdesc address-space\n");
22190eb1077SAndy Ritger 
222*b5bf85a8SAndy Ritger     NV_CHECK_OK_OR_RETURN(LEVEL_ERROR, _kccuapiMemdescGet(pKernelCcuApi, pClient, pDevice, &pMemDesc));
22390eb1077SAndy Ritger 
22490eb1077SAndy Ritger     if (pMemDesc == NULL)
22590eb1077SAndy Ritger     {
22690eb1077SAndy Ritger         NV_PRINTF(LEVEL_ERROR, "Shared buffer memdesc is NULL\n");
22790eb1077SAndy Ritger         return NV_ERR_INVALID_OBJECT;
22890eb1077SAndy Ritger     }
22990eb1077SAndy Ritger 
23090eb1077SAndy Ritger     NV_ASSERT_OK_OR_RETURN(rmapiGetEffectiveAddrSpace(pGpu, pMemDesc, mapFlags, &addrSpace));
23190eb1077SAndy Ritger 
23290eb1077SAndy Ritger     *pAddrSpace = addrSpace;
23390eb1077SAndy Ritger 
23490eb1077SAndy Ritger     return NV_OK;
23590eb1077SAndy Ritger }
23690eb1077SAndy Ritger 
23790eb1077SAndy Ritger NV_STATUS
kccuapiGetMemoryMappingDescriptor_IMPL(KernelCcuApi * pKernelCcuApi,MEMORY_DESCRIPTOR ** ppMemDesc)23890eb1077SAndy Ritger kccuapiGetMemoryMappingDescriptor_IMPL
23990eb1077SAndy Ritger (
24090eb1077SAndy Ritger     KernelCcuApi      *pKernelCcuApi,
24190eb1077SAndy Ritger     MEMORY_DESCRIPTOR **ppMemDesc
24290eb1077SAndy Ritger )
24390eb1077SAndy Ritger {
24490eb1077SAndy Ritger     MEMORY_DESCRIPTOR *pMemDesc = NULL;
245*b5bf85a8SAndy Ritger     Device *pDevice   = GPU_RES_GET_DEVICE(pKernelCcuApi);
24690eb1077SAndy Ritger     RmClient *pClient = dynamicCast(RES_GET_CLIENT(pKernelCcuApi), RmClient);
24790eb1077SAndy Ritger 
24890eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: get memdesc\n");
24990eb1077SAndy Ritger 
250*b5bf85a8SAndy Ritger     NV_CHECK_OK_OR_RETURN(LEVEL_ERROR, _kccuapiMemdescGet(pKernelCcuApi, pClient, pDevice, &pMemDesc));
25190eb1077SAndy Ritger 
25290eb1077SAndy Ritger     if (pMemDesc == NULL)
25390eb1077SAndy Ritger     {
25490eb1077SAndy Ritger         NV_PRINTF(LEVEL_ERROR, "Shared buffer memdesc is NULL\n");
25590eb1077SAndy Ritger         return NV_ERR_INVALID_OBJECT;
25690eb1077SAndy Ritger     }
25790eb1077SAndy Ritger 
25890eb1077SAndy Ritger     *ppMemDesc = pMemDesc;
25990eb1077SAndy Ritger 
26090eb1077SAndy Ritger     return NV_OK;
26190eb1077SAndy Ritger }
26290eb1077SAndy Ritger 
26390eb1077SAndy Ritger NV_STATUS
kccuapiCtrlCmdSubscribe_IMPL(KernelCcuApi * pKernelCcuApi,NV_COUNTER_COLLECTION_UNIT_SUBSCRIBE_PARAMS * pParams)26490eb1077SAndy Ritger kccuapiCtrlCmdSubscribe_IMPL
26590eb1077SAndy Ritger (
26690eb1077SAndy Ritger     KernelCcuApi *pKernelCcuApi,
26790eb1077SAndy Ritger     NV_COUNTER_COLLECTION_UNIT_SUBSCRIBE_PARAMS *pParams
26890eb1077SAndy Ritger )
26990eb1077SAndy Ritger {
27090eb1077SAndy Ritger     MIG_INSTANCE_REF ref;
27190eb1077SAndy Ritger     MEMORY_DESCRIPTOR *pMemDesc = NULL;
27290eb1077SAndy Ritger     NV_STATUS status      = NV_OK;
273*b5bf85a8SAndy Ritger     Device *pDevice       = GPU_RES_GET_DEVICE(pKernelCcuApi);
27490eb1077SAndy Ritger     OBJGPU    *pGpu       = GPU_RES_GET_GPU(pKernelCcuApi);
27590eb1077SAndy Ritger     KernelCcu *pKernelCcu = GPU_GET_KERNEL_CCU(pGpu);
27690eb1077SAndy Ritger     RmClient *pClient     = dynamicCast(RES_GET_CLIENT(pKernelCcuApi), RmClient);
27790eb1077SAndy Ritger     KernelMIGManager *pKernelMIGManager = GPU_GET_KERNEL_MIG_MANAGER(pGpu);
27890eb1077SAndy Ritger 
27990eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: CCU subscribe request\n");
28090eb1077SAndy Ritger 
28190eb1077SAndy Ritger     if (pKernelCcu == NULL)
28290eb1077SAndy Ritger     {
28390eb1077SAndy Ritger         return NV_ERR_INVALID_OBJECT;
28490eb1077SAndy Ritger     }
28590eb1077SAndy Ritger 
28690eb1077SAndy Ritger     if (!IS_MIG_ENABLED(pGpu))
28790eb1077SAndy Ritger     {
28890eb1077SAndy Ritger         NV_CHECK_OK_OR_RETURN(LEVEL_ERROR,
28990eb1077SAndy Ritger                 kccuMemDescGetForShrBufId(pGpu, pKernelCcu, CCU_DEV_SHRBUF_ID, &pMemDesc));
29090eb1077SAndy Ritger 
29190eb1077SAndy Ritger         if (pMemDesc == NULL)
29290eb1077SAndy Ritger         {
29390eb1077SAndy Ritger             return NV_ERR_NO_MEMORY;
29490eb1077SAndy Ritger         }
29590eb1077SAndy Ritger 
29690eb1077SAndy Ritger         pParams->counterBlockSize = kccuCounterBlockSizeGet(pGpu, pKernelCcu, NV_TRUE);
29790eb1077SAndy Ritger         pParams->bufferSize       = memdescGetSize(pMemDesc);
29890eb1077SAndy Ritger 
29990eb1077SAndy Ritger         return status;
30090eb1077SAndy Ritger     }
30190eb1077SAndy Ritger 
30290eb1077SAndy Ritger     // In case of MIG
303*b5bf85a8SAndy Ritger     status = kmigmgrGetInstanceRefFromDevice(pGpu, pKernelMIGManager, pDevice, &ref);
30490eb1077SAndy Ritger     if (status != NV_OK)
30590eb1077SAndy Ritger     {
30690eb1077SAndy Ritger         // Check if client is allowed to query for device counters or not
30790eb1077SAndy Ritger         if (!rmclientIsCapable(pClient, NV_RM_CAP_SYS_SMC_MONITOR))
30890eb1077SAndy Ritger         {
30990eb1077SAndy Ritger             // Return if the client is not allowed
31090eb1077SAndy Ritger             return status;
31190eb1077SAndy Ritger         }
31290eb1077SAndy Ritger 
31390eb1077SAndy Ritger         // Get device counter block size
31490eb1077SAndy Ritger         NV_CHECK_OK_OR_RETURN(LEVEL_ERROR,
31590eb1077SAndy Ritger                 kccuMemDescGetForShrBufId(pGpu, pKernelCcu, CCU_DEV_SHRBUF_ID, &pMemDesc));
31690eb1077SAndy Ritger         pParams->counterBlockSize = kccuCounterBlockSizeGet(pGpu, pKernelCcu, NV_TRUE);
31790eb1077SAndy Ritger     }
31890eb1077SAndy Ritger     else
31990eb1077SAndy Ritger     {
32090eb1077SAndy Ritger         // Get counter block size for mig gpu inst
32190eb1077SAndy Ritger         NV_CHECK_OK_OR_RETURN(LEVEL_ERROR,
32290eb1077SAndy Ritger                 kccuMemDescGetForSwizzId(pGpu, pKernelCcu, ref.pKernelMIGGpuInstance->swizzId, &pMemDesc));
32390eb1077SAndy Ritger         pParams->counterBlockSize = kccuCounterBlockSizeGet(pGpu, pKernelCcu, NV_FALSE);
32490eb1077SAndy Ritger     }
32590eb1077SAndy Ritger 
32690eb1077SAndy Ritger     if (pMemDesc == NULL)
32790eb1077SAndy Ritger     {
32890eb1077SAndy Ritger         return NV_ERR_NO_MEMORY;
32990eb1077SAndy Ritger     }
33090eb1077SAndy Ritger     pParams->bufferSize = memdescGetSize(pMemDesc);
33190eb1077SAndy Ritger 
33290eb1077SAndy Ritger     return NV_OK;
33390eb1077SAndy Ritger }
33490eb1077SAndy Ritger 
33590eb1077SAndy Ritger NV_STATUS
kccuapiCtrlCmdUnsubscribe_IMPL(KernelCcuApi * pKernelCcuApi)33690eb1077SAndy Ritger kccuapiCtrlCmdUnsubscribe_IMPL
33790eb1077SAndy Ritger (
33890eb1077SAndy Ritger     KernelCcuApi *pKernelCcuApi
33990eb1077SAndy Ritger )
34090eb1077SAndy Ritger {
34190eb1077SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: CCU unsubscribe request\n");
34290eb1077SAndy Ritger 
34390eb1077SAndy Ritger     return NV_OK;
34490eb1077SAndy Ritger }
34590eb1077SAndy Ritger 
346758b4ee8SAndy Ritger NV_STATUS
kccuapiCtrlCmdSetStreamState_IMPL(KernelCcuApi * pKernelCcuApi,NV_COUNTER_COLLECTION_UNIT_STREAM_STATE_PARAMS * pParams)347758b4ee8SAndy Ritger kccuapiCtrlCmdSetStreamState_IMPL
348758b4ee8SAndy Ritger (
349758b4ee8SAndy Ritger     KernelCcuApi *pKernelCcuApi,
350758b4ee8SAndy Ritger     NV_COUNTER_COLLECTION_UNIT_STREAM_STATE_PARAMS *pParams
351758b4ee8SAndy Ritger )
352758b4ee8SAndy Ritger {
353758b4ee8SAndy Ritger     OBJGPU    *pGpu       = GPU_RES_GET_GPU(pKernelCcuApi);
354758b4ee8SAndy Ritger     KernelCcu *pKernelCcu = GPU_GET_KERNEL_CCU(pGpu);
355758b4ee8SAndy Ritger 
356758b4ee8SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: CCU set stream state request\n");
357758b4ee8SAndy Ritger 
358758b4ee8SAndy Ritger     if (pKernelCcu == NULL)
359758b4ee8SAndy Ritger     {
360758b4ee8SAndy Ritger         return NV_ERR_INVALID_OBJECT;
361758b4ee8SAndy Ritger     }
362758b4ee8SAndy Ritger 
363758b4ee8SAndy Ritger     // Set counter collection unit stream state
364758b4ee8SAndy Ritger     NV_CHECK_OK_OR_RETURN(LEVEL_ERROR,
365758b4ee8SAndy Ritger             kccuStreamStateSet(pGpu, pKernelCcu, pParams));
366758b4ee8SAndy Ritger 
367758b4ee8SAndy Ritger     return NV_OK;
368758b4ee8SAndy Ritger }
369758b4ee8SAndy Ritger 
370758b4ee8SAndy Ritger NV_STATUS
kccuapiCtrlCmdGetStreamState_IMPL(KernelCcuApi * pKernelCcuApi,NV_COUNTER_COLLECTION_UNIT_STREAM_STATE_PARAMS * pParams)371758b4ee8SAndy Ritger kccuapiCtrlCmdGetStreamState_IMPL
372758b4ee8SAndy Ritger (
373758b4ee8SAndy Ritger     KernelCcuApi *pKernelCcuApi,
374758b4ee8SAndy Ritger     NV_COUNTER_COLLECTION_UNIT_STREAM_STATE_PARAMS *pParams
375758b4ee8SAndy Ritger )
376758b4ee8SAndy Ritger {
377758b4ee8SAndy Ritger     OBJGPU    *pGpu       = GPU_RES_GET_GPU(pKernelCcuApi);
378758b4ee8SAndy Ritger     KernelCcu *pKernelCcu = GPU_GET_KERNEL_CCU(pGpu);
379758b4ee8SAndy Ritger 
380758b4ee8SAndy Ritger     NV_PRINTF(LEVEL_INFO, "Kernel Ccu Api: CCU get stream state request\n");
381758b4ee8SAndy Ritger 
382758b4ee8SAndy Ritger     if (pKernelCcu == NULL)
383758b4ee8SAndy Ritger     {
384758b4ee8SAndy Ritger         return NV_ERR_INVALID_OBJECT;
385758b4ee8SAndy Ritger     }
386758b4ee8SAndy Ritger 
387758b4ee8SAndy Ritger     // Get counter collection unit stream state
388758b4ee8SAndy Ritger     pParams->bStreamState = kccuStreamStateGet(pGpu, pKernelCcu);
389758b4ee8SAndy Ritger 
390758b4ee8SAndy Ritger     return NV_OK;
391758b4ee8SAndy Ritger }
392