2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2024-10-22 20:56:08 +08:00
|
|
|
* Copyright (C) 2018-2024 Intel Corporation
|
2019-03-26 18:59:46 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
#include "performance_counters_linux.h"
|
|
|
|
|
2020-02-24 05:44:01 +08:00
|
|
|
#include "shared/source/device/device.h"
|
2020-12-17 21:17:28 +08:00
|
|
|
#include "shared/source/device/sub_device.h"
|
2023-10-18 16:00:43 +08:00
|
|
|
#include "shared/source/execution_environment/root_device_environment.h"
|
2023-02-02 00:23:01 +08:00
|
|
|
#include "shared/source/helpers/gfx_core_helper.h"
|
2023-01-27 20:45:12 +08:00
|
|
|
#include "shared/source/os_interface/linux/drm_neo.h"
|
2021-05-21 07:17:57 +08:00
|
|
|
#include "shared/source/os_interface/os_interface.h"
|
2019-05-20 17:19:27 +08:00
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
namespace NEO {
|
2019-05-20 17:19:27 +08:00
|
|
|
////////////////////////////////////////////////////
|
|
|
|
// PerformanceCounters::create
|
|
|
|
////////////////////////////////////////////////////
|
|
|
|
std::unique_ptr<PerformanceCounters> PerformanceCounters::create(Device *device) {
|
|
|
|
auto counter = std::make_unique<PerformanceCountersLinux>();
|
2023-10-18 16:00:43 +08:00
|
|
|
auto drm = device->getRootDeviceEnvironment().osInterface->getDriverModel()->as<Drm>();
|
2022-12-09 23:11:27 +08:00
|
|
|
auto &gfxCoreHelper = device->getGfxCoreHelper();
|
2019-05-20 17:19:27 +08:00
|
|
|
UNRECOVERABLE_IF(counter == nullptr);
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2021-04-08 01:00:33 +08:00
|
|
|
if (!device->isSubDevice()) {
|
2020-12-17 21:17:28 +08:00
|
|
|
|
|
|
|
// Root device.
|
|
|
|
counter->subDevice.Enabled = false;
|
|
|
|
counter->subDeviceIndex.Index = 0;
|
2021-09-16 00:27:42 +08:00
|
|
|
counter->subDeviceCount.Count = std::max(device->getNumSubDevices(), 1u);
|
2020-12-17 21:17:28 +08:00
|
|
|
} else {
|
|
|
|
|
|
|
|
// Sub device.
|
|
|
|
counter->subDevice.Enabled = true;
|
|
|
|
counter->subDeviceIndex.Index = static_cast<NEO::SubDevice *>(device)->getSubDeviceIndex();
|
2021-09-16 00:27:42 +08:00
|
|
|
counter->subDeviceCount.Count = std::max(device->getRootDevice()->getNumSubDevices(), 1u);
|
2020-12-17 21:17:28 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Adapter data.
|
2020-05-15 23:28:26 +08:00
|
|
|
counter->adapter.Type = LinuxAdapterType::DrmFileDescriptor;
|
|
|
|
counter->adapter.DrmFileDescriptor = drm->getFileDescriptor();
|
|
|
|
counter->clientData.Linux.Adapter = &(counter->adapter);
|
2024-10-22 20:56:08 +08:00
|
|
|
counter->metricsLibrary->api->callbacks.CommandBufferFlush = &PerformanceCounters::flushCommandBufferCallback;
|
|
|
|
counter->clientData.Handle = reinterpret_cast<void *>(device);
|
2020-12-17 21:17:28 +08:00
|
|
|
|
|
|
|
// Gen data.
|
2022-12-08 20:22:35 +08:00
|
|
|
counter->clientType.Gen = static_cast<MetricsLibraryApi::ClientGen>(gfxCoreHelper.getMetricsLibraryGenId());
|
2020-12-17 21:17:28 +08:00
|
|
|
|
2019-05-20 17:19:27 +08:00
|
|
|
return counter;
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
|
2019-05-20 17:19:27 +08:00
|
|
|
//////////////////////////////////////////////////////
|
|
|
|
// PerformanceCountersLinux::enableCountersConfiguration
|
|
|
|
//////////////////////////////////////////////////////
|
|
|
|
bool PerformanceCountersLinux::enableCountersConfiguration() {
|
|
|
|
// Release previous counters configuration so the user
|
|
|
|
// can change configuration between kernels.
|
|
|
|
releaseCountersConfiguration();
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2019-05-20 17:19:27 +08:00
|
|
|
// Create oa configuration.
|
|
|
|
if (!metricsLibrary->oaConfigurationCreate(
|
|
|
|
context,
|
|
|
|
oaConfiguration)) {
|
|
|
|
DEBUG_BREAK_IF(true);
|
|
|
|
return false;
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
|
2019-05-20 17:19:27 +08:00
|
|
|
// Enable oa configuration.
|
|
|
|
if (!metricsLibrary->oaConfigurationActivate(
|
|
|
|
oaConfiguration)) {
|
|
|
|
DEBUG_BREAK_IF(true);
|
|
|
|
return false;
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
|
2019-05-20 17:19:27 +08:00
|
|
|
return true;
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
|
2019-05-20 17:19:27 +08:00
|
|
|
//////////////////////////////////////////////////////
|
|
|
|
// PerformanceCountersLinux::releaseCountersConfiguration
|
|
|
|
//////////////////////////////////////////////////////
|
|
|
|
void PerformanceCountersLinux::releaseCountersConfiguration() {
|
|
|
|
// Oa configuration.
|
|
|
|
if (oaConfiguration.IsValid()) {
|
|
|
|
metricsLibrary->oaConfigurationDeactivate(oaConfiguration);
|
|
|
|
metricsLibrary->oaConfigurationDelete(oaConfiguration);
|
|
|
|
oaConfiguration.data = nullptr;
|
2017-12-21 07:45:38 +08:00
|
|
|
}
|
|
|
|
}
|
2019-03-26 18:59:46 +08:00
|
|
|
} // namespace NEO
|