1ad2056f2SAlexander Leidinger /*- 2023b850bSEd Maste * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 37f2d13d6SPedro F. Giffuni * 4ad2056f2SAlexander Leidinger * Copyright (c) 2006 Roman Divacky 5ad2056f2SAlexander Leidinger * All rights reserved. 61ca6b15bSDmitry Chagin * Copyright (c) 2013 Dmitry Chagin <dchagin@FreeBSD.org> 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 12023b850bSEd Maste * 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 * 17023b850bSEd Maste * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 18023b850bSEd Maste * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19023b850bSEd Maste * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20023b850bSEd Maste * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 21023b850bSEd Maste * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22023b850bSEd Maste * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23023b850bSEd Maste * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24023b850bSEd Maste * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25023b850bSEd Maste * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26023b850bSEd Maste * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27023b850bSEd Maste * SUCH DAMAGE. 28ad2056f2SAlexander Leidinger * 29ad2056f2SAlexander Leidinger * $FreeBSD$ 30ad2056f2SAlexander Leidinger */ 31ad2056f2SAlexander Leidinger 32ad2056f2SAlexander Leidinger #ifndef _LINUX_EMUL_H_ 33ad2056f2SAlexander Leidinger #define _LINUX_EMUL_H_ 34ad2056f2SAlexander Leidinger 35d49fb289SEdward Tomasz Napierala struct image_params; 36447636e4SEdward Tomasz Napierala struct note_info_list; 37447636e4SEdward Tomasz Napierala 38447636e4SEdward Tomasz Napierala /* Linux core notes are labeled "CORE" */ 39447636e4SEdward Tomasz Napierala #define LINUX_ABI_VENDOR "CORE" 40d49fb289SEdward Tomasz Napierala 410eef2f8aSAlexander Leidinger /* 420eef2f8aSAlexander Leidinger * modeled after similar structure in NetBSD 43ad2056f2SAlexander Leidinger * this will be extended as we need more functionality 44ad2056f2SAlexander Leidinger */ 45ad2056f2SAlexander Leidinger struct linux_emuldata { 46ad2056f2SAlexander Leidinger int *child_set_tid; /* in clone(): Child's TID to set on clone */ 47ad2056f2SAlexander Leidinger int *child_clear_tid;/* in clone(): Child's TID to clear on exit */ 48ad2056f2SAlexander Leidinger 49bc273677SDmitry Chagin int flags; /* thread emuldata flags */ 5081338031SDmitry Chagin int em_tid; /* thread id */ 51955d762aSAlexander Leidinger 524732e446SRoman Divacky struct linux_robust_list_head *robust_futexes; 53ad2056f2SAlexander Leidinger }; 54ad2056f2SAlexander Leidinger 5581338031SDmitry Chagin struct linux_emuldata *em_find(struct thread *); 56ad2056f2SAlexander Leidinger 57b267239dSEd Maste int linux_exec_imgact_try(struct image_params *); 580a4b664aSDmitry Chagin void linux_proc_init(struct thread *, struct thread *, bool); 594815f175SKonstantin Belousov void linux_on_exit(struct proc *); 60e5d81ef1SDmitry Chagin void linux_schedtail(struct thread *); 614815f175SKonstantin Belousov void linux_on_exec(struct proc *, struct image_params *); 624815f175SKonstantin Belousov void linux_thread_dtor(struct thread *); 6381338031SDmitry Chagin int linux_common_execve(struct thread *, struct image_args *); 64447636e4SEdward Tomasz Napierala void linux32_prepare_notes(struct thread *, struct note_info_list *, size_t *); 65447636e4SEdward Tomasz Napierala void linux64_prepare_notes(struct thread *, struct note_info_list *, size_t *); 6694cb2ecfSAlexander Leidinger 67bc273677SDmitry Chagin /* process emuldata flags */ 68bc273677SDmitry Chagin #define LINUX_XDEPR_REQUEUEOP 0x00000001 /* uses deprecated 69bc273677SDmitry Chagin futex REQUEUE op*/ 70e16fe1c7SDmitry Chagin #define LINUX_XUNSUP_EPOLL 0x00000002 /* unsupported epoll events */ 715dd1d097SDmitry Chagin #define LINUX_XUNSUP_FUTEXPIOP 0x00000004 /* uses unsupported pi futex */ 72e16fe1c7SDmitry Chagin 73bc273677SDmitry Chagin struct linux_pemuldata { 74bc273677SDmitry Chagin uint32_t flags; /* process emuldata flags */ 75bc273677SDmitry Chagin struct sx pem_sx; /* lock for this struct */ 7623e8912cSDmitry Chagin uint32_t persona; /* process execution domain */ 77d49fb289SEdward Tomasz Napierala uint32_t ptrace_flags; /* used by ptrace(2) */ 78b7df7b98SDmitry Chagin uint32_t oom_score_adj; /* /proc/self/oom_score_adj */ 79*0e26e54bSDmitry Chagin uint32_t so_timestamp; /* requested timeval */ 80bc273677SDmitry Chagin }; 81bc273677SDmitry Chagin 82bc273677SDmitry Chagin #define LINUX_PEM_XLOCK(p) sx_xlock(&(p)->pem_sx) 83bc273677SDmitry Chagin #define LINUX_PEM_XUNLOCK(p) sx_xunlock(&(p)->pem_sx) 84bc273677SDmitry Chagin #define LINUX_PEM_SLOCK(p) sx_slock(&(p)->pem_sx) 85bc273677SDmitry Chagin #define LINUX_PEM_SUNLOCK(p) sx_sunlock(&(p)->pem_sx) 86bc273677SDmitry Chagin 87bc273677SDmitry Chagin struct linux_pemuldata *pem_find(struct proc *); 88bc273677SDmitry Chagin 89ad2056f2SAlexander Leidinger #endif /* !_LINUX_EMUL_H_ */ 90