From f13115627c601f66728b903d935fe31f234b910b Mon Sep 17 00:00:00 2001 From: Julien Portalier Date: Tue, 7 Jan 2025 12:14:39 +0100 Subject: [PATCH] Fix: signal handler musn't depend on the event loop Only a limited set of POSIX functions are signal safe, and the system functions that the event loop implementations can rely on isn't in the list (e.g. epoll, kevent, malloc, ...). --- src/crystal/system/unix/signal.cr | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/crystal/system/unix/signal.cr b/src/crystal/system/unix/signal.cr index f65b529bf0fb..e3675843c450 100644 --- a/src/crystal/system/unix/signal.cr +++ b/src/crystal/system/unix/signal.cr @@ -33,7 +33,7 @@ module Crystal::System::Signal action.sa_flags = LibC::SA_RESTART action.sa_sigaction = LibC::SigactionHandlerT.new do |value, _, _| - writer.write_bytes(value) unless writer.closed? + FileDescriptor.write_fully(writer.fd, pointerof(value)) unless writer.closed? end LibC.sigemptyset(pointerof(action.@sa_mask)) LibC.sigaction(signal, pointerof(action), nil) @@ -85,7 +85,9 @@ module Crystal::System::Signal private def self.start_loop spawn(name: "signal-loop") do loop do - value = reader.read_bytes(Int32) + buf = uninitialized StaticArray(UInt8, 4) + reader.read_fully(buf.to_slice) + value = buf.unsafe_as(Int32) rescue IO::Error next else