18a272653SPeter Holm#!/bin/sh 28a272653SPeter Holm 38a272653SPeter Holm# 4*4d846d26SWarner Losh# SPDX-License-Identifier: BSD-2-Clause 58a272653SPeter Holm# 68a272653SPeter Holm# Copyright (c) 2017 Konstantin Belousov <kib@FreeBSD.org> 78a272653SPeter Holm# 88a272653SPeter Holm# Redistribution and use in source and binary forms, with or without 98a272653SPeter Holm# modification, are permitted provided that the following conditions 108a272653SPeter Holm# are met: 118a272653SPeter Holm# 1. Redistributions of source code must retain the above copyright 128a272653SPeter Holm# notice, this list of conditions and the following disclaimer. 138a272653SPeter Holm# 2. Redistributions in binary form must reproduce the above copyright 148a272653SPeter Holm# notice, this list of conditions and the following disclaimer in the 158a272653SPeter Holm# documentation and/or other materials provided with the distribution. 168a272653SPeter Holm# 178a272653SPeter Holm# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 188a272653SPeter Holm# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 198a272653SPeter Holm# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 208a272653SPeter Holm# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 218a272653SPeter Holm# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 228a272653SPeter Holm# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 238a272653SPeter Holm# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 248a272653SPeter Holm# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 258a272653SPeter Holm# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 268a272653SPeter Holm# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 278a272653SPeter Holm# SUCH DAMAGE. 288a272653SPeter Holm# 298a272653SPeter Holm 308a272653SPeter Holm# Maxime Villard <max@m00nbsd.net> spotted this problem: 318a272653SPeter Holm# Issue with segment registers on freebsd-i386 328a272653SPeter Holm 338a272653SPeter Holm# Fixed in r323722 348a272653SPeter Holm 358a272653SPeter Holm[ `uname -m` = "i386" ] || exit 0 368a272653SPeter Holm 378a272653SPeter Holm. ../default.cfg 388a272653SPeter Holm 398a272653SPeter Holmcat > /tmp/mvillard_nest.c <<EOF 408a272653SPeter Holm/* $Id: mvillard_nest.c,v 1.2 2017/09/15 14:33:30 kostik Exp kostik $ */ 418a272653SPeter Holm 428a272653SPeter Holm#include <sys/types.h> 438a272653SPeter Holm#include <sys/syscall.h> 448a272653SPeter Holm#include <sys/ucontext.h> 458a272653SPeter Holm#include <machine/atomic.h> 468a272653SPeter Holm#include <machine/segments.h> 478a272653SPeter Holm#include <machine/sysarch.h> 488a272653SPeter Holm#include <err.h> 498a272653SPeter Holm#include <pthread.h> 508a272653SPeter Holm#include <signal.h> 518a272653SPeter Holm#include <time.h> 528a272653SPeter Holm#include <string.h> 538a272653SPeter Holm#include <unistd.h> 548a272653SPeter Holm 558a272653SPeter Holmstatic volatile u_int b, s; 568a272653SPeter Holm 578a272653SPeter Holmstatic void * 588a272653SPeter Holmdealloc_ldt(void *arg __unused) 598a272653SPeter Holm{ 608a272653SPeter Holm u_int sl; 618a272653SPeter Holm 628a272653SPeter Holm for (;;) { 638a272653SPeter Holm while (atomic_load_acq_int(&b) == 0) 648a272653SPeter Holm ; 658a272653SPeter Holm sl = s; 668a272653SPeter Holm s = 0; 678a272653SPeter Holm if (sl != 0) 688a272653SPeter Holm i386_set_ldt(sl, NULL, 1); 698a272653SPeter Holm atomic_store_rel_int(&b, 0); 708a272653SPeter Holm } 718a272653SPeter Holm return (NULL); 728a272653SPeter Holm} 738a272653SPeter Holm 748a272653SPeter Holmstatic void 758a272653SPeter Holmfunc(void) 768a272653SPeter Holm{ 778a272653SPeter Holm union descriptor desc; 788a272653SPeter Holm u_int sel, sl; 798a272653SPeter Holm 808a272653SPeter Holm bzero(&desc, sizeof(desc)); 818a272653SPeter Holm desc.sd.sd_type = SDT_MEMRWA; 828a272653SPeter Holm desc.sd.sd_dpl = SEL_UPL; 838a272653SPeter Holm desc.sd.sd_p = 1; 848a272653SPeter Holm desc.sd.sd_def32 = 1; 858a272653SPeter Holm desc.sd.sd_gran = 1; 868a272653SPeter Holm desc.sd.sd_lolimit = 0xffff; 878a272653SPeter Holm desc.sd.sd_hilimit = 0xf; 888a272653SPeter Holm sl = i386_set_ldt(LDT_AUTO_ALLOC, &desc, 1); 898a272653SPeter Holm if ((int)sl == -1) 908a272653SPeter Holm err(1, "i386_set_ldt"); 918a272653SPeter Holm sel = LSEL(sl, SEL_UPL); 928a272653SPeter Holm s = sl; 938a272653SPeter Holm __asm volatile("movw\t%w0,%%es" : : "r" (sel)); 948a272653SPeter Holm atomic_store_rel_int(&b, 1); 958a272653SPeter Holm while (atomic_load_acq_int(&b) != 0) 968a272653SPeter Holm ; 978a272653SPeter Holm getpid(); 988a272653SPeter Holm} 998a272653SPeter Holm 1008a272653SPeter Holmstatic void 1018a272653SPeter Holmsigsegv_handler(int signo __unused, siginfo_t *si __unused, void *rctx) 1028a272653SPeter Holm{ 1038a272653SPeter Holm ucontext_t *uc; 1048a272653SPeter Holm 1058a272653SPeter Holm uc = rctx; 1068a272653SPeter Holm uc->uc_mcontext.mc_es = uc->uc_mcontext.mc_ds; 1078a272653SPeter Holm} 1088a272653SPeter Holm 1098a272653SPeter Holmint 1108a272653SPeter Holmmain(void) 1118a272653SPeter Holm{ 1128a272653SPeter Holm pthread_t thr; 1138a272653SPeter Holm time_t start; 1148a272653SPeter Holm struct sigaction sa; 1158a272653SPeter Holm int error; 1168a272653SPeter Holm 1178a272653SPeter Holm bzero(&sa, sizeof(sa)); 1188a272653SPeter Holm sa.sa_sigaction = sigsegv_handler; 1198a272653SPeter Holm sa.sa_flags = SA_SIGINFO; 1208a272653SPeter Holm error = sigaction(SIGSEGV, &sa, NULL); 1218a272653SPeter Holm if (error != 0) 1228a272653SPeter Holm err(1, "sigaction SIGSEGV"); 1238a272653SPeter Holm error = sigaction(SIGBUS, &sa, NULL); 1248a272653SPeter Holm if (error != 0) 1258a272653SPeter Holm err(1, "sigaction SIGBUS"); 1268a272653SPeter Holm 1278a272653SPeter Holm error = pthread_create(&thr, NULL, dealloc_ldt, NULL); 1288a272653SPeter Holm if (error != 0) 1298a272653SPeter Holm errc(1, error, "pthread_create"); 1308a272653SPeter Holm 1318a272653SPeter Holm start = time(NULL); 1328a272653SPeter Holm while (time(NULL) - start < 120) 1338a272653SPeter Holm func(); 1348a272653SPeter Holm} 1358a272653SPeter HolmEOF 1368a272653SPeter Holm 1378a272653SPeter Holmmycc -o /tmp/mvillard_nest -Wall -Wextra -O2 -g /tmp/mvillard_nest.c \ 1388a272653SPeter Holm -l pthread || exit 1 1398a272653SPeter Holmrm /tmp/mvillard_nest.c 1408a272653SPeter Holm 1418a272653SPeter Holm/tmp/mvillard_nest; s=$? 1428a272653SPeter Holm 1438a272653SPeter Holmrm /tmp/mvillard_nest 1448a272653SPeter Holmexit $s 145