Move to final version of upstream patch for non-constant SIGSTKSZ
NOTE: I did not build this package because it will cause dependency problems (requiring every other OCaml package in F35 to be rebuilt). If there is a mass rebuild of Rawhide then that would be a good time to rebuild it.
This commit is contained in:
parent
b8653f50ff
commit
129153b851
@ -23,5 +23,5 @@ index 07e2eda1a..340508a60 100644
|
|||||||
> ocamlmklibconfig.ml
|
> ocamlmklibconfig.ml
|
||||||
|
|
||||||
--
|
--
|
||||||
2.29.0.rc2
|
2.32.0
|
||||||
|
|
||||||
|
@ -23,5 +23,5 @@ index 83455a3b6..213392b25 100644
|
|||||||
|
|
||||||
# Enable SSE2 on x86 mingw to avoid using 80-bit registers.
|
# Enable SSE2 on x86 mingw to avoid using 80-bit registers.
|
||||||
--
|
--
|
||||||
2.29.0.rc2
|
2.32.0
|
||||||
|
|
||||||
|
@ -39,5 +39,5 @@ index 213392b25..c7e594b5d 100644
|
|||||||
# We first compute default values for as and aspp
|
# We first compute default values for as and aspp
|
||||||
# If values have been given by the user then they take precedence over
|
# If values have been given by the user then they take precedence over
|
||||||
--
|
--
|
||||||
2.29.0.rc2
|
2.32.0
|
||||||
|
|
||||||
|
103
0004-Dynamically-allocate-the-alternate-signal-stack-1026.patch
Normal file
103
0004-Dynamically-allocate-the-alternate-signal-stack-1026.patch
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
From 3104d92743614f8f52039e0520116af4179880a5 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Xavier Leroy <xavierleroy@users.noreply.github.com>
|
||||||
|
Date: Fri, 5 Mar 2021 19:14:07 +0100
|
||||||
|
Subject: [PATCH 4/4] Dynamically allocate the alternate signal stack (#10266)
|
||||||
|
|
||||||
|
In Glibc 2.34 and later, SIGSTKSZ may not be a compile-time constant.
|
||||||
|
It is no longer possible to statically allocate the alternate signal
|
||||||
|
stack for the main thread, as we've been doing for the last 25 years.
|
||||||
|
|
||||||
|
This commit implements dynamic allocation of the alternate signal stack
|
||||||
|
even for the main thread. It reuses the code already in place to allocate
|
||||||
|
the alternate signal stack for other threads.
|
||||||
|
|
||||||
|
Fixes: #10250.
|
||||||
|
(cherry picked from commit fc9534746bf5d08a4c109f22e344cf49d5d46d54)
|
||||||
|
---
|
||||||
|
runtime/caml/signals.h | 2 +-
|
||||||
|
runtime/signals_byt.c | 2 +-
|
||||||
|
runtime/signals_nat.c | 25 ++++++++++++++-----------
|
||||||
|
3 files changed, 16 insertions(+), 13 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/runtime/caml/signals.h b/runtime/caml/signals.h
|
||||||
|
index 3ff152c26..285dbd7fe 100644
|
||||||
|
--- a/runtime/caml/signals.h
|
||||||
|
+++ b/runtime/caml/signals.h
|
||||||
|
@@ -87,7 +87,7 @@ value caml_do_pending_actions_exn (void);
|
||||||
|
value caml_process_pending_actions_with_root (value extra_root); // raises
|
||||||
|
value caml_process_pending_actions_with_root_exn (value extra_root);
|
||||||
|
int caml_set_signal_action(int signo, int action);
|
||||||
|
-CAMLextern void caml_setup_stack_overflow_detection(void);
|
||||||
|
+CAMLextern int caml_setup_stack_overflow_detection(void);
|
||||||
|
|
||||||
|
CAMLextern void (*caml_enter_blocking_section_hook)(void);
|
||||||
|
CAMLextern void (*caml_leave_blocking_section_hook)(void);
|
||||||
|
diff --git a/runtime/signals_byt.c b/runtime/signals_byt.c
|
||||||
|
index 2183142da..38eb5e3a4 100644
|
||||||
|
--- a/runtime/signals_byt.c
|
||||||
|
+++ b/runtime/signals_byt.c
|
||||||
|
@@ -81,4 +81,4 @@ int caml_set_signal_action(int signo, int action)
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
-CAMLexport void caml_setup_stack_overflow_detection(void) {}
|
||||||
|
+CAMLexport int caml_setup_stack_overflow_detection(void) { return 0; }
|
||||||
|
diff --git a/runtime/signals_nat.c b/runtime/signals_nat.c
|
||||||
|
index 8b64ab452..2b4004860 100644
|
||||||
|
--- a/runtime/signals_nat.c
|
||||||
|
+++ b/runtime/signals_nat.c
|
||||||
|
@@ -181,8 +181,6 @@ DECLARE_SIGNAL_HANDLER(trap_handler)
|
||||||
|
#error "CONTEXT_SP is required if HAS_STACK_OVERFLOW_DETECTION is defined"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
-static char sig_alt_stack[SIGSTKSZ];
|
||||||
|
-
|
||||||
|
/* Code compiled with ocamlopt never accesses more than
|
||||||
|
EXTRA_STACK bytes below the stack pointer. */
|
||||||
|
#define EXTRA_STACK 256
|
||||||
|
@@ -276,28 +274,33 @@ void caml_init_signals(void)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAS_STACK_OVERFLOW_DETECTION
|
||||||
|
- {
|
||||||
|
- stack_t stk;
|
||||||
|
+ if (caml_setup_stack_overflow_detection() != -1) {
|
||||||
|
struct sigaction act;
|
||||||
|
- stk.ss_sp = sig_alt_stack;
|
||||||
|
- stk.ss_size = SIGSTKSZ;
|
||||||
|
- stk.ss_flags = 0;
|
||||||
|
SET_SIGACT(act, segv_handler);
|
||||||
|
act.sa_flags |= SA_ONSTACK | SA_NODEFER;
|
||||||
|
sigemptyset(&act.sa_mask);
|
||||||
|
- if (sigaltstack(&stk, NULL) == 0) { sigaction(SIGSEGV, &act, NULL); }
|
||||||
|
+ sigaction(SIGSEGV, &act, NULL);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
-CAMLexport void caml_setup_stack_overflow_detection(void)
|
||||||
|
+/* Allocate and select an alternate stack for handling signals,
|
||||||
|
+ especially SIGSEGV signals.
|
||||||
|
+ Each thread needs its own alternate stack.
|
||||||
|
+ The alternate stack used to be statically-allocated for the main thread,
|
||||||
|
+ but this is incompatible with Glibc 2.34 and newer, where SIGSTKSZ
|
||||||
|
+ may not be a compile-time constant (issue #10250). */
|
||||||
|
+
|
||||||
|
+CAMLexport int caml_setup_stack_overflow_detection(void)
|
||||||
|
{
|
||||||
|
#ifdef HAS_STACK_OVERFLOW_DETECTION
|
||||||
|
stack_t stk;
|
||||||
|
stk.ss_sp = malloc(SIGSTKSZ);
|
||||||
|
+ if (stk.ss_sp == NULL) return -1;
|
||||||
|
stk.ss_size = SIGSTKSZ;
|
||||||
|
stk.ss_flags = 0;
|
||||||
|
- if (stk.ss_sp)
|
||||||
|
- sigaltstack(&stk, NULL);
|
||||||
|
+ return sigaltstack(&stk, NULL);
|
||||||
|
+#else
|
||||||
|
+ return 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
--
|
||||||
|
2.32.0
|
||||||
|
|
@ -1,39 +0,0 @@
|
|||||||
From dfb5e954a04f59b0456cc4c0ddf3acaf22e0ff07 Mon Sep 17 00:00:00 2001
|
|
||||||
From: "Richard W.M. Jones" <rjones@redhat.com>
|
|
||||||
Date: Sun, 28 Feb 2021 20:45:47 +0000
|
|
||||||
Subject: [PATCH 4/4] Workaround for glibc non-constant SIGSTKSZ
|
|
||||||
|
|
||||||
https://github.com/ocaml/ocaml/issues/10250
|
|
||||||
|
|
||||||
Signed-off-by: Richard W.M. Jones <rjones@redhat.com>
|
|
||||||
---
|
|
||||||
runtime/signals_nat.c | 12 ++++++++++++
|
|
||||||
1 file changed, 12 insertions(+)
|
|
||||||
|
|
||||||
diff --git a/runtime/signals_nat.c b/runtime/signals_nat.c
|
|
||||||
index 8b64ab452..7f0a97513 100644
|
|
||||||
--- a/runtime/signals_nat.c
|
|
||||||
+++ b/runtime/signals_nat.c
|
|
||||||
@@ -181,7 +181,19 @@ DECLARE_SIGNAL_HANDLER(trap_handler)
|
|
||||||
#error "CONTEXT_SP is required if HAS_STACK_OVERFLOW_DETECTION is defined"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
+#ifndef __GLIBC__
|
|
||||||
static char sig_alt_stack[SIGSTKSZ];
|
|
||||||
+#else
|
|
||||||
+/* glibc 2.34 has non-constant SIGSTKSZ */
|
|
||||||
+static char *sig_alt_stack;
|
|
||||||
+
|
|
||||||
+static void allocate_sig_alt_stack(void) __attribute__((constructor));
|
|
||||||
+static void
|
|
||||||
+allocate_sig_alt_stack(void)
|
|
||||||
+{
|
|
||||||
+ sig_alt_stack = malloc(SIGSTKSZ);
|
|
||||||
+}
|
|
||||||
+#endif
|
|
||||||
|
|
||||||
/* Code compiled with ocamlopt never accesses more than
|
|
||||||
EXTRA_STACK bytes below the stack pointer. */
|
|
||||||
--
|
|
||||||
2.29.0.rc2
|
|
||||||
|
|
@ -31,7 +31,7 @@
|
|||||||
|
|
||||||
Name: ocaml
|
Name: ocaml
|
||||||
Version: 4.12.0
|
Version: 4.12.0
|
||||||
Release: 1%{?dist}
|
Release: 2%{?dist}
|
||||||
|
|
||||||
Summary: OCaml compiler and programming environment
|
Summary: OCaml compiler and programming environment
|
||||||
|
|
||||||
@ -60,7 +60,7 @@ Source0: https://caml.inria.fr/pub/distrib/ocaml-4.12/ocaml-%{version}.ta
|
|||||||
Patch0001: 0001-Don-t-add-rpaths-to-libraries.patch
|
Patch0001: 0001-Don-t-add-rpaths-to-libraries.patch
|
||||||
Patch0002: 0002-configure-Allow-user-defined-C-compiler-flags.patch
|
Patch0002: 0002-configure-Allow-user-defined-C-compiler-flags.patch
|
||||||
Patch0003: 0003-configure-Remove-incorrect-assumption-about-cross-co.patch
|
Patch0003: 0003-configure-Remove-incorrect-assumption-about-cross-co.patch
|
||||||
Patch0004: 0004-Workaround-for-glibc-non-constant-SIGSTKSZ.patch
|
Patch0004: 0004-Dynamically-allocate-the-alternate-signal-stack-1026.patch
|
||||||
|
|
||||||
BuildRequires: make
|
BuildRequires: make
|
||||||
BuildRequires: git
|
BuildRequires: git
|
||||||
@ -370,6 +370,9 @@ rm -f $RPM_BUILD_ROOT%{_libdir}/ocaml/eventlog_metadata
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Jun 23 2021 Richard W.M. Jones <rjones@redhat.com> - 4.12.0-2
|
||||||
|
- Move to final version of upstream patch for non-constant SIGSTKSZ
|
||||||
|
|
||||||
* Sun Feb 28 2021 Richard W.M. Jones <rjones@redhat.com> - 4.12.0-1
|
* Sun Feb 28 2021 Richard W.M. Jones <rjones@redhat.com> - 4.12.0-1
|
||||||
- OCaml 4.12.0 release (RHBZ#1893381).
|
- OCaml 4.12.0 release (RHBZ#1893381).
|
||||||
- Workaround for glibc non-constant SIGSTKSZ
|
- Workaround for glibc non-constant SIGSTKSZ
|
||||||
|
Loading…
Reference in New Issue
Block a user