blob: 30f07beddfd51b96a161248b413f385e85d93bb1 [file] [log] [blame]
/*
* Copyright (c) 2019-2020 Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 (the License); you may
* not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an AS IS BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef ETHOSU_COMMON_H
#define ETHOSU_COMMON_H
/******************************************************************************
* Includes
******************************************************************************/
#include "ethosu55_interface.h"
#include <stdio.h>
/******************************************************************************
* Defines
******************************************************************************/
// Log severity levels
#define ETHOSU_LOG_EMERG 0
#define ETHOSU_LOG_ALERT 1
#define ETHOSU_LOG_CRIT 2
#define ETHOSU_LOG_ERR 3
#define ETHOSU_LOG_WARN 4
#define ETHOSU_LOG_NOTICE 5
#define ETHOSU_LOG_INFO 6
#define ETHOSU_LOG_DEBUG 7
// Define default log severity
#ifndef ETHOSU_LOG_SEVERITY
#define ETHOSU_LOG_SEVERITY ETHOSU_LOG_WARN
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_EMERG
#define LOG_EMERG(format, ...) \
fprintf(stderr, format, ##__VA_ARGS__); \
fflush(stderr); \
exit(-1)
#else
#define LOG_EMERG(format, ...)
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_ALERT
#define LOG_ALERT(format, ...) \
fprintf(stderr, format, ##__VA_ARGS__); \
fflush(stderr); \
exit(-1)
#else
#define LOG_ALERT(format, ...)
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_CRIT
#define LOG_CRIT(format, ...) \
fprintf(stderr, format, ##__VA_ARGS__); \
fflush(stderr); \
exit(-1)
#else
#define LOG_CRIT(format, ...)
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_ERR
#define LOG_ERR(format, ...) \
fprintf(stderr, format, ##__VA_ARGS__); \
fflush(stderr)
#else
#define LOG_ERR(format, ...)
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_WARN
#define LOG_WARN(format, ...) fprintf(stdout, format, ##__VA_ARGS__)
#else
#define LOG_WARN(format, ...)
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_NOTICE
#define LOG_NOTICE(format, ...) fprintf(stdout, format, ##__VA_ARGS__)
#else
#define LOG_NOTICE(format, ...)
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_INFO
#define LOG_INFO(format, ...) fprintf(stdout, format, ##__VA_ARGS__)
#else
#define LOG_INFO(format, ...)
#endif
#if ETHOSU_LOG_SEVERITY >= ETHOSU_LOG_DEBUG
#define LOG_DEBUG(format, ...) fprintf(stdout, format, ##__VA_ARGS__)
#else
#define LOG_DEBUG(format, ...)
#endif
#if defined(ASSERT_DISABLE)
#define ASSERT(args)
#else
#define ASSERT(args) assert(args)
#endif
#define UNUSED(x) ((void)x)
#define VER_STR(X) VNUM_STR(X)
#define VNUM_STR(X) #X
#define MASK_0_31_BITS (0xFFFFFFFF)
#define MASK_32_47_BITS (0xFFFF00000000)
/******************************************************************************
* Inline functions
******************************************************************************/
static const __attribute__((section("npu_driver_version"))) char driver_version_str[] = VER_STR(
ETHOSU_DRIVER_VERSION_MAJOR) "." VER_STR(ETHOSU_DRIVER_VERSION_MINOR) "." VER_STR(ETHOSU_DRIVER_VERSION_PATCH);
static const __attribute__((section("npu_driver_arch_version"))) char driver_arch_version_str[] =
VER_STR(NNX_ARCH_VERSION_MAJOR) "." VER_STR(NNX_ARCH_VERSION_MINOR) "." VER_STR(NNX_ARCH_VERSION_PATCH);
#endif // ETHOSU_COMMON_H