mirror of
https://github.com/intel/compute-runtime.git
synced 2026-01-03 06:49:52 +08:00
107 lines
5.2 KiB
C++
107 lines
5.2 KiB
C++
/*
|
|
* Copyright (C) 2022-2025 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "level_zero/tools/source/metrics/metric.h"
|
|
#include "level_zero/tools/source/metrics/os_interface_metric.h"
|
|
|
|
namespace L0 {
|
|
|
|
class IpSamplingMetricSourceImp;
|
|
struct IpSamplingMetricImp;
|
|
struct IpSamplingMetricGroupBase;
|
|
struct IpSamplingMetricGroupImp;
|
|
class L0GfxCoreHelper;
|
|
|
|
struct IpSamplingMetricStreamerBase : public MetricStreamer {
|
|
ze_result_t appendStreamerMarker(CommandList &commandList, uint32_t value) override { return ZE_RESULT_ERROR_UNSUPPORTED_FEATURE; }
|
|
};
|
|
|
|
struct IpSamplingMetricStreamerImp : public IpSamplingMetricStreamerBase {
|
|
|
|
IpSamplingMetricStreamerImp(IpSamplingMetricSourceImp &ipSamplingSource) : ipSamplingSource(ipSamplingSource) {}
|
|
~IpSamplingMetricStreamerImp() override{};
|
|
ze_result_t readData(uint32_t maxReportCount, size_t *pRawDataSize, uint8_t *pRawData) override;
|
|
ze_result_t close() override;
|
|
Event::State getNotificationState() override;
|
|
uint32_t getMaxSupportedReportCount();
|
|
|
|
protected:
|
|
IpSamplingMetricSourceImp &ipSamplingSource;
|
|
};
|
|
|
|
struct MultiDeviceIpSamplingMetricStreamerImp : public IpSamplingMetricStreamerBase {
|
|
|
|
MultiDeviceIpSamplingMetricStreamerImp(std::vector<IpSamplingMetricStreamerImp *> subDeviceStreamers) : subDeviceStreamers(subDeviceStreamers) {}
|
|
~MultiDeviceIpSamplingMetricStreamerImp() override = default;
|
|
ze_result_t readData(uint32_t maxReportCount, size_t *pRawDataSize, uint8_t *pRawData) override;
|
|
ze_result_t close() override;
|
|
Event::State getNotificationState() override;
|
|
|
|
protected:
|
|
std::vector<IpSamplingMetricStreamerImp *> subDeviceStreamers = {};
|
|
};
|
|
|
|
struct IpSamplingMetricCalcOpImp : public MetricCalcOpImp {
|
|
IpSamplingMetricCalcOpImp(uint32_t inputCachedMetricsCount, std::vector<MetricImp *> &inputMetricsInReport,
|
|
std::vector<uint32_t> &inputIncludedMetricIndexes, bool multidevice)
|
|
: MetricCalcOpImp(multidevice),
|
|
cachedMetricsCount(inputCachedMetricsCount),
|
|
metricsInReportCount(static_cast<uint32_t>(inputMetricsInReport.size())),
|
|
metricsInReport(inputMetricsInReport),
|
|
includedMetricIndexes(inputIncludedMetricIndexes) {}
|
|
|
|
~IpSamplingMetricCalcOpImp() override{};
|
|
static ze_result_t create(IpSamplingMetricSourceImp &metricSource,
|
|
zet_intel_metric_calculate_exp_desc_t *pCalculateDesc,
|
|
bool isMultiDevice,
|
|
zet_intel_metric_calculate_operation_exp_handle_t *phCalculateOperation);
|
|
ze_result_t destroy() override;
|
|
ze_result_t getReportFormat(uint32_t *pCount, zet_metric_handle_t *phMetrics) override;
|
|
ze_result_t metricCalculateMultipleValues(const size_t rawDataSize, size_t *offset, const uint8_t *pRawData,
|
|
uint32_t *pSetCount, uint32_t *pMetricsReportCountPerSet,
|
|
uint32_t *pTotalMetricReportCount,
|
|
zet_intel_metric_result_exp_t *pMetricResults) override {
|
|
return ZE_RESULT_ERROR_UNSUPPORTED_FEATURE;
|
|
}
|
|
ze_result_t metricCalculateValues(const size_t rawDataSize, size_t *pOffset, const uint8_t *pRawData,
|
|
uint32_t *pTotalMetricReportCount,
|
|
zet_intel_metric_result_exp_t *pMetricResults) override;
|
|
|
|
void fillStallDataMap(const size_t rawDataSize, const uint8_t *pRawData, size_t *processedSize,
|
|
L0GfxCoreHelper &l0GfxCoreHelper,
|
|
std::map<uint64_t, void *> &stallReportDataMap,
|
|
bool *dataOVerflow,
|
|
bool allowInterrupt,
|
|
uint32_t requestedReportCount);
|
|
|
|
protected:
|
|
ze_result_t metricCalculateValuesSingle(const size_t rawDataSize, size_t *pOffset, const uint8_t *pRawData,
|
|
uint32_t *pTotalMetricReportCount,
|
|
L0::L0GfxCoreHelper &l0GfxCoreHelper,
|
|
IpSamplingMetricGroupBase *metricGroupBase,
|
|
bool getSize,
|
|
bool &dataOverflow,
|
|
std::map<uint64_t, void *> &stallReportDataMap);
|
|
ze_result_t metricCalculateValuesMulti(const size_t rawDataSize, size_t *pOffset, const uint8_t *pRawData,
|
|
uint32_t *pTotalMetricReportCount,
|
|
L0::L0GfxCoreHelper &l0GfxCoreHelper,
|
|
IpSamplingMetricGroupBase *metricGroupBase,
|
|
bool getSize,
|
|
uint32_t numSubDevices,
|
|
bool &dataOverflow,
|
|
std::map<uint64_t, void *> &stallReportDataMap);
|
|
|
|
uint32_t cachedMetricsCount = 0;
|
|
uint32_t metricsInReportCount = 0;
|
|
std::vector<MetricImp *> metricsInReport{};
|
|
std::vector<uint32_t> includedMetricIndexes{};
|
|
};
|
|
|
|
} // namespace L0
|