/* SPDX-License-Identifier: GPL-2.0-only */ #ifndef SELFTESTS_VFIO_LIB_INCLUDE_LIBVFIO_ASSERT_H #define SELFTESTS_VFIO_LIB_INCLUDE_LIBVFIO_ASSERT_H #include #include #include #include "../../../../kselftest.h" #define VFIO_LOG_AND_EXIT(...) do { \ fprintf(stderr, " " __VA_ARGS__); \ fprintf(stderr, "\n"); \ exit(KSFT_FAIL); \ } while (0) #define VFIO_ASSERT_OP(_lhs, _rhs, _op, ...) do { \ typeof(_lhs) __lhs = (_lhs); \ typeof(_rhs) __rhs = (_rhs); \ \ if (__lhs _op __rhs) \ break; \ \ fprintf(stderr, "%s:%u: Assertion Failure\n\n", __FILE__, __LINE__); \ fprintf(stderr, " Expression: " #_lhs " " #_op " " #_rhs "\n"); \ fprintf(stderr, " Observed: %#lx %s %#lx\n", \ (u64)__lhs, #_op, (u64)__rhs); \ fprintf(stderr, " [errno: %d - %s]\n", errno, strerror(errno)); \ VFIO_LOG_AND_EXIT(__VA_ARGS__); \ } while (0) #define VFIO_ASSERT_EQ(_a, _b, ...) VFIO_ASSERT_OP(_a, _b, ==, ##__VA_ARGS__) #define VFIO_ASSERT_NE(_a, _b, ...) VFIO_ASSERT_OP(_a, _b, !=, ##__VA_ARGS__) #define VFIO_ASSERT_LT(_a, _b, ...) VFIO_ASSERT_OP(_a, _b, <, ##__VA_ARGS__) #define VFIO_ASSERT_LE(_a, _b, ...) VFIO_ASSERT_OP(_a, _b, <=, ##__VA_ARGS__) #define VFIO_ASSERT_GT(_a, _b, ...) VFIO_ASSERT_OP(_a, _b, >, ##__VA_ARGS__) #define VFIO_ASSERT_GE(_a, _b, ...) VFIO_ASSERT_OP(_a, _b, >=, ##__VA_ARGS__) #define VFIO_ASSERT_TRUE(_a, ...) VFIO_ASSERT_NE(false, (_a), ##__VA_ARGS__) #define VFIO_ASSERT_FALSE(_a, ...) VFIO_ASSERT_EQ(false, (_a), ##__VA_ARGS__) #define VFIO_ASSERT_NULL(_a, ...) VFIO_ASSERT_EQ(NULL, _a, ##__VA_ARGS__) #define VFIO_ASSERT_NOT_NULL(_a, ...) VFIO_ASSERT_NE(NULL, _a, ##__VA_ARGS__) #define VFIO_FAIL(_fmt, ...) do { \ fprintf(stderr, "%s:%u: FAIL\n\n", __FILE__, __LINE__); \ VFIO_LOG_AND_EXIT(_fmt, ##__VA_ARGS__); \ } while (0) #define ioctl_assert(_fd, _op, _arg) do { \ void *__arg = (_arg); \ int __ret = ioctl((_fd), (_op), (__arg)); \ VFIO_ASSERT_EQ(__ret, 0, "ioctl(%s, %s, %s) returned %d\n", #_fd, #_op, #_arg, __ret); \ } while (0) #endif /* SELFTESTS_VFIO_LIB_INCLUDE_LIBVFIO_ASSERT_H */