1ad2056f2SAlexander Leidinger /* $NetBSD: linux_futex.h,v 1.2 2005/12/11 12:20:19 christos Exp $ */ 2ad2056f2SAlexander Leidinger 3ad2056f2SAlexander Leidinger /*- 47f2d13d6SPedro F. Giffuni * SPDX-License-Identifier: BSD-4-Clause 57f2d13d6SPedro F. Giffuni * 6ad2056f2SAlexander Leidinger * Copyright (c) 2005 Emmanuel Dreyfus, all rights reserved. 7ad2056f2SAlexander Leidinger * 8ad2056f2SAlexander Leidinger * Redistribution and use in source and binary forms, with or without 9ad2056f2SAlexander Leidinger * modification, are permitted provided that the following conditions 10ad2056f2SAlexander Leidinger * are met: 11ad2056f2SAlexander Leidinger * 1. Redistributions of source code must retain the above copyright 12ad2056f2SAlexander Leidinger * notice, this list of conditions and the following disclaimer. 13ad2056f2SAlexander Leidinger * 2. Redistributions in binary form must reproduce the above copyright 14ad2056f2SAlexander Leidinger * notice, this list of conditions and the following disclaimer in the 15ad2056f2SAlexander Leidinger * documentation and/or other materials provided with the distribution. 16ad2056f2SAlexander Leidinger * 3. All advertising materials mentioning features or use of this software 17ad2056f2SAlexander Leidinger * must display the following acknowledgement: 18ad2056f2SAlexander Leidinger * This product includes software developed by Emmanuel Dreyfus 19ad2056f2SAlexander Leidinger * 4. The name of the author may not be used to endorse or promote 20ad2056f2SAlexander Leidinger * products derived from this software without specific prior written 21ad2056f2SAlexander Leidinger * permission. 22ad2056f2SAlexander Leidinger * 23ad2056f2SAlexander Leidinger * THIS SOFTWARE IS PROVIDED BY THE THE AUTHOR AND CONTRIBUTORS ``AS IS'' 24ad2056f2SAlexander Leidinger * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 25ad2056f2SAlexander Leidinger * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 26ad2056f2SAlexander Leidinger * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS 27ad2056f2SAlexander Leidinger * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 28ad2056f2SAlexander Leidinger * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 29ad2056f2SAlexander Leidinger * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 30ad2056f2SAlexander Leidinger * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 31ad2056f2SAlexander Leidinger * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 32ad2056f2SAlexander Leidinger * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 33ad2056f2SAlexander Leidinger * POSSIBILITY OF SUCH DAMAGE. 34ad2056f2SAlexander Leidinger */ 35ad2056f2SAlexander Leidinger 36ad2056f2SAlexander Leidinger #ifndef _LINUX_FUTEX_H 37ad2056f2SAlexander Leidinger #define _LINUX_FUTEX_H 38ad2056f2SAlexander Leidinger 39ad2056f2SAlexander Leidinger #define LINUX_FUTEX_WAIT 0 40ad2056f2SAlexander Leidinger #define LINUX_FUTEX_WAKE 1 41b41a7787SDmitry Chagin #define LINUX_FUTEX_FD 2 /* unused */ 42ad2056f2SAlexander Leidinger #define LINUX_FUTEX_REQUEUE 3 43ad2056f2SAlexander Leidinger #define LINUX_FUTEX_CMP_REQUEUE 4 44ad2056f2SAlexander Leidinger #define LINUX_FUTEX_WAKE_OP 5 456af82123SRoman Divacky #define LINUX_FUTEX_LOCK_PI 6 466af82123SRoman Divacky #define LINUX_FUTEX_UNLOCK_PI 7 476af82123SRoman Divacky #define LINUX_FUTEX_TRYLOCK_PI 8 48be44a97cSAlexander Leidinger #define LINUX_FUTEX_WAIT_BITSET 9 4951637623SDmitry Chagin #define LINUX_FUTEX_WAKE_BITSET 10 50be44a97cSAlexander Leidinger #define LINUX_FUTEX_WAIT_REQUEUE_PI 11 5178ec1867SDmitry Chagin #define LINUX_FUTEX_CMP_REQUEUE_PI 12 52a9bb1b1cSDmitry Chagin #define LINUX_FUTEX_LOCK_PI2 13 536af82123SRoman Divacky 546af82123SRoman Divacky #define LINUX_FUTEX_PRIVATE_FLAG 128 55be44a97cSAlexander Leidinger #define LINUX_FUTEX_CLOCK_REALTIME 256 56ad2056f2SAlexander Leidinger 572e46d0c3SDmitry Chagin #define LINUX_FUTEX_CMD_MASK ~(LINUX_FUTEX_PRIVATE_FLAG | \ 582e46d0c3SDmitry Chagin LINUX_FUTEX_CLOCK_REALTIME) 592e46d0c3SDmitry Chagin 60ad2056f2SAlexander Leidinger #define FUTEX_OP_SET 0 /* *(int *)UADDR2 = OPARG; */ 61ad2056f2SAlexander Leidinger #define FUTEX_OP_ADD 1 /* *(int *)UADDR2 += OPARG; */ 62ad2056f2SAlexander Leidinger #define FUTEX_OP_OR 2 /* *(int *)UADDR2 |= OPARG; */ 63ad2056f2SAlexander Leidinger #define FUTEX_OP_ANDN 3 /* *(int *)UADDR2 &= ~OPARG; */ 64ad2056f2SAlexander Leidinger #define FUTEX_OP_XOR 4 /* *(int *)UADDR2 ^= OPARG; */ 65ad2056f2SAlexander Leidinger 66ad2056f2SAlexander Leidinger #define FUTEX_OP_OPARG_SHIFT 8 /* Use (1 << OPARG) instead of OPARG. */ 67ad2056f2SAlexander Leidinger 68ad2056f2SAlexander Leidinger #define FUTEX_OP_CMP_EQ 0 /* if (oldval == CMPARG) wake */ 69ad2056f2SAlexander Leidinger #define FUTEX_OP_CMP_NE 1 /* if (oldval != CMPARG) wake */ 70ad2056f2SAlexander Leidinger #define FUTEX_OP_CMP_LT 2 /* if (oldval < CMPARG) wake */ 71ad2056f2SAlexander Leidinger #define FUTEX_OP_CMP_LE 3 /* if (oldval <= CMPARG) wake */ 72ad2056f2SAlexander Leidinger #define FUTEX_OP_CMP_GT 4 /* if (oldval > CMPARG) wake */ 73ad2056f2SAlexander Leidinger #define FUTEX_OP_CMP_GE 5 /* if (oldval >= CMPARG) wake */ 74ad2056f2SAlexander Leidinger 754732e446SRoman Divacky #define FUTEX_WAITERS 0x80000000 764732e446SRoman Divacky #define FUTEX_OWNER_DIED 0x40000000 774732e446SRoman Divacky #define FUTEX_TID_MASK 0x3fffffff 7851637623SDmitry Chagin #define FUTEX_BITSET_MATCH_ANY 0xffffffff 794732e446SRoman Divacky 80*575e48f1SDmitry Chagin /* robust futexes */ 81*575e48f1SDmitry Chagin struct linux_robust_list { 82*575e48f1SDmitry Chagin l_uintptr_t next; 83*575e48f1SDmitry Chagin }; 84*575e48f1SDmitry Chagin 85*575e48f1SDmitry Chagin struct linux_robust_list_head { 86*575e48f1SDmitry Chagin struct linux_robust_list list; 87*575e48f1SDmitry Chagin l_long futex_offset; 88*575e48f1SDmitry Chagin l_uintptr_t pending_list; 89*575e48f1SDmitry Chagin }; 90*575e48f1SDmitry Chagin 910cde66afSKonstantin Belousov int futex_xchgl(int oparg, uint32_t *uaddr, int *oldval); 920cde66afSKonstantin Belousov int futex_addl(int oparg, uint32_t *uaddr, int *oldval); 930cde66afSKonstantin Belousov int futex_orl(int oparg, uint32_t *uaddr, int *oldval); 940cde66afSKonstantin Belousov int futex_andl(int oparg, uint32_t *uaddr, int *oldval); 950cde66afSKonstantin Belousov int futex_xorl(int oparg, uint32_t *uaddr, int *oldval); 960dc38e33SDmitry Chagin int futex_wake(struct thread *td, uint32_t *uaddr, int val, bool shared); 9781338031SDmitry Chagin void release_futexes(struct thread *, 9881338031SDmitry Chagin struct linux_emuldata *); 994732e446SRoman Divacky 100ad2056f2SAlexander Leidinger #endif /* !_LINUX_FUTEX_H */ 101