mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-19 01:07:09 +07:00
79b1b30e4c
Having a helpful compile time warning in libbpf_util.h is not a good
idea since all warnings are treated as errors. Change this into a
comment in the code instead.
Fixes: b7e3a28019
("libbpf: remove dependency on barrier.h in xsk.h")
Signed-off-by: Magnus Karlsson <magnus.karlsson@intel.com>
Acked-by: Yonghong Song <yhs@fb.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
61 lines
2.0 KiB
C
61 lines
2.0 KiB
C
/* SPDX-License-Identifier: (LGPL-2.1 OR BSD-2-Clause) */
|
|
/* Copyright (c) 2019 Facebook */
|
|
|
|
#ifndef __LIBBPF_LIBBPF_UTIL_H
|
|
#define __LIBBPF_LIBBPF_UTIL_H
|
|
|
|
#include <stdbool.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
extern void libbpf_print(enum libbpf_print_level level,
|
|
const char *format, ...)
|
|
__attribute__((format(printf, 2, 3)));
|
|
|
|
#define __pr(level, fmt, ...) \
|
|
do { \
|
|
libbpf_print(level, "libbpf: " fmt, ##__VA_ARGS__); \
|
|
} while (0)
|
|
|
|
#define pr_warning(fmt, ...) __pr(LIBBPF_WARN, fmt, ##__VA_ARGS__)
|
|
#define pr_info(fmt, ...) __pr(LIBBPF_INFO, fmt, ##__VA_ARGS__)
|
|
#define pr_debug(fmt, ...) __pr(LIBBPF_DEBUG, fmt, ##__VA_ARGS__)
|
|
|
|
/* Use these barrier functions instead of smp_[rw]mb() when they are
|
|
* used in a libbpf header file. That way they can be built into the
|
|
* application that uses libbpf.
|
|
*/
|
|
#if defined(__i386__) || defined(__x86_64__)
|
|
# define libbpf_smp_rmb() asm volatile("" : : : "memory")
|
|
# define libbpf_smp_wmb() asm volatile("" : : : "memory")
|
|
# define libbpf_smp_mb() \
|
|
asm volatile("lock; addl $0,-4(%%rsp)" : : : "memory", "cc")
|
|
/* Hinders stores to be observed before older loads. */
|
|
# define libbpf_smp_rwmb() asm volatile("" : : : "memory")
|
|
#elif defined(__aarch64__)
|
|
# define libbpf_smp_rmb() asm volatile("dmb ishld" : : : "memory")
|
|
# define libbpf_smp_wmb() asm volatile("dmb ishst" : : : "memory")
|
|
# define libbpf_smp_mb() asm volatile("dmb ish" : : : "memory")
|
|
# define libbpf_smp_rwmb() libbpf_smp_mb()
|
|
#elif defined(__arm__)
|
|
/* These are only valid for armv7 and above */
|
|
# define libbpf_smp_rmb() asm volatile("dmb ish" : : : "memory")
|
|
# define libbpf_smp_wmb() asm volatile("dmb ishst" : : : "memory")
|
|
# define libbpf_smp_mb() asm volatile("dmb ish" : : : "memory")
|
|
# define libbpf_smp_rwmb() libbpf_smp_mb()
|
|
#else
|
|
/* Architecture missing native barrier functions. */
|
|
# define libbpf_smp_rmb() __sync_synchronize()
|
|
# define libbpf_smp_wmb() __sync_synchronize()
|
|
# define libbpf_smp_mb() __sync_synchronize()
|
|
# define libbpf_smp_rwmb() __sync_synchronize()
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
|
|
#endif
|