1*8a272653SPeter Holm#!/bin/sh 2*8a272653SPeter Holm 3*8a272653SPeter Holm# 4*8a272653SPeter Holm# Copyright (c) 2012 Peter Holm <pho@FreeBSD.org> 5*8a272653SPeter Holm# All rights reserved. 6*8a272653SPeter Holm# 7*8a272653SPeter Holm# Redistribution and use in source and binary forms, with or without 8*8a272653SPeter Holm# modification, are permitted provided that the following conditions 9*8a272653SPeter Holm# are met: 10*8a272653SPeter Holm# 1. Redistributions of source code must retain the above copyright 11*8a272653SPeter Holm# notice, this list of conditions and the following disclaimer. 12*8a272653SPeter Holm# 2. Redistributions in binary form must reproduce the above copyright 13*8a272653SPeter Holm# notice, this list of conditions and the following disclaimer in the 14*8a272653SPeter Holm# documentation and/or other materials provided with the distribution. 15*8a272653SPeter Holm# 16*8a272653SPeter Holm# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 17*8a272653SPeter Holm# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 18*8a272653SPeter Holm# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 19*8a272653SPeter Holm# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 20*8a272653SPeter Holm# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21*8a272653SPeter Holm# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22*8a272653SPeter Holm# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23*8a272653SPeter Holm# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24*8a272653SPeter Holm# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25*8a272653SPeter Holm# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26*8a272653SPeter Holm# SUCH DAMAGE. 27*8a272653SPeter Holm# 28*8a272653SPeter Holm 29*8a272653SPeter Holm# Page fault due to recursion. Fixed in r216150. 30*8a272653SPeter Holm 31*8a272653SPeter Holm# Looping in kernel: http://people.freebsd.org/~pho/stress/log/kostik737.txt 32*8a272653SPeter Holm# Fixed in r274712 33*8a272653SPeter Holm 34*8a272653SPeter Holm. ../default.cfg 35*8a272653SPeter Holm 36*8a272653SPeter Holmhere=`pwd` 37*8a272653SPeter Holmcd /tmp 38*8a272653SPeter Holmsed '1,/^EOF/d' < $here/$0 > socketpair.c 39*8a272653SPeter Holmmycc -o socketpair -Wall -Wextra -O2 socketpair.c 40*8a272653SPeter Holmrm -f socketpair.c 41*8a272653SPeter Holm[ -d $RUNDIR ] || mkdir -p $RUNDIR 42*8a272653SPeter Holmcd $RUNDIR 43*8a272653SPeter Holm 44*8a272653SPeter Holmulimit -b 10485760 45*8a272653SPeter Holm/tmp/socketpair 46*8a272653SPeter Holm 47*8a272653SPeter Holmcd $here 48*8a272653SPeter Holmrm -f /tmp/socketpair 49*8a272653SPeter Holmexit 0 50*8a272653SPeter HolmEOF 51*8a272653SPeter Holm/* From http://lkml.org/lkml/2010/11/25/8 */ 52*8a272653SPeter Holm 53*8a272653SPeter Holm#include <errno.h> 54*8a272653SPeter Holm#include <fcntl.h> 55*8a272653SPeter Holm#include <stdio.h> 56*8a272653SPeter Holm#include <stdlib.h> 57*8a272653SPeter Holm#include <string.h> 58*8a272653SPeter Holm#include <sys/mount.h> 59*8a272653SPeter Holm#include <sys/socket.h> 60*8a272653SPeter Holm#include <sys/un.h> 61*8a272653SPeter Holm#include <sys/wait.h> 62*8a272653SPeter Holm#include <unistd.h> 63*8a272653SPeter Holm 64*8a272653SPeter Holmstatic int 65*8a272653SPeter Holmsend_fd(int unix_fd, int fd) 66*8a272653SPeter Holm{ 67*8a272653SPeter Holm struct msghdr msgh; 68*8a272653SPeter Holm struct cmsghdr *cmsg; 69*8a272653SPeter Holm char buf[CMSG_SPACE(sizeof(fd))]; 70*8a272653SPeter Holm memset(&msgh, 0, sizeof(msgh)); 71*8a272653SPeter Holm memset(buf, 0, sizeof(buf)); 72*8a272653SPeter Holm 73*8a272653SPeter Holm msgh.msg_control = buf; 74*8a272653SPeter Holm msgh.msg_controllen = sizeof(buf); 75*8a272653SPeter Holm 76*8a272653SPeter Holm cmsg = CMSG_FIRSTHDR(&msgh); 77*8a272653SPeter Holm cmsg->cmsg_len = CMSG_LEN(sizeof(fd)); 78*8a272653SPeter Holm cmsg->cmsg_level = SOL_SOCKET; 79*8a272653SPeter Holm cmsg->cmsg_type = SCM_RIGHTS; 80*8a272653SPeter Holm 81*8a272653SPeter Holm msgh.msg_controllen = cmsg->cmsg_len; 82*8a272653SPeter Holm 83*8a272653SPeter Holm memcpy(CMSG_DATA(cmsg), &fd, sizeof(fd)); 84*8a272653SPeter Holm return sendmsg(unix_fd, &msgh, 0); 85*8a272653SPeter Holm} 86*8a272653SPeter Holm 87*8a272653SPeter Holmint 88*8a272653SPeter Holmmain() 89*8a272653SPeter Holm{ 90*8a272653SPeter Holm int fd[2], ff[2]; 91*8a272653SPeter Holm 92*8a272653SPeter Holm if (socketpair(PF_UNIX, SOCK_SEQPACKET, 0, fd) == -1) 93*8a272653SPeter Holm return 1; 94*8a272653SPeter Holm for (;;) { 95*8a272653SPeter Holm if (socketpair(PF_UNIX, SOCK_SEQPACKET, 0, ff) == -1) 96*8a272653SPeter Holm return 2; 97*8a272653SPeter Holm send_fd(ff[0], fd[0]); 98*8a272653SPeter Holm send_fd(ff[0], fd[1]); 99*8a272653SPeter Holm close(fd[1]); 100*8a272653SPeter Holm close(fd[0]); 101*8a272653SPeter Holm fd[0] = ff[0]; 102*8a272653SPeter Holm fd[1] = ff[1]; 103*8a272653SPeter Holm } 104*8a272653SPeter Holm} 105