diff options
author | Viet-Hoa Do <viet-hoa.do@arm.com> | 2023-07-05 17:36:40 +0100 |
---|---|---|
committer | Viet-Hoa Do <viet-hoa.do@arm.com> | 2023-07-11 13:46:38 +0000 |
commit | 3389f530fb19247889048f9a2b2eedda14f3fea2 (patch) | |
tree | 5e22f5f014194f6382a35b2c7eae4e805d2541bf /compute_kernel_writer/include/ckw/Error.h | |
parent | 8e2dedea8550b1c18c3bbeead8c972f661dcfac8 (diff) | |
download | ComputeLibrary-3389f530fb19247889048f9a2b2eedda14f3fea2.tar.gz |
Add kernel and kernel writer skeletons
* Add the skeleton for kernel, kernel writer and their respective
OpenCL implementation.
* Add method to write code comment and its test.
Resolves: COMPMID-6343
Signed-off-by: Viet-Hoa Do <viet-hoa.do@arm.com>
Change-Id: Ib986228154f7a00da7a5fd3b7105941325fe13b1
Reviewed-on: https://review.mlplatform.org/c/ml/ComputeLibrary/+/9889
Tested-by: Arm Jenkins <bsgcomp@arm.com>
Reviewed-by: Gunes Bayir <gunes.bayir@arm.com>
Comments-Addressed: Arm Jenkins <bsgcomp@arm.com>
Benchmark: Arm Jenkins <bsgcomp@arm.com>
Diffstat (limited to 'compute_kernel_writer/include/ckw/Error.h')
-rw-r--r-- | compute_kernel_writer/include/ckw/Error.h | 65 |
1 files changed, 62 insertions, 3 deletions
diff --git a/compute_kernel_writer/include/ckw/Error.h b/compute_kernel_writer/include/ckw/Error.h index 2793791802..100bdc48fe 100644 --- a/compute_kernel_writer/include/ckw/Error.h +++ b/compute_kernel_writer/include/ckw/Error.h @@ -21,8 +21,8 @@ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ -#ifndef COMPUTE_KERNEL_WRITER_INCLUDE_CKW_ERROR_H -#define COMPUTE_KERNEL_WRITER_INCLUDE_CKW_ERROR_H +#ifndef CKW_INCLUDE_CKW_ERROR_H +#define CKW_INCLUDE_CKW_ERROR_H #include <stdexcept> #include <string> @@ -55,6 +55,65 @@ create_error_msg(const std::string &file, const std::string &func, const std::st std::runtime_error(create_error_msg(arg0, arg1, arg2, arg3)); \ } while(false) +/** Mark the variables as unused. + * + * @param[in] ... Variables which are unused. + */ +#define CKW_UNUSED(...) ckw::ignore_unused(__VA_ARGS__) // NOLINT + +/** Mark the variables as unused. + * + * @param[in] ... Variables which are unused. + */ +template <typename... T> +inline void ignore_unused(T &&...) +{ +} + +/** Throw an std::runtime_error with the specified message. + * + * @param[in] msg The error message. + */ +#define CKW_THROW_MSG(msg) \ + do \ + { \ + const std::string file(__FILE__); \ + const std::string func(__func__); \ + const std::string line(std::to_string(__LINE__)); \ + const std::string message(msg); \ + \ + throw std::runtime_error(ckw::create_error_msg(file, func, line, message)); \ + } while(false) + +#ifdef COMPUTE_KERNEL_WRITER_ASSERTS_ENABLED + +/** If the condition is not met, throw an std::runtime_error with the specified message. + * + * @param[in] cond The condition that is expected to be true. + * @param[in] msg The error message when the condition is not met. + */ +#define CKW_ASSERT_MSG(cond, msg) \ + do \ + { \ + if(!(cond)) \ + { \ + CKW_THROW_MSG(msg); \ + } \ + } while(false) + +/** If the condition is not met, throw an std::runtime_error. + * + * @param[in] cond The condition that is expected to be true. + */ +#define CKW_ASSERT(cond) CKW_ASSERT_MSG(cond, #cond) + +#else // COMPUTE_KERNEL_WRITER_ASSERTS_ENABLED + +#define CKW_ASSERT_MSG(cond, msg) +#define CKW_ASSERT(cond) + +#endif // COMPUTE_KERNEL_WRITER_ASSERTS_ENABLED + } // namespace ckw -#endif /* COMPUTE_KERNEL_WRITER_INCLUDE_CKW_ERROR_H */ +#endif // CKW_INCLUDE_CKW_ERROR_H |