1761fc6ecSEtienne Carriere /* SPDX-License-Identifier: BSD-2-Clause */ 2761fc6ecSEtienne Carriere /* 3761fc6ecSEtienne Carriere * Copyright (C) 2023, STMicroelectronics 4761fc6ecSEtienne Carriere * Copyright (C) 2022, Microchip 5761fc6ecSEtienne Carriere */ 6761fc6ecSEtienne Carriere #ifndef __PTA_STATS_H 7761fc6ecSEtienne Carriere #define __PTA_STATS_H 8761fc6ecSEtienne Carriere 9a05577eaSEtienne Carriere #include <stdint.h> 10a05577eaSEtienne Carriere #include <tee_api_types.h> 11a05577eaSEtienne Carriere 12761fc6ecSEtienne Carriere #define STATS_UUID \ 13761fc6ecSEtienne Carriere { 0xd96a5b40, 0xe2c7, 0xb1af, \ 14761fc6ecSEtienne Carriere { 0x87, 0x94, 0x10, 0x02, 0xa5, 0xd5, 0xc6, 0x1b } } 15761fc6ecSEtienne Carriere 16761fc6ecSEtienne Carriere /* 17a05577eaSEtienne Carriere * STATS_CMD_PAGER_STATS - Get statistics on pager 18761fc6ecSEtienne Carriere * 19a05577eaSEtienne Carriere * [out] value[0].a Number of unlocked pages 20a05577eaSEtienne Carriere * [out] value[0].b Page pool size 21a05577eaSEtienne Carriere * [out] value[1].a R/O faults since last stats dump 22a05577eaSEtienne Carriere * [out] value[1].b R/W faults since last stats dump 23a05577eaSEtienne Carriere * [out] value[2].a Hidden faults since last stats dump 24a05577eaSEtienne Carriere * [out] value[2].b Zi pages released since last stats dump 25a05577eaSEtienne Carriere */ 26a05577eaSEtienne Carriere #define STATS_CMD_PAGER_STATS 0 27a05577eaSEtienne Carriere 28a05577eaSEtienne Carriere /* 29a05577eaSEtienne Carriere * STATS_CMD_ALLOC_STATS - Get statistics on core heap allocations 30a05577eaSEtienne Carriere * 31a05577eaSEtienne Carriere * [in] value[0].a ID of allocator(s) to get stats from (ALLOC_ID_*) 32a05577eaSEtienne Carriere * [out] memref[0] Array of struct pta_stats_alloc instances 33a05577eaSEtienne Carriere */ 34a05577eaSEtienne Carriere #define STATS_CMD_ALLOC_STATS 1 35a05577eaSEtienne Carriere 36a05577eaSEtienne Carriere #define ALLOC_ID_ALL 0 /* All allocators */ 37a05577eaSEtienne Carriere #define ALLOC_ID_HEAP 1 /* Core heap allocator */ 38a05577eaSEtienne Carriere #define ALLOC_ID_PUBLIC_DDR 2 /* Public DDR allocator (deprecated) */ 39a05577eaSEtienne Carriere #define ALLOC_ID_TA_RAM 3 /* TA_RAM allocator */ 40a05577eaSEtienne Carriere #define ALLOC_ID_NEXUS_HEAP 4 /* Nexus heap allocator */ 4176306f73SEtienne Carriere #define ALLOC_ID_RPMB 5 /* RPMB secure storage */ 42a05577eaSEtienne Carriere #define STATS_NB_POOLS 5 43a05577eaSEtienne Carriere 44a05577eaSEtienne Carriere #define TEE_ALLOCATOR_DESC_LENGTH 32 45a05577eaSEtienne Carriere 46a05577eaSEtienne Carriere struct pta_stats_alloc { 47a05577eaSEtienne Carriere char desc[TEE_ALLOCATOR_DESC_LENGTH]; 48*682ff6ebSJens Wiklander uint64_t free2_sum; /* Sum of size^2 of each free chunk */ 49a05577eaSEtienne Carriere uint32_t allocated; /* Bytes currently allocated */ 50a05577eaSEtienne Carriere uint32_t max_allocated; /* Tracks max value of allocated */ 51a05577eaSEtienne Carriere uint32_t size; /* Total size for this allocator */ 52a05577eaSEtienne Carriere uint32_t num_alloc_fail; /* Number of failed alloc requests */ 53a05577eaSEtienne Carriere uint32_t biggest_alloc_fail; /* Size of biggest failed alloc */ 54a05577eaSEtienne Carriere uint32_t biggest_alloc_fail_used; /* Alloc bytes when above occurred */ 55a05577eaSEtienne Carriere }; 56a05577eaSEtienne Carriere 57a05577eaSEtienne Carriere /* 58a05577eaSEtienne Carriere * STATS_CMD_MEMLEAK_STATS - Print memory leakage info to console 59a05577eaSEtienne Carriere */ 60a05577eaSEtienne Carriere #define STATS_CMD_MEMLEAK_STATS 2 61a05577eaSEtienne Carriere 62a05577eaSEtienne Carriere /* 63a05577eaSEtienne Carriere * STATS_CMD_TA_STATS - Get information on TA instances 64a05577eaSEtienne Carriere * 65a05577eaSEtienne Carriere * [out] memref[0] Array of struct pta_stats_ta per loaded TA 66761fc6ecSEtienne Carriere */ 67761fc6ecSEtienne Carriere #define STATS_CMD_TA_STATS 3 68761fc6ecSEtienne Carriere 69a05577eaSEtienne Carriere struct pta_stats_ta { 70a05577eaSEtienne Carriere TEE_UUID uuid; 71a05577eaSEtienne Carriere uint32_t panicked; /* True if TA has panicked */ 72a05577eaSEtienne Carriere uint32_t sess_num; /* Number of opened session */ 73a05577eaSEtienne Carriere struct pta_stats_alloc heap; 74a05577eaSEtienne Carriere }; 75a05577eaSEtienne Carriere 76761fc6ecSEtienne Carriere /* 77761fc6ecSEtienne Carriere * STATS_CMD_GET_TIME - Get both REE time and TEE time 78761fc6ecSEtienne Carriere * 79761fc6ecSEtienne Carriere * [out] value[0].a REE time as seen by OP-TEE in seconds 80761fc6ecSEtienne Carriere * [out] value[0].b REE time as seen by OP-TEE, milliseconds part 81761fc6ecSEtienne Carriere * [out] value[1].a TEE system time in seconds 82761fc6ecSEtienne Carriere * [out] value[1].b TEE system time, milliseconds part 83761fc6ecSEtienne Carriere */ 84761fc6ecSEtienne Carriere #define STATS_CMD_GET_TIME 4 85761fc6ecSEtienne Carriere 86a5e75b7eSEtienne Carriere /* 87a5e75b7eSEtienne Carriere * STATS_CMD_PRINT_DRIVER_INFO - Print device drivers information to console 88a5e75b7eSEtienne Carriere * 89a5e75b7eSEtienne Carriere * [in] value[0].a Target driver, one of STATS_DRIVER_TYPE_* 90a5e75b7eSEtienne Carriere */ 91a5e75b7eSEtienne Carriere #define STATS_CMD_PRINT_DRIVER_INFO 5 92a5e75b7eSEtienne Carriere 93a5e75b7eSEtienne Carriere #define STATS_DRIVER_TYPE_CLOCK 0 94a5e75b7eSEtienne Carriere #define STATS_DRIVER_TYPE_REGULATOR 1 95a5e75b7eSEtienne Carriere 96761fc6ecSEtienne Carriere #endif /*__PTA_STATS_H*/ 97