-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathshmem-add-shmem_size-option-set-filesystem-size.v5.4-rc2.v5.6_updated.patch
168 lines (153 loc) · 5.29 KB
/
shmem-add-shmem_size-option-set-filesystem-size.v5.4-rc2.v5.6_updated.patch
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
From 68111f854dae1ffa60035c97478490681fad6985 Mon Sep 17 00:00:00 2001
From: "Gary B. Genett" <me@garybgenett.net>
Date: Mon, 7 Oct 2019 12:26:55 -0700
Subject: [PATCH] shmem: add shmem_size option, set filesystem size
Adds a kernel configuration option and command line parameter to
specify the size of the shmem filesystem. It is currently hard-coded
to 50% of memory. Users should have the option to set this value as
they see fit.
A specific case where this is necessary would be if the initramfs were
larger than half of the memory, such as a 2.5GB filesystem with 4GB of
memory. Without this option, this causes a kernel panic. With this
option, the user may specify something like 75%, which would allow the
filesystem into memory, while still leaving enough resources to run
a functioning system.
This patch creates the SHMEM_SIZE configuration option and the
shmem_size parameter, which may be specified in bytes, human notation
(1G, 100M, etc.) or percentage (75%). The default remains unchanged.
This patch has no impact unless the values are changed.
Signed-off-by: Gary B. Genett <me@garybgenett.net>
---
Documentation/admin-guide/kernel-parameters.rst | 1 +
Documentation/admin-guide/kernel-parameters.txt | 5 +++
init/Kconfig | 8 ++++
mm/shmem.c | 57 +++++++++++++++++++++++--
4 files changed, 67 insertions(+), 4 deletions(-)
diff --git a/Documentation/admin-guide/kernel-parameters.rst b/Documentation/admin-guide/kernel-parameters.rst
index d05d531b4ec9..33122a6df04f 100644
--- a/Documentation/admin-guide/kernel-parameters.rst
+++ b/Documentation/admin-guide/kernel-parameters.rst
@@ -149,6 +149,7 @@ parameter is applicable::
APPARMOR AppArmor support is enabled.
SERIAL Serial support is enabled.
SH SuperH architecture is enabled.
+ SHMEM Full shmem filesystem is enabled.
SMP The kernel is an SMP kernel.
SPARC Sparc architecture is enabled.
SWSUSP Software suspend (hibernation) is enabled.
diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt
index c7ac2f3ac99f..aeac92577569 100644
--- a/Documentation/admin-guide/kernel-parameters.txt
+++ b/Documentation/admin-guide/kernel-parameters.txt
@@ -4307,6 +4307,11 @@
shapers= [NET]
Maximal number of shapers.
+ shmem_size= [SHMEM]
+ Size of shmem filesystem. Can be specified as a plain
+ integer, in memory size notation (such as 1024M or 1G),
+ or as a percentage (50%).
+
simeth= [IA-64]
simscsi=
diff --git a/init/Kconfig b/init/Kconfig
index b4daad2bac23..7b07f5c448af 100644
--- a/init/Kconfig
+++ b/init/Kconfig
@@ -1537,6 +1537,14 @@ config SHMEM
option replaces shmem and tmpfs with the much simpler ramfs code,
which may be appropriate on small systems without swap.
+config SHMEM_SIZE
+ string "Hard-set the shmem filesystem size"
+ default 0
+ depends on SHMEM
+ help
+ Size of shmem filesystem. Can be specified as a plain integer, in
+ memory size notation (such as 1024M or 1G), or as a percentage (50%).
+
config AIO
bool "Enable AIO support" if EXPERT
default y
diff --git a/mm/shmem.c b/mm/shmem.c
index cd570cc79c76..ad6109524ad1 100644
--- a/mm/shmem.c
+++ b/mm/shmem.c
@@ -95,6 +95,12 @@ static struct vfsmount *shm_mnt;
/* Symlink up to this size is kmalloc'ed instead of using a swappable page */
#define SHORT_SYMLINK_LEN 128
+/* Default size of shmem filesystem (defaults to 50% of memory) */
+#define SHMEM_SIZE_DEFAULT ((totalram_pages() * PAGE_SIZE) / 2)
+/* Final initialized size of shmem filesystem, and stored parameter value */
+unsigned long shmem_size_final;
+char shmem_size_param[20];
+
/*
* shmem_fallocate communicates with shmem_fault or shmem_writepage via
* inode->i_private (with i_mutex making sure that it has only one user at
@@ -123,16 +129,56 @@ struct shmem_options {
};
#ifdef CONFIG_TMPFS
+static void shmem_size_parse(void)
+{
+ char *str, *t;
+
+ sprintf(shmem_size_param, "%s", "0");
+ str = strstr(boot_command_line, "shmem_size=");
+ if (str) {
+ t = strsep(&str, " ");
+ t += 11;
+ sprintf(shmem_size_param, "%s", t);
+ }
+}
+
+static void shmem_size(char *str, char *val)
+{
+ char *rest;
+ unsigned long mem = memparse(val, &rest);
+
+ if (*rest == '%') {
+ mem *= (totalram_pages() * PAGE_SIZE);
+ do_div(mem, 100);
+ }
+ if (mem > 0) {
+ pr_info("shmem: found %s value: %s (%ld pages, %ld bytes)\n",
+ str, val, (mem / PAGE_SIZE), mem);
+ shmem_size_final = (mem / PAGE_SIZE);
+ }
+}
+
+static void shmem_size_init(void)
+{
+ char tmp[20];
+
+ sprintf(tmp, "%ld", SHMEM_SIZE_DEFAULT);
+ shmem_size("default", tmp);
+#ifdef CONFIG_SHMEM_SIZE
+ shmem_size("kernel configuration", CONFIG_SHMEM_SIZE);
+#endif
+ shmem_size_parse();
+ shmem_size("kernel parameter", shmem_size_param);
+}
+
static unsigned long shmem_default_max_blocks(void)
{
- return totalram_pages() / 2;
+ return shmem_size_final;
}
static unsigned long shmem_default_max_inodes(void)
{
- unsigned long nr_pages = totalram_pages();
-
- return min(nr_pages - totalhigh_pages(), nr_pages / 2);
+ return min(totalram_pages() - totalhigh_pages(), shmem_size_final);
}
#endif
@@ -3887,6 +3933,9 @@ int __init shmem_init(void)
{
int error;
+#ifdef CONFIG_TMPFS
+ shmem_size_init();
+#endif
shmem_init_inodecache();
error = register_filesystem(&shmem_fs_type);
--
2.15.2