1 1.9 riastrad /* $NetBSD: compiler.h,v 1.9 2022/07/17 08:34:00 riastradh Exp $ */ 2 1.1 riastrad 3 1.1 riastrad /*- 4 1.1 riastrad * Copyright (c) 2018 The NetBSD Foundation, Inc. 5 1.1 riastrad * All rights reserved. 6 1.1 riastrad * 7 1.1 riastrad * This code is derived from software contributed to The NetBSD Foundation 8 1.1 riastrad * by Taylor R. Campbell. 9 1.1 riastrad * 10 1.1 riastrad * Redistribution and use in source and binary forms, with or without 11 1.1 riastrad * modification, are permitted provided that the following conditions 12 1.1 riastrad * are met: 13 1.1 riastrad * 1. Redistributions of source code must retain the above copyright 14 1.1 riastrad * notice, this list of conditions and the following disclaimer. 15 1.1 riastrad * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 riastrad * notice, this list of conditions and the following disclaimer in the 17 1.1 riastrad * documentation and/or other materials provided with the distribution. 18 1.1 riastrad * 19 1.1 riastrad * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 riastrad * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 riastrad * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 riastrad * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 riastrad * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 riastrad * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 riastrad * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 riastrad * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 riastrad * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 riastrad * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 riastrad * POSSIBILITY OF SUCH DAMAGE. 30 1.1 riastrad */ 31 1.1 riastrad 32 1.1 riastrad #ifndef _LINUX_COMPILER_H_ 33 1.1 riastrad #define _LINUX_COMPILER_H_ 34 1.1 riastrad 35 1.2 riastrad #include <sys/atomic.h> 36 1.4 riastrad #include <sys/cdefs.h> 37 1.2 riastrad 38 1.5 riastrad #include <linux/stddef.h> 39 1.5 riastrad 40 1.3 riastrad #include <asm/barrier.h> 41 1.3 riastrad 42 1.4 riastrad #define __printf __printflike 43 1.4 riastrad #define __user 44 1.4 riastrad #if __GNUC_PREREQ__(4,0) /* not sure when but this will work */ 45 1.4 riastrad #define __must_check __attribute__((warn_unused_result)) 46 1.4 riastrad #else 47 1.4 riastrad #define __must_check /* nothing */ 48 1.4 riastrad #endif 49 1.4 riastrad #define __always_unused __unused 50 1.4 riastrad #define __maybe_unused __unused 51 1.4 riastrad #define noinline __noinline 52 1.4 riastrad #define __deprecated /* nothing */ 53 1.7 riastrad #define __acquire(X) /* nothing */ 54 1.7 riastrad #define __release(X) /* nothing */ 55 1.4 riastrad 56 1.4 riastrad #define barrier() __insn_barrier() 57 1.4 riastrad #define likely(X) __predict_true(X) 58 1.4 riastrad #define unlikely(X) __predict_false(X) 59 1.6 riastrad #define __same_type(X,Y) \ 60 1.6 riastrad __builtin_types_compatible_p(__typeof__(X), __typeof__(Y)) 61 1.6 riastrad #define __must_be_array(X) \ 62 1.6 riastrad BUILD_BUG_ON_ZERO(__same_type((X), &(X)[0])) 63 1.4 riastrad 64 1.2 riastrad #define READ_ONCE(X) ({ \ 65 1.9 riastrad __insn_barrier(); \ 66 1.2 riastrad typeof(X) __read_once_tmp = (X); \ 67 1.2 riastrad membar_datadep_consumer(); \ 68 1.2 riastrad __read_once_tmp; \ 69 1.2 riastrad }) 70 1.2 riastrad 71 1.2 riastrad #define WRITE_ONCE(X, V) ({ \ 72 1.2 riastrad typeof(X) __write_once_tmp = (V); \ 73 1.9 riastrad __insn_barrier(); \ 74 1.2 riastrad (X) = __write_once_tmp; \ 75 1.9 riastrad __insn_barrier(); \ 76 1.2 riastrad __write_once_tmp; \ 77 1.2 riastrad }) 78 1.2 riastrad 79 1.3 riastrad #define smp_store_mb(X, V) do { \ 80 1.3 riastrad WRITE_ONCE(X, V); \ 81 1.3 riastrad smp_mb(); \ 82 1.3 riastrad } while (0) 83 1.3 riastrad 84 1.3 riastrad #define smp_store_release(X, V) do { \ 85 1.3 riastrad typeof(X) __smp_store_release_tmp = (V); \ 86 1.8 riastrad membar_release(); \ 87 1.3 riastrad (X) = __write_once_tmp; \ 88 1.3 riastrad } while (0) 89 1.3 riastrad 90 1.1 riastrad #endif /* _LINUX_COMPILER_H_ */ 91