18a272653SPeter Holm#!/bin/sh 28a272653SPeter Holm 38a272653SPeter Holm# 48a272653SPeter Holm# Copyright (c) 2009 Peter Holm <pho@FreeBSD.org> 58a272653SPeter Holm# All rights reserved. 68a272653SPeter Holm# 78a272653SPeter Holm# Redistribution and use in source and binary forms, with or without 88a272653SPeter Holm# modification, are permitted provided that the following conditions 98a272653SPeter Holm# are met: 108a272653SPeter Holm# 1. Redistributions of source code must retain the above copyright 118a272653SPeter Holm# notice, this list of conditions and the following disclaimer. 128a272653SPeter Holm# 2. Redistributions in binary form must reproduce the above copyright 138a272653SPeter Holm# notice, this list of conditions and the following disclaimer in the 148a272653SPeter Holm# documentation and/or other materials provided with the distribution. 158a272653SPeter Holm# 168a272653SPeter Holm# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 178a272653SPeter Holm# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 188a272653SPeter Holm# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 198a272653SPeter Holm# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 208a272653SPeter Holm# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 218a272653SPeter Holm# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 228a272653SPeter Holm# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 238a272653SPeter Holm# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 248a272653SPeter Holm# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 258a272653SPeter Holm# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 268a272653SPeter Holm# SUCH DAMAGE. 278a272653SPeter Holm# 288a272653SPeter Holm 298a272653SPeter Holm# Variation of the datamove.sh scenario by not using "sysctl vm.old_msync=1" 308a272653SPeter Holm 318a272653SPeter Holm# Deadlock seen: 328a272653SPeter Holm# https://people.freebsd.org/~pho/stress/log/numa042.txt 338a272653SPeter Holm 348a272653SPeter Holm# Test scenario by ups 358a272653SPeter Holm 368a272653SPeter Holm. ../default.cfg 378a272653SPeter Holm 388a272653SPeter Holmhere=`pwd` 398a272653SPeter Holmcd /tmp 408a272653SPeter Holmsed '1,/^EOF/d' < $here/$0 > datamove2.c 418a272653SPeter Holmmycc -o datamove2 -Wall datamove2.c 428a272653SPeter Holmrm -f datamove2.c 438a272653SPeter Holm 448a272653SPeter Holmfor i in `jot 2`; do 458a272653SPeter Holm $here/../testcases/swap/swap -t 5m -i 100 -h & 468a272653SPeter Holm sleep 1 478a272653SPeter Holm /tmp/datamove2 || { echo FAIL; r=1; } 488a272653SPeter Holm while pkill -9 swap; do :; done 498a272653SPeter Holm [ -n "$r" ] && break 508a272653SPeter Holmdone 518a272653SPeter Holmrm -rf /tmp/datamove2 528a272653SPeter Holmexit $r 538a272653SPeter HolmEOF 548a272653SPeter Holm/*- 558a272653SPeter Holm * Copyright (c) 2006, Stephan Uphoff <ups@freebsd.org> 568a272653SPeter Holm * All rights reserved. 578a272653SPeter Holm * 588a272653SPeter Holm * Redistribution and use in source and binary forms, with or without 598a272653SPeter Holm * modification, are permitted provided that the following conditions 608a272653SPeter Holm * are met: 618a272653SPeter Holm * 1. Redistributions of source code must retain the above copyright 628a272653SPeter Holm * notice unmodified, this list of conditions, and the following 638a272653SPeter Holm * disclaimer. 648a272653SPeter Holm * 2. Redistributions in binary form must reproduce the above copyright 658a272653SPeter Holm * notice, this list of conditions and the following disclaimer in the 668a272653SPeter Holm * documentation and/or other materials provided with the distribution. 678a272653SPeter Holm * 688a272653SPeter Holm * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 698a272653SPeter Holm * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 708a272653SPeter Holm * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 718a272653SPeter Holm * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 728a272653SPeter Holm * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 738a272653SPeter Holm * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 748a272653SPeter Holm * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 758a272653SPeter Holm * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 768a272653SPeter Holm * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 778a272653SPeter Holm * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 788a272653SPeter Holm */ 798a272653SPeter Holm 808a272653SPeter Holm#include <err.h> 818a272653SPeter Holm#include <fcntl.h> 828a272653SPeter Holm#include <stdio.h> 838a272653SPeter Holm#include <stdlib.h> 848a272653SPeter Holm#include <sys/mman.h> 858a272653SPeter Holm#include <sys/stat.h> 868a272653SPeter Holm#include <sys/types.h> 878a272653SPeter Holm#include <sys/wait.h> 888a272653SPeter Holm#include <unistd.h> 898a272653SPeter Holm 908a272653SPeter Holmint prepareFile(char *filename, int *fdp); 918a272653SPeter Holmint mapBuffer (char **bufferp, int fd1, int fd2); 928a272653SPeter Holmint startIO (int fd, char *buffer); 938a272653SPeter Holm 948a272653SPeter Holmint pagesize; 958a272653SPeter Holm 968a272653SPeter Holm#define FILESIZE (32*1024) 978a272653SPeter Holmchar wbuffer [FILESIZE]; 988a272653SPeter Holm 998a272653SPeter Holm/* Create a FILESIZE sized file - then remove file data from the cache */ 1008a272653SPeter Holmint 1018a272653SPeter HolmprepareFile(char *filename, int *fdp) 1028a272653SPeter Holm{ 1038a272653SPeter Holm int fd; 1048a272653SPeter Holm int len; 1058a272653SPeter Holm int status; 1068a272653SPeter Holm void *addr; 1078a272653SPeter Holm 1088a272653SPeter Holm fd = open(filename, O_CREAT | O_TRUNC | O_RDWR, S_IRWXU); 1098a272653SPeter Holm if (fd == -1) { 1108a272653SPeter Holm perror("Creating file"); 1118a272653SPeter Holm return fd; 1128a272653SPeter Holm } 1138a272653SPeter Holm len = write(fd, wbuffer, FILESIZE); 1148a272653SPeter Holm if (len < 0) { 1158a272653SPeter Holm perror("Write failed"); 1168a272653SPeter Holm return 1; 1178a272653SPeter Holm } 1188a272653SPeter Holm status = fsync(fd); 1198a272653SPeter Holm if (status != 0) { 1208a272653SPeter Holm perror("fsync failed"); 1218a272653SPeter Holm return 1; 1228a272653SPeter Holm } 1238a272653SPeter Holm addr = mmap(NULL, FILESIZE, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); 1248a272653SPeter Holm if (addr == MAP_FAILED) { 1258a272653SPeter Holm perror("Mmap failed"); 1268a272653SPeter Holm return 1; 1278a272653SPeter Holm } 1288a272653SPeter Holm status = msync(addr, FILESIZE, MS_INVALIDATE | MS_SYNC); 1298a272653SPeter Holm if (status != 0) { 1308a272653SPeter Holm perror("Msync failed"); 1318a272653SPeter Holm return 1; 1328a272653SPeter Holm } 1338a272653SPeter Holm if (munmap(addr, FILESIZE) == -1) { 1348a272653SPeter Holm perror("munmap failed"); 1358a272653SPeter Holm return 1; 1368a272653SPeter Holm } 1378a272653SPeter Holm 1388a272653SPeter Holm *fdp = fd; 1398a272653SPeter Holm return 0; 1408a272653SPeter Holm} 1418a272653SPeter Holm 1428a272653SPeter Holm/* mmap a 2 page buffer - first page is from fd1, second page from fd2 */ 1438a272653SPeter Holmint 1448a272653SPeter HolmmapBuffer(char **bufferp, int fd1, int fd2) 1458a272653SPeter Holm{ 1468a272653SPeter Holm void *addr; 1478a272653SPeter Holm char *buffer; 1488a272653SPeter Holm 1498a272653SPeter Holm addr = mmap(NULL, pagesize * 2, PROT_READ | PROT_WRITE, MAP_SHARED, fd1, 0); 1508a272653SPeter Holm if (addr == MAP_FAILED) { 1518a272653SPeter Holm perror("Mmap failed"); 1528a272653SPeter Holm return 1; 1538a272653SPeter Holm } 1548a272653SPeter Holm buffer = addr; 1558a272653SPeter Holm addr = mmap(buffer + pagesize, pagesize, PROT_READ | PROT_WRITE, MAP_FIXED | 1568a272653SPeter Holm MAP_SHARED, fd2, 0); 1578a272653SPeter Holm 1588a272653SPeter Holm if (addr == MAP_FAILED) { 1598a272653SPeter Holm perror("Mmap2 failed"); 1608a272653SPeter Holm return 1; 1618a272653SPeter Holm } 1628a272653SPeter Holm *bufferp = buffer; 1638a272653SPeter Holm return 0; 1648a272653SPeter Holm} 1658a272653SPeter Holm 1668a272653SPeter Holmvoid 1678a272653SPeter HolmunmapBuffer(char *bufferp) 1688a272653SPeter Holm{ 1698a272653SPeter Holm if (munmap(bufferp, pagesize * 2) == -1) 1708a272653SPeter Holm err(1, "unmap 1. buffer"); 1718a272653SPeter Holm /* 1728a272653SPeter Holm The following unmaps something random, which could trigger: 1738a272653SPeter Holm Program received signal SIGSEGV, Segmentation fault. 1748a272653SPeter Holm free (cp=0x28070000) at /usr/src/libexec/rtld-elf/malloc.c:311 1758a272653SPeter Holm */ 1768a272653SPeter Holm 1778a272653SPeter Holm#if 0 1788a272653SPeter Holm if (munmap(bufferp + pagesize * 2, pagesize * 2) == -1) 1798a272653SPeter Holm err(1, "unmap 2. buffer"); 1808a272653SPeter Holm#endif 1818a272653SPeter Holm} 1828a272653SPeter Holm 1838a272653SPeter Holmint 1848a272653SPeter HolmstartIO(int fd, char *buffer) 1858a272653SPeter Holm{ 1868a272653SPeter Holm ssize_t len; 1878a272653SPeter Holm 1888a272653SPeter Holm len = write(fd, buffer, 2 * pagesize); 1898a272653SPeter Holm if (len == -1) { 1908a272653SPeter Holm perror("write failed"); 1918a272653SPeter Holm return 1; 1928a272653SPeter Holm } 1938a272653SPeter Holm return 0; 1948a272653SPeter Holm} 1958a272653SPeter Holm 1968a272653SPeter Holmint 197*32ded86aSPeter Holmmain(void) 1988a272653SPeter Holm{ 1998a272653SPeter Holm 2008a272653SPeter Holm int fdA, fdB, fdDelayA, fdDelayB; 2018a272653SPeter Holm int status; 2028a272653SPeter Holm int i; 2038a272653SPeter Holm char *bufferA, *bufferB; 2048a272653SPeter Holm pid_t pid; 2058a272653SPeter Holm 2068a272653SPeter Holm pagesize = getpagesize(); 2078a272653SPeter Holm 2088a272653SPeter Holm for (i = 0; i < 1000; i++) { 2098a272653SPeter Holm if ((prepareFile("A", &fdA)) 2108a272653SPeter Holm || (prepareFile("B", &fdB)) 2118a272653SPeter Holm || (prepareFile("DelayA", &fdDelayA)) 2128a272653SPeter Holm || (prepareFile("DelayB", &fdDelayB)) 2138a272653SPeter Holm || (mapBuffer(&bufferA, fdDelayA, fdB)) 2148a272653SPeter Holm || (mapBuffer(&bufferB, fdDelayB, fdA))) 2158a272653SPeter Holm exit(1); 2168a272653SPeter Holm 2178a272653SPeter Holm pid = fork(); 2188a272653SPeter Holm 2198a272653SPeter Holm if (pid == 0) { 2208a272653SPeter Holm status = startIO(fdA, bufferA); 2218a272653SPeter Holm exit(status); 2228a272653SPeter Holm } 2238a272653SPeter Holm if (pid == -1) { 2248a272653SPeter Holm perror("fork"); 2258a272653SPeter Holm exit(1); 2268a272653SPeter Holm } 2278a272653SPeter Holm status = startIO(fdB, bufferB); 2288a272653SPeter Holm if (wait(&status) == -1) 2298a272653SPeter Holm err(1, "wait"); 2308a272653SPeter Holm 2318a272653SPeter Holm close(fdA); 2328a272653SPeter Holm close(fdB); 2338a272653SPeter Holm close(fdDelayA); 2348a272653SPeter Holm close(fdDelayB); 2358a272653SPeter Holm unmapBuffer(bufferA); 2368a272653SPeter Holm unmapBuffer(bufferB); 2378a272653SPeter Holm unlink("A"); 2388a272653SPeter Holm unlink("B"); 2398a272653SPeter Holm unlink("DelayA"); 2408a272653SPeter Holm unlink("DelayB"); 2418a272653SPeter Holm } 2428a272653SPeter Holm exit(status); 2438a272653SPeter Holm 2448a272653SPeter Holm} 245