xref: /freebsd/sys/fs/tmpfs/tmpfs_fifoops.c (revision 5e954b9216ed94f66c74ef55622e0a8fe18d805a)
1d1fa59e9SXin LI /*	$NetBSD: tmpfs_fifoops.c,v 1.5 2005/12/11 12:24:29 christos Exp $	*/
2d1fa59e9SXin LI 
3e08d5567SXin LI /*-
4d63027b6SPedro F. Giffuni  * SPDX-License-Identifier: BSD-2-Clause-NetBSD
5d63027b6SPedro F. Giffuni  *
6d1fa59e9SXin LI  * Copyright (c) 2005 The NetBSD Foundation, Inc.
7d1fa59e9SXin LI  * All rights reserved.
8d1fa59e9SXin LI  *
9d1fa59e9SXin LI  * This code is derived from software contributed to The NetBSD Foundation
10d1fa59e9SXin LI  * by Julio M. Merino Vidal, developed as part of Google's Summer of Code
11d1fa59e9SXin LI  * 2005 program.
12d1fa59e9SXin LI  *
13d1fa59e9SXin LI  * Redistribution and use in source and binary forms, with or without
14d1fa59e9SXin LI  * modification, are permitted provided that the following conditions
15d1fa59e9SXin LI  * are met:
16d1fa59e9SXin LI  * 1. Redistributions of source code must retain the above copyright
17d1fa59e9SXin LI  *    notice, this list of conditions and the following disclaimer.
18d1fa59e9SXin LI  * 2. Redistributions in binary form must reproduce the above copyright
19d1fa59e9SXin LI  *    notice, this list of conditions and the following disclaimer in the
20d1fa59e9SXin LI  *    documentation and/or other materials provided with the distribution.
21d1fa59e9SXin LI  *
22d1fa59e9SXin LI  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
23d1fa59e9SXin LI  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
24d1fa59e9SXin LI  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
25d1fa59e9SXin LI  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
26d1fa59e9SXin LI  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
27d1fa59e9SXin LI  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
28d1fa59e9SXin LI  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
29d1fa59e9SXin LI  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
30d1fa59e9SXin LI  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
31d1fa59e9SXin LI  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32d1fa59e9SXin LI  * POSSIBILITY OF SUCH DAMAGE.
33d1fa59e9SXin LI  */
34d1fa59e9SXin LI 
35d1fa59e9SXin LI /*
36d1fa59e9SXin LI  * tmpfs vnode interface for named pipes.
37d1fa59e9SXin LI  */
38d1fa59e9SXin LI #include <sys/cdefs.h>
39d1fa59e9SXin LI  __FBSDID("$FreeBSD$");
40d1fa59e9SXin LI 
41d1fa59e9SXin LI #include <sys/param.h>
42db357f58SGleb Smirnoff #include <sys/mount.h>
43d1fa59e9SXin LI #include <sys/proc.h>
44d1fa59e9SXin LI #include <sys/vnode.h>
45d1fa59e9SXin LI 
46d1fa59e9SXin LI #include <vm/vm.h>
47d1fa59e9SXin LI #include <vm/vm_object.h>
48d1fa59e9SXin LI 
49d1fa59e9SXin LI #include <fs/tmpfs/tmpfs.h>
50d1fa59e9SXin LI #include <fs/tmpfs/tmpfs_fifoops.h>
51d1fa59e9SXin LI #include <fs/tmpfs/tmpfs_vnops.h>
52d1fa59e9SXin LI 
53a96539bfSXin LI static int
54d1fa59e9SXin LI tmpfs_fifo_close(struct vop_close_args *v)
55d1fa59e9SXin LI {
56d1fa59e9SXin LI 	struct tmpfs_node *node;
57d1fa59e9SXin LI 
585dc11286SKonstantin Belousov 	node = VP_TO_TMPFS_NODE(v->a_vp);
59016b7c7eSKonstantin Belousov 	tmpfs_set_accessed(VFS_TO_TMPFS(v->a_vp->v_mount), node);
60d1fa59e9SXin LI 	tmpfs_update(v->a_vp);
615dc11286SKonstantin Belousov 	return (fifo_specops.vop_close(v));
62d1fa59e9SXin LI }
63a96539bfSXin LI 
64a96539bfSXin LI /*
65a96539bfSXin LI  * vnode operations vector used for fifos stored in a tmpfs file system.
66a96539bfSXin LI  */
67a96539bfSXin LI struct vop_vector tmpfs_fifoop_entries = {
68a96539bfSXin LI 	.vop_default =			&fifo_specops,
69a96539bfSXin LI 	.vop_close =			tmpfs_fifo_close,
70a96539bfSXin LI 	.vop_reclaim =			tmpfs_reclaim,
71a96539bfSXin LI 	.vop_access =			tmpfs_access,
72a96539bfSXin LI 	.vop_getattr =			tmpfs_getattr,
73a96539bfSXin LI 	.vop_setattr =			tmpfs_setattr,
74b501cc5dSJohn Baldwin 	.vop_pathconf =                 tmpfs_pathconf,
755b01ccb0SJohn Baldwin 	.vop_print =			tmpfs_print,
7618790219SMateusz Guzik 	.vop_add_writecount =		vop_stdadd_writecount_nomsync,
77*5e954b92SMateusz Guzik 	.vop_fplookup_vexec =		VOP_EAGAIN,
78*5e954b92SMateusz Guzik 	.vop_fplookup_symlink =		VOP_EAGAIN,
79a96539bfSXin LI };
806fa079fcSMateusz Guzik VFS_VOP_VECTOR_REGISTER(tmpfs_fifoop_entries);
81