xref: /netbsd-src/sbin/mount_tmpfs/mount_tmpfs.8 (revision 6a493d6bc668897c91594964a732d38505b70cbb)
1.\"	$NetBSD: mount_tmpfs.8,v 1.17 2013/12/04 18:05:21 wiz Exp $
2.\"
3.\" Copyright (c) 2005, 2006 The NetBSD Foundation, Inc.
4.\" All rights reserved.
5.\"
6.\" This code is derived from software contributed to The NetBSD Foundation
7.\" by Julio M. Merino Vidal, developed as part of Google's Summer of Code
8.\" 2005 program.
9.\"
10.\" Redistribution and use in source and binary forms, with or without
11.\" modification, are permitted provided that the following conditions
12.\" are met:
13.\" 1. Redistributions of source code must retain the above copyright
14.\"    notice, this list of conditions and the following disclaimer.
15.\" 2. Redistributions in binary form must reproduce the above copyright
16.\"    notice, this list of conditions and the following disclaimer in the
17.\"    documentation and/or other materials provided with the distribution.
18.\"
19.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22.\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29.\" POSSIBILITY OF SUCH DAMAGE.
30.\"
31.Dd December 4, 2013
32.Dt MOUNT_TMPFS 8
33.Os
34.Sh NAME
35.Nm mount_tmpfs
36.Nd mount an efficient memory file system
37.Sh SYNOPSIS
38.Nm
39.Op Fl g Ar group
40.Op Fl m Ar mode
41.Op Fl n Ar nodes
42.Op Fl o Ar options
43.Op Fl s Ar size
44.Op Fl u Ar user
45.Ar tmpfs
46.Ar mount_point
47.Sh DESCRIPTION
48The
49.Nm
50command attaches an instance of the efficient memory file system to the
51global file system namespace.
52The
53.Ar tmpfs
54parameter only exists for compatibility with the other mount commands and
55is ignored.
56The directory specified by
57.Ar mount_point
58is converted to an absolute path before use and its attributes (owner,
59group and mode) are inherited unless explicitly overridden by the options
60described below.
61.Pp
62The following options are supported:
63.Bl -tag -width XoXoptions
64.It Fl g Ar group
65Specifies the group name or GID of the root inode of the file system.
66Defaults to the mount point's GID.
67.It Fl m Ar mode
68Specifies the mode (in octal notation) of the root inode of the file system.
69Defaults to the mount point's mode.
70.It Fl n Ar nodes
71Specifies the maximum number of nodes available to the file system.
72If not specified, the file system chooses a reasonable maximum given its
73size at mount time, which can be limited with
74.Fl s .
75.It Fl o Ar options
76Options are specified with a
77.Fl o
78flag followed by a comma-separated string of options.
79See the
80.Xr mount 8
81man page for possible options and their meanings.
82.It Fl s Ar size
83Specifies the total file system size in bytes.
84If zero is given (the default), the available amount of memory (including
85main memory and swap space) will be used.
86Note that four megabytes are always reserved for the system and cannot
87be assigned to the file system.
88.Ar Size
89can alternatively be specified as a percentage of the available
90system ram by using the notation
91.Ar ram%n
92where
93.Ar n
94is a number between 1 and 100.
95Similarily it can be specified as a fraction of the available system
96ram by using
97.Ar ram/n
98where
99.Ar n
100is the divisor.
101(Using
102.Ar ram%25
103and
104.Ar ram/4
105will result in the same limit.)
106.It Fl u Ar user
107Specifies the user name or UID of the root inode of the file system.
108Defaults to the mount point's UID.
109.El
110.Pp
111Every option that accepts a numerical value as its argument can take a
112trailing
113.Sq b
114to indicate bytes (the default), a
115.Sq k
116to indicate kilobytes, a
117.Sq M
118to indicate megabytes or a
119.Sq G
120to indicate gigabytes.
121Note that both lowercase and uppercase forms of these letters are allowed.
122.Sh EXAMPLES
123The following command mounts a tmpfs instance over the
124.Pa /tmp
125directory, inheriting its owner, group and mode settings:
126.Pp
127.Dl # mount -t tmpfs tmpfs /tmp
128.Pp
129The following command mounts a tmpfs instance over the
130.Pa /mnt
131directory, setting a 20 megabytes limit in space, owned by the
132.Sq joe
133user and belonging to the
134.Sq users
135group, with a restricted 0700 mode:
136.Pp
137.Dl # mount -t tmpfs -o -s20M -o -ujoe -o -gusers -o -m0700 tmpfs /mnt
138.Pp
139See
140.Pa /usr/share/examples/fstab/fstab.ramdisk
141for some examples on how to add tmpfs entries to
142.Pa /etc/fstab .
143.Sh SEE ALSO
144.Xr fstab 5 ,
145.Xr mount 8
146.Sh HISTORY
147The
148.Nm
149utility first appeared in
150.Nx 4.0 .
151.Sh BUGS
152File system meta-data is not pageable.
153If there is not enough main memory to hold this information, the system may
154become unstable or very unresponsive because it will not be able to allocate
155required memory.
156A malicious user could trigger this condition if he could create lots of
157files inside a size-unbounded tmpfs file system.
158Limiting the number of nodes per file system
159.Pq Fl n
160will prevent this; the default value for this setting is also often adjusted
161to an adequate value to resolve this.
162