10a4b664aSDmitry Chagin /*- 2*c47116e9SDmitry Chagin * SPDX-License-Identifier: BSD-2-Clause 3*c47116e9SDmitry Chagin * 40a4b664aSDmitry Chagin * Copyright (c) 2021 Dmitry Chagin <dchagin@FreeBSD.org> 50a4b664aSDmitry Chagin * 60a4b664aSDmitry Chagin * Redistribution and use in source and binary forms, with or without 70a4b664aSDmitry Chagin * modification, are permitted provided that the following conditions 80a4b664aSDmitry Chagin * are met: 90a4b664aSDmitry Chagin * 1. Redistributions of source code must retain the above copyright 100a4b664aSDmitry Chagin * notice, this list of conditions and the following disclaimer. 110a4b664aSDmitry Chagin * 2. Redistributions in binary form must reproduce the above copyright 120a4b664aSDmitry Chagin * notice, this list of conditions and the following disclaimer in the 130a4b664aSDmitry Chagin * documentation and/or other materials provided with the distribution. 140a4b664aSDmitry Chagin * 150a4b664aSDmitry Chagin * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 160a4b664aSDmitry Chagin * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 170a4b664aSDmitry Chagin * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 180a4b664aSDmitry Chagin * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 190a4b664aSDmitry Chagin * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 200a4b664aSDmitry Chagin * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 210a4b664aSDmitry Chagin * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 220a4b664aSDmitry Chagin * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 230a4b664aSDmitry Chagin * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 240a4b664aSDmitry Chagin * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 250a4b664aSDmitry Chagin * SUCH DAMAGE. 260a4b664aSDmitry Chagin */ 270a4b664aSDmitry Chagin 280a4b664aSDmitry Chagin #ifndef _LINUX_FORK_H_ 290a4b664aSDmitry Chagin #define _LINUX_FORK_H_ 300a4b664aSDmitry Chagin 310a4b664aSDmitry Chagin #define LINUX_CLONE_VM 0x00000100 320a4b664aSDmitry Chagin #define LINUX_CLONE_FS 0x00000200 330a4b664aSDmitry Chagin #define LINUX_CLONE_FILES 0x00000400 340a4b664aSDmitry Chagin #define LINUX_CLONE_SIGHAND 0x00000800 35a796845dSDmitry Chagin #define LINUX_CLONE_PIDFD 0x00001000 /* since Linux 5.2 */ 360a4b664aSDmitry Chagin #define LINUX_CLONE_PTRACE 0x00002000 370a4b664aSDmitry Chagin #define LINUX_CLONE_VFORK 0x00004000 380a4b664aSDmitry Chagin #define LINUX_CLONE_PARENT 0x00008000 390a4b664aSDmitry Chagin #define LINUX_CLONE_THREAD 0x00010000 400a4b664aSDmitry Chagin #define LINUX_CLONE_NEWNS 0x00020000 /* New mount NS */ 410a4b664aSDmitry Chagin #define LINUX_CLONE_SYSVSEM 0x00040000 420a4b664aSDmitry Chagin #define LINUX_CLONE_SETTLS 0x00080000 430a4b664aSDmitry Chagin #define LINUX_CLONE_PARENT_SETTID 0x00100000 440a4b664aSDmitry Chagin #define LINUX_CLONE_CHILD_CLEARTID 0x00200000 450a4b664aSDmitry Chagin #define LINUX_CLONE_DETACHED 0x00400000 /* Unused */ 460a4b664aSDmitry Chagin #define LINUX_CLONE_UNTRACED 0x00800000 470a4b664aSDmitry Chagin #define LINUX_CLONE_CHILD_SETTID 0x01000000 480a4b664aSDmitry Chagin #define LINUX_CLONE_NEWCGROUP 0x02000000 /* New cgroup NS */ 490a4b664aSDmitry Chagin #define LINUX_CLONE_NEWUTS 0x04000000 500a4b664aSDmitry Chagin #define LINUX_CLONE_NEWIPC 0x08000000 510a4b664aSDmitry Chagin #define LINUX_CLONE_NEWUSER 0x10000000 520a4b664aSDmitry Chagin #define LINUX_CLONE_NEWPID 0x20000000 530a4b664aSDmitry Chagin #define LINUX_CLONE_NEWNET 0x40000000 540a4b664aSDmitry Chagin #define LINUX_CLONE_IO 0x80000000 550a4b664aSDmitry Chagin 5617913b0bSDmitry Chagin /* Flags for the clone3() syscall. */ 5717913b0bSDmitry Chagin #define LINUX_CLONE_CLEAR_SIGHAND 0x100000000ULL 5817913b0bSDmitry Chagin #define LINUX_CLONE_INTO_CGROUP 0x200000000ULL 5917913b0bSDmitry Chagin #define LINUX_CLONE_NEWTIME 0x00000080 6017913b0bSDmitry Chagin 6117913b0bSDmitry Chagin #define LINUX_CLONE_LEGACY_FLAGS 0xffffffffULL 6217913b0bSDmitry Chagin 630a4b664aSDmitry Chagin #define LINUX_CSIGNAL 0x000000ff 640a4b664aSDmitry Chagin 653f1bfc13SDmitry Chagin #if defined(_KERNEL) 660a4b664aSDmitry Chagin /* 670a4b664aSDmitry Chagin * User-space clone3 args layout. 680a4b664aSDmitry Chagin */ 690a4b664aSDmitry Chagin struct l_user_clone_args { 700a4b664aSDmitry Chagin uint64_t flags; 710a4b664aSDmitry Chagin uint64_t pidfd; 720a4b664aSDmitry Chagin uint64_t child_tid; 730a4b664aSDmitry Chagin uint64_t parent_tid; 740a4b664aSDmitry Chagin uint64_t exit_signal; 750a4b664aSDmitry Chagin uint64_t stack; 760a4b664aSDmitry Chagin uint64_t stack_size; 770a4b664aSDmitry Chagin uint64_t tls; 780a4b664aSDmitry Chagin uint64_t set_tid; 790a4b664aSDmitry Chagin uint64_t set_tid_size; 800a4b664aSDmitry Chagin uint64_t cgroup; 810a4b664aSDmitry Chagin }; 820a4b664aSDmitry Chagin 830a4b664aSDmitry Chagin /* 840a4b664aSDmitry Chagin * Kernel clone3 args layout. 850a4b664aSDmitry Chagin */ 860a4b664aSDmitry Chagin struct l_clone_args { 870a4b664aSDmitry Chagin uint64_t flags; 880a4b664aSDmitry Chagin l_int *child_tid; 890a4b664aSDmitry Chagin l_int *parent_tid; 900a4b664aSDmitry Chagin l_int exit_signal; 910a4b664aSDmitry Chagin l_ulong stack; 920a4b664aSDmitry Chagin l_ulong stack_size; 930a4b664aSDmitry Chagin l_ulong tls; 940a4b664aSDmitry Chagin }; 950a4b664aSDmitry Chagin 9617913b0bSDmitry Chagin #define LINUX_CLONE_ARGS_SIZE_VER0 64 9717913b0bSDmitry Chagin 980a4b664aSDmitry Chagin int linux_set_upcall(struct thread *, register_t); 990a4b664aSDmitry Chagin int linux_set_cloned_tls(struct thread *, void *); 1000a4b664aSDmitry Chagin void linux_thread_detach(struct thread *); 1013f1bfc13SDmitry Chagin #endif /* defined(_KERNEL) */ 1020a4b664aSDmitry Chagin 1030a4b664aSDmitry Chagin #endif /* _LINUX_FORK_H_ */ 104