2017-12-21 07:45:38 +08:00
|
|
|
/*
|
2019-03-26 18:59:46 +08:00
|
|
|
* Copyright (C) 2017-2019 Intel Corporation
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
2019-03-26 18:59:46 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2017-12-21 07:45:38 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#include "CL/cl_ext_intel.h"
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
namespace NEO {
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
enum PerformanceHints {
|
|
|
|
CL_BUFFER_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
|
|
|
CL_BUFFER_MEETS_ALIGNMENT_RESTRICTIONS,
|
|
|
|
CL_BUFFER_NEEDS_ALLOCATE_MEMORY,
|
2018-02-09 00:30:44 +08:00
|
|
|
CL_IMAGE_MEETS_ALIGNMENT_RESTRICTIONS,
|
2017-12-21 07:45:38 +08:00
|
|
|
DRIVER_CALLS_INTERNAL_CL_FLUSH,
|
|
|
|
PROFILING_ENABLED,
|
|
|
|
PROFILING_ENABLED_WITH_DISABLED_PREEMPTION,
|
|
|
|
SUBBUFFER_SHARES_MEMORY,
|
|
|
|
CL_SVM_ALLOC_MEETS_ALIGNMENT_RESTRICTIONS,
|
|
|
|
CL_ENQUEUE_READ_BUFFER_REQUIRES_COPY_DATA,
|
2018-01-11 22:42:55 +08:00
|
|
|
CL_ENQUEUE_READ_BUFFER_DOESNT_REQUIRE_COPY_DATA,
|
2017-12-21 07:45:38 +08:00
|
|
|
CL_ENQUEUE_READ_BUFFER_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
|
|
|
CL_ENQUEUE_READ_BUFFER_RECT_REQUIRES_COPY_DATA,
|
2018-01-25 20:17:35 +08:00
|
|
|
CL_ENQUEUE_READ_BUFFER_RECT_DOESNT_REQUIRES_COPY_DATA,
|
2017-12-21 07:45:38 +08:00
|
|
|
CL_ENQUEUE_READ_BUFFER_RECT_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
|
|
|
CL_ENQUEUE_WRITE_BUFFER_REQUIRES_COPY_DATA,
|
2018-01-11 22:42:55 +08:00
|
|
|
CL_ENQUEUE_WRITE_BUFFER_DOESNT_REQUIRE_COPY_DATA,
|
2017-12-21 07:45:38 +08:00
|
|
|
CL_ENQUEUE_WRITE_BUFFER_RECT_REQUIRES_COPY_DATA,
|
2018-01-24 16:57:20 +08:00
|
|
|
CL_ENQUEUE_WRITE_BUFFER_RECT_DOESNT_REQUIRE_COPY_DATA,
|
2017-12-21 07:45:38 +08:00
|
|
|
CL_ENQUEUE_READ_IMAGE_DOESNT_MEET_ALIGNMENT_RESTRICTIONS,
|
2018-02-02 17:19:13 +08:00
|
|
|
CL_ENQUEUE_READ_IMAGE_DOESNT_REQUIRES_COPY_DATA,
|
2017-12-21 07:45:38 +08:00
|
|
|
CL_ENQUEUE_WRITE_IMAGE_REQUIRES_COPY_DATA,
|
2018-02-02 17:19:13 +08:00
|
|
|
CL_ENQUEUE_WRITE_IMAGE_DOESNT_REQUIRES_COPY_DATA,
|
2017-12-21 07:45:38 +08: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,
|
|
|
|
KERNEL_REQUIRES_COHERENCY
|
|
|
|
};
|
|
|
|
|
|
|
|
class DriverDiagnostics {
|
|
|
|
public:
|
|
|
|
DriverDiagnostics(cl_diagnostics_verbose_level level);
|
2018-03-02 20:39:22 +08:00
|
|
|
bool validFlags(cl_diagnostics_verbose_level flags) const;
|
2017-12-21 07:45:38 +08:00
|
|
|
~DriverDiagnostics() = default;
|
|
|
|
static const char *hintFormat[];
|
|
|
|
static const cl_int maxHintStringSize = 1024;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
cl_diagnostics_verbose_level verboseLevel;
|
|
|
|
};
|
2019-03-26 18:59:46 +08:00
|
|
|
} // namespace NEO
|