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[ `id -u ` -ne 0 ] && echo "Must be root!" && exit 1 318a272653SPeter Holm. ../default.cfg 328a272653SPeter Holm 338a272653SPeter Holm# Regression test for: 348a272653SPeter Holm# Mark pages after EOF as clean after pageout. 358a272653SPeter Holm# https://reviews.freebsd.org/D11697 368a272653SPeter Holm# Committed as r321580 + r321581. 378a272653SPeter Holm 388a272653SPeter Holmdir=/tmp 398a272653SPeter Holmodir=`pwd` 408a272653SPeter Holmcd $dir 418a272653SPeter Holmsed '1,/^EOF/d' < $odir/$0 > $dir/nfs_halfpage.c 428a272653SPeter Holmmycc -o nfs_halfpage -Wall -Wextra -O0 -g nfs_halfpage.c || exit 1 438a272653SPeter Holmrm -f nfs_halfpage.c 448a272653SPeter Holmcd $odir 458a272653SPeter Holm 468a272653SPeter Holm[ -z "$nfs_export" ] && exit 0 478a272653SPeter Holmping -c 2 `echo $nfs_export | sed 's/:.*//'` > /dev/null 2>&1 || 488a272653SPeter Holm exit 0 498a272653SPeter Holm 508a272653SPeter Holmmount | grep "$mntpoint" | grep -q nfs && umount $mntpoint 518a272653SPeter Holmmount -t nfs -o tcp -o retrycnt=3 -o intr,soft -o rw $nfs_export $mntpoint 528a272653SPeter Holm 538a272653SPeter Holmfile=$mntpoint/nfs_halfpage.file 548a272653SPeter Holm/tmp/nfs_halfpage $file 558a272653SPeter Holm 568a272653SPeter Holmecho "Reboot now to trigger syncing disks loop." 578a272653SPeter Holmsleep 60 588a272653SPeter Holm 598a272653SPeter Holmrm $file 608a272653SPeter Holmfor i in `jot 6`; do 618a272653SPeter Holm mount | grep -q "on $mntpoint " || break 628a272653SPeter Holm umount $mntpoint && break || sleep 10 638a272653SPeter Holmdone 648a272653SPeter Holm[ $i -eq 6 ] && s=1 || s=0 658a272653SPeter Holmrm -f /tmp/nfs_halfpage 668a272653SPeter Holm 678a272653SPeter Holmexit $s 688a272653SPeter HolmEOF 698a272653SPeter Holm/* $Id: nfs_halfpage.c,v 1.2 2017/07/23 09:36:23 kostik Exp kostik $ */ 708a272653SPeter Holm 718a272653SPeter Holm#include <sys/fcntl.h> 728a272653SPeter Holm#include <sys/mman.h> 738a272653SPeter Holm#include <err.h> 748a272653SPeter Holm#include <unistd.h> 758a272653SPeter Holm 768a272653SPeter Holmint 778a272653SPeter Holmmain(int argc __unused, char *argv[]) 788a272653SPeter Holm{ 798a272653SPeter Holm char *m; 808a272653SPeter Holm int error, fd, pgsz, sz; 818a272653SPeter Holm 828a272653SPeter Holm pgsz = getpagesize(); 838a272653SPeter Holm fd = open(argv[1], O_RDWR | O_CREAT | O_TRUNC, 0666); 848a272653SPeter Holm if (fd == -1) 858a272653SPeter Holm err(1, "open %s", argv[1]); 868a272653SPeter Holm sz = pgsz / 4; 878a272653SPeter Holm error = lseek(fd, sz, SEEK_SET); 888a272653SPeter Holm if (error == -1) 898a272653SPeter Holm err(1, "lseek"); 908a272653SPeter Holm error = write(fd, "a", 1); 918a272653SPeter Holm if (error == -1) 928a272653SPeter Holm err(1, "write"); 938a272653SPeter Holm else if (error != 1) 948a272653SPeter Holm errx(1, "short write"); 958a272653SPeter Holm m = mmap(NULL, sz + 1, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); 968a272653SPeter Holm if (m == MAP_FAILED) 978a272653SPeter Holm err(1, "mmap"); 988a272653SPeter Holm m[0] = 'x'; 998a272653SPeter Holm} 100