2017-12-21 00:45:38 +01:00
|
|
|
/*
|
2025-02-04 11:14:19 +00:00
|
|
|
* Copyright (C) 2018-2025 Intel Corporation
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
2019-03-26 11:59:46 +01:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 00:45:38 +01:00
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
2022-06-21 13:00:57 +00:00
|
|
|
#include "CL/cl_ext.h"
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
namespace NEO {
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
enum PerformanceHints {
|
|
|
|
|
CL_BUFFER_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
|
|
|
|
CL_BUFFER_MEETS_ALIGNMENT_RESTRICTIONS,
|
|
|
|
|
CL_BUFFER_NEEDS_ALLOCATE_MEMORY,
|
2018-02-08 17:30:44 +01:00
|
|
|
CL_IMAGE_MEETS_ALIGNMENT_RESTRICTIONS,
|
2017-12-21 00:45:38 +01:00
|
|
|
DRIVER_CALLS_INTERNAL_CL_FLUSH,
|
|
|
|
|
PROFILING_ENABLED,
|
|
|
|
|
SUBBUFFER_SHARES_MEMORY,
|
|
|
|
|
CL_SVM_ALLOC_MEETS_ALIGNMENT_RESTRICTIONS,
|
|
|
|
|
CL_ENQUEUE_READ_BUFFER_REQUIRES_COPY_DATA,
|
2018-01-11 15:42:55 +01:00
|
|
|
CL_ENQUEUE_READ_BUFFER_DOESNT_REQUIRE_COPY_DATA,
|
2017-12-21 00:45:38 +01:00
|
|
|
CL_ENQUEUE_READ_BUFFER_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
|
|
|
|
CL_ENQUEUE_READ_BUFFER_RECT_REQUIRES_COPY_DATA,
|
2018-01-25 13:17:35 +01:00
|
|
|
CL_ENQUEUE_READ_BUFFER_RECT_DOESNT_REQUIRES_COPY_DATA,
|
2017-12-21 00:45:38 +01:00
|
|
|
CL_ENQUEUE_READ_BUFFER_RECT_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
|
|
|
|
CL_ENQUEUE_WRITE_BUFFER_REQUIRES_COPY_DATA,
|
2018-01-11 15:42:55 +01:00
|
|
|
CL_ENQUEUE_WRITE_BUFFER_DOESNT_REQUIRE_COPY_DATA,
|
2017-12-21 00:45:38 +01:00
|
|
|
CL_ENQUEUE_WRITE_BUFFER_RECT_REQUIRES_COPY_DATA,
|
2018-01-24 09:57:20 +01:00
|
|
|
CL_ENQUEUE_WRITE_BUFFER_RECT_DOESNT_REQUIRE_COPY_DATA,
|
2017-12-21 00:45:38 +01:00
|
|
|
CL_ENQUEUE_READ_IMAGE_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
2018-02-02 10:19:13 +01:00
|
|
|
CL_ENQUEUE_READ_IMAGE_DOESNT_REQUIRES_COPY_DATA,
|
2017-12-21 00:45:38 +01:00
|
|
|
CL_ENQUEUE_WRITE_IMAGE_REQUIRES_COPY_DATA,
|
2018-02-02 10:19:13 +01:00
|
|
|
CL_ENQUEUE_WRITE_IMAGE_DOESNT_REQUIRES_COPY_DATA,
|
2017-12-21 00:45:38 +01:00
|
|
|
CL_ENQUEUE_MAP_BUFFER_REQUIRES_COPY_DATA,
|
|
|
|
|
CL_ENQUEUE_MAP_BUFFER_DOESNT_REQUIRE_COPY_DATA,
|
|
|
|
|
CL_ENQUEUE_MAP_IMAGE_REQUIRES_COPY_DATA,
|
|
|
|
|
CL_ENQUEUE_MAP_IMAGE_DOESNT_REQUIRE_COPY_DATA,
|
|
|
|
|
CL_ENQUEUE_UNMAP_MEM_OBJ_DOESNT_REQUIRE_COPY_DATA,
|
|
|
|
|
CL_ENQUEUE_UNMAP_MEM_OBJ_REQUIRES_COPY_DATA,
|
|
|
|
|
CL_ENQUEUE_SVM_MAP_DOESNT_REQUIRE_COPY_DATA,
|
|
|
|
|
PRINTF_DETECTED_IN_KERNEL,
|
|
|
|
|
NULL_LOCAL_WORKGROUP_SIZE,
|
|
|
|
|
BAD_LOCAL_WORKGROUP_SIZE,
|
|
|
|
|
REGISTER_PRESSURE_TOO_HIGH,
|
|
|
|
|
PRIVATE_MEMORY_USAGE_TOO_HIGH,
|
2019-04-25 14:41:38 +02:00
|
|
|
KERNEL_REQUIRES_COHERENCY,
|
2019-06-28 18:22:38 +02:00
|
|
|
KERNEL_ARGUMENT_AUX_TRANSLATION,
|
2021-07-21 15:03:58 +00:00
|
|
|
KERNEL_ALLOCATION_AUX_TRANSLATION,
|
2019-06-28 18:22:38 +02:00
|
|
|
BUFFER_IS_COMPRESSED,
|
|
|
|
|
BUFFER_IS_NOT_COMPRESSED,
|
|
|
|
|
IMAGE_IS_COMPRESSED,
|
|
|
|
|
IMAGE_IS_NOT_COMPRESSED
|
2017-12-21 00:45:38 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
class DriverDiagnostics {
|
|
|
|
|
public:
|
2025-04-14 12:24:03 +00:00
|
|
|
DriverDiagnostics(cl_diagnostic_verbose_level_intel level);
|
|
|
|
|
bool validFlags(cl_diagnostic_verbose_level_intel flags) const;
|
2017-12-21 00:45:38 +01:00
|
|
|
~DriverDiagnostics() = default;
|
2019-06-11 13:43:51 +02:00
|
|
|
static const char *const hintFormat[];
|
2017-12-21 00:45:38 +01:00
|
|
|
static const cl_int maxHintStringSize = 1024;
|
2019-05-30 14:36:12 +02:00
|
|
|
PerformanceHints obtainHintForTransferOperation(cl_command_type commandType, bool transferRequired);
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
|
protected:
|
2025-04-14 12:24:03 +00:00
|
|
|
cl_diagnostic_verbose_level_intel verboseLevel;
|
2017-12-21 00:45:38 +01:00
|
|
|
};
|
2019-03-26 11:59:46 +01:00
|
|
|
} // namespace NEO
|