cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

rwonce.h (812B)


      1/* SPDX-License-Identifier: GPL-2.0 */
      2/*
      3 * Copyright (C) 2019 Google LLC.
      4 */
      5#ifndef __ASM_RWONCE_H
      6#define __ASM_RWONCE_H
      7
      8#ifdef CONFIG_SMP
      9
     10#include <asm/barrier.h>
     11
     12/*
     13 * Alpha is apparently daft enough to reorder address-dependent loads
     14 * on some CPU implementations. Knock some common sense into it with
     15 * a memory barrier in READ_ONCE().
     16 *
     17 * For the curious, more information about this unusual reordering is
     18 * available in chapter 15 of the "perfbook":
     19 *
     20 *  https://kernel.org/pub/linux/kernel/people/paulmck/perfbook/perfbook.html
     21 *
     22 */
     23#define __READ_ONCE(x)							\
     24({									\
     25	__unqual_scalar_typeof(x) __x =					\
     26		(*(volatile typeof(__x) *)(&(x)));			\
     27	mb();								\
     28	(typeof(x))__x;							\
     29})
     30
     31#endif /* CONFIG_SMP */
     32
     33#include <asm-generic/rwonce.h>
     34
     35#endif /* __ASM_RWONCE_H */