2017-10-04 00:19:51 +02:00
|
|
|
From c66c18e3f6c228ec3204aa76afc567e3834c3a13 Mon Sep 17 00:00:00 2001
|
2017-03-15 20:38:55 +01:00
|
|
|
From: =?UTF-8?q?Andreas=20F=C3=A4rber?= <afaerber@suse.de>
|
|
|
|
Date: Sun, 15 Jan 2012 19:53:49 +0100
|
|
|
|
Subject: [PATCH] Raise soft address space limit to hard limit
|
|
|
|
MIME-Version: 1.0
|
|
|
|
Content-Type: text/plain; charset=UTF-8
|
|
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
|
|
|
|
For SLES we want users to be able to use large memory configurations
|
|
|
|
with KVM without fiddling with ulimit -Sv.
|
|
|
|
|
|
|
|
Signed-off-by: Andreas Färber <afaerber@suse.de>
|
|
|
|
[BR: add include for sys/resource.h]
|
|
|
|
Signed-off-by: Bruce Rogers <brogers@suse.com>
|
|
|
|
---
|
|
|
|
vl.c | 12 ++++++++++++
|
|
|
|
1 file changed, 12 insertions(+)
|
|
|
|
|
|
|
|
diff --git a/vl.c b/vl.c
|
2017-10-04 00:19:51 +02:00
|
|
|
index d63269332f..b939df9622 100644
|
2017-03-15 20:38:55 +01:00
|
|
|
--- a/vl.c
|
|
|
|
+++ b/vl.c
|
|
|
|
@@ -26,6 +26,7 @@
|
|
|
|
#include "qemu/cutils.h"
|
|
|
|
#include "qemu/help_option.h"
|
|
|
|
#include "qemu/uuid.h"
|
|
|
|
+#include <sys/resource.h>
|
|
|
|
|
|
|
|
#ifdef CONFIG_SECCOMP
|
|
|
|
#include "sysemu/seccomp.h"
|
2017-08-31 00:22:50 +02:00
|
|
|
@@ -3035,6 +3036,7 @@ int main(int argc, char **argv, char **envp)
|
2017-03-29 06:22:10 +02:00
|
|
|
} BlockdevOptions_queue;
|
|
|
|
QSIMPLEQ_HEAD(, BlockdevOptions_queue) bdo_queue
|
|
|
|
= QSIMPLEQ_HEAD_INITIALIZER(bdo_queue);
|
2017-03-15 20:38:55 +01:00
|
|
|
+ struct rlimit rlimit_as;
|
|
|
|
|
|
|
|
module_call_init(MODULE_INIT_TRACE);
|
|
|
|
|
2017-08-31 00:22:50 +02:00
|
|
|
@@ -3042,6 +3044,16 @@ int main(int argc, char **argv, char **envp)
|
2017-03-15 20:38:55 +01:00
|
|
|
qemu_init_cpu_loop();
|
|
|
|
qemu_mutex_lock_iothread();
|
|
|
|
|
|
|
|
+ /*
|
|
|
|
+ * Try to raise the soft address space limit.
|
|
|
|
+ * Default on SLES 11 SP2 is 80% of physical+swap memory.
|
|
|
|
+ */
|
|
|
|
+ getrlimit(RLIMIT_AS, &rlimit_as);
|
|
|
|
+ if (rlimit_as.rlim_cur < rlimit_as.rlim_max) {
|
|
|
|
+ rlimit_as.rlim_cur = rlimit_as.rlim_max;
|
|
|
|
+ setrlimit(RLIMIT_AS, &rlimit_as);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
atexit(qemu_run_exit_notifiers);
|
|
|
|
error_set_progname(argv[0]);
|
|
|
|
qemu_init_exec_dir(argv[0]);
|