1d1fa59e9SXin LI /* $NetBSD: tmpfs_fifoops.c,v 1.5 2005/12/11 12:24:29 christos Exp $ */ 2d1fa59e9SXin LI 3d1fa59e9SXin LI /* 4d1fa59e9SXin LI * Copyright (c) 2005 The NetBSD Foundation, Inc. 5d1fa59e9SXin LI * All rights reserved. 6d1fa59e9SXin LI * 7d1fa59e9SXin LI * This code is derived from software contributed to The NetBSD Foundation 8d1fa59e9SXin LI * by Julio M. Merino Vidal, developed as part of Google's Summer of Code 9d1fa59e9SXin LI * 2005 program. 10d1fa59e9SXin LI * 11d1fa59e9SXin LI * Redistribution and use in source and binary forms, with or without 12d1fa59e9SXin LI * modification, are permitted provided that the following conditions 13d1fa59e9SXin LI * are met: 14d1fa59e9SXin LI * 1. Redistributions of source code must retain the above copyright 15d1fa59e9SXin LI * notice, this list of conditions and the following disclaimer. 16d1fa59e9SXin LI * 2. Redistributions in binary form must reproduce the above copyright 17d1fa59e9SXin LI * notice, this list of conditions and the following disclaimer in the 18d1fa59e9SXin LI * documentation and/or other materials provided with the distribution. 19d1fa59e9SXin LI * 3. All advertising materials mentioning features or use of this software 20d1fa59e9SXin LI * must display the following acknowledgement: 21d1fa59e9SXin LI * This product includes software developed by the NetBSD 22d1fa59e9SXin LI * Foundation, Inc. and its contributors. 23d1fa59e9SXin LI * 4. Neither the name of The NetBSD Foundation nor the names of its 24d1fa59e9SXin LI * contributors may be used to endorse or promote products derived 25d1fa59e9SXin LI * from this software without specific prior written permission. 26d1fa59e9SXin LI * 27d1fa59e9SXin LI * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 28d1fa59e9SXin LI * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 29d1fa59e9SXin LI * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 30d1fa59e9SXin LI * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 31d1fa59e9SXin LI * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 32d1fa59e9SXin LI * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 33d1fa59e9SXin LI * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 34d1fa59e9SXin LI * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 35d1fa59e9SXin LI * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 36d1fa59e9SXin LI * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 37d1fa59e9SXin LI * POSSIBILITY OF SUCH DAMAGE. 38d1fa59e9SXin LI */ 39d1fa59e9SXin LI 40d1fa59e9SXin LI /* 41d1fa59e9SXin LI * tmpfs vnode interface for named pipes. 42d1fa59e9SXin LI */ 43d1fa59e9SXin LI #include <sys/cdefs.h> 44d1fa59e9SXin LI __FBSDID("$FreeBSD$"); 45d1fa59e9SXin LI 46d1fa59e9SXin LI #include <sys/param.h> 47d1fa59e9SXin LI #include <sys/filedesc.h> 48d1fa59e9SXin LI #include <sys/proc.h> 49d1fa59e9SXin LI #include <sys/vnode.h> 50d1fa59e9SXin LI 51d1fa59e9SXin LI #include <vm/vm.h> 52d1fa59e9SXin LI #include <vm/vm_object.h> 53d1fa59e9SXin LI 54d1fa59e9SXin LI #include <fs/tmpfs/tmpfs.h> 55d1fa59e9SXin LI #include <fs/tmpfs/tmpfs_fifoops.h> 56d1fa59e9SXin LI #include <fs/tmpfs/tmpfs_vnops.h> 57d1fa59e9SXin LI 58d1fa59e9SXin LI /* --------------------------------------------------------------------- */ 59d1fa59e9SXin LI 60d1fa59e9SXin LI /* 61d1fa59e9SXin LI * vnode operations vector used for fifos stored in a tmpfs file system. 62d1fa59e9SXin LI */ 63d1fa59e9SXin LI struct vop_vector tmpfs_fifoop_entries = { 64d1fa59e9SXin LI .vop_default = &fifo_specops, 65d1fa59e9SXin LI .vop_close = tmpfs_fifo_close, 66d1fa59e9SXin LI .vop_reclaim = tmpfs_reclaim, 67d1fa59e9SXin LI .vop_access = tmpfs_access, 68d1fa59e9SXin LI .vop_getattr = tmpfs_getattr, 69d1fa59e9SXin LI .vop_setattr = tmpfs_setattr, 70d1fa59e9SXin LI .vop_kqfilter = tmpfs_fifo_kqfilter, 71d1fa59e9SXin LI }; 72d1fa59e9SXin LI 73d1fa59e9SXin LI 74d1fa59e9SXin LI int 75d1fa59e9SXin LI tmpfs_fifo_kqfilter(struct vop_kqfilter_args *ap) 76d1fa59e9SXin LI { 77d1fa59e9SXin LI struct vnode *vp; 78d1fa59e9SXin LI struct tmpfs_node *node; 79d1fa59e9SXin LI 80d1fa59e9SXin LI vp = ap->a_vp; 81d1fa59e9SXin LI node = VP_TO_TMPFS_NODE(vp); 82d1fa59e9SXin LI 83d1fa59e9SXin LI switch (ap->a_kn->kn_filter){ 84d1fa59e9SXin LI case EVFILT_READ: 85d1fa59e9SXin LI node->tn_status |= TMPFS_NODE_ACCESSED; 86d1fa59e9SXin LI break; 87d1fa59e9SXin LI case EVFILT_WRITE: 88d1fa59e9SXin LI node->tn_status |= TMPFS_NODE_MODIFIED; 89d1fa59e9SXin LI break; 90d1fa59e9SXin LI } 91d1fa59e9SXin LI 92d1fa59e9SXin LI return fifo_specops.vop_kqfilter(ap); 93d1fa59e9SXin LI } 94d1fa59e9SXin LI 95d1fa59e9SXin LI /* --------------------------------------------------------------------- */ 96d1fa59e9SXin LI 97d1fa59e9SXin LI int 98d1fa59e9SXin LI tmpfs_fifo_close(struct vop_close_args *v) 99d1fa59e9SXin LI { 100d1fa59e9SXin LI struct tmpfs_node *node; 101d1fa59e9SXin LI node = VP_TO_TMPFS_NODE(v->a_vp); 102d1fa59e9SXin LI node->tn_status |= TMPFS_NODE_ACCESSED; 103d1fa59e9SXin LI 104d1fa59e9SXin LI tmpfs_update(v->a_vp); 105d1fa59e9SXin LI return fifo_specops.vop_close(v); 106d1fa59e9SXin LI } 107