mirror of
https://github.com/systemd/systemd.git
synced 2024-10-27 01:55:22 +03:00
Merge pull request #13077 from poettering/activate-n-fds
activate: move array allocation to heap
This commit is contained in:
commit
64c3b40c25
@ -49,8 +49,7 @@ static int add_epoll(int epoll_fd, int fd) {
|
||||
|
||||
static int open_sockets(int *epoll_fd, bool accept) {
|
||||
char **address;
|
||||
int n, fd, r;
|
||||
int count = 0;
|
||||
int n, fd, r, count = 0;
|
||||
|
||||
n = sd_listen_fds(true);
|
||||
if (n < 0)
|
||||
@ -69,13 +68,18 @@ static int open_sockets(int *epoll_fd, bool accept) {
|
||||
|
||||
/* Close logging and all other descriptors */
|
||||
if (arg_listen) {
|
||||
int except[3 + n];
|
||||
_cleanup_free_ int *except = NULL;
|
||||
int i;
|
||||
|
||||
for (fd = 0; fd < SD_LISTEN_FDS_START + n; fd++)
|
||||
except[fd] = fd;
|
||||
except = new(int, n);
|
||||
if (!except)
|
||||
return log_oom();
|
||||
|
||||
for (i = 0; i < n; i++)
|
||||
except[i] = SD_LISTEN_FDS_START + i;
|
||||
|
||||
log_close();
|
||||
r = close_all_fds(except, 3 + n);
|
||||
r = close_all_fds(except, n);
|
||||
if (r < 0)
|
||||
return log_error_errno(r, "Failed to close all file descriptors: %m");
|
||||
}
|
||||
|
@ -26,6 +26,7 @@
|
||||
#include "sparse-endian.h"
|
||||
#include "string-table.h"
|
||||
#include "string-util.h"
|
||||
#include "unaligned.h"
|
||||
#include "util.h"
|
||||
|
||||
#if HAVE_LZ4
|
||||
@ -101,7 +102,7 @@ int compress_blob_lz4(const void *src, uint64_t src_size,
|
||||
if (r <= 0)
|
||||
return -ENOBUFS;
|
||||
|
||||
*(le64_t*) dst = htole64(src_size);
|
||||
unaligned_write_le64(dst, src_size);
|
||||
*dst_size = r + 8;
|
||||
|
||||
return 0;
|
||||
@ -187,8 +188,8 @@ int decompress_blob_lz4(const void *src, uint64_t src_size,
|
||||
if (src_size <= 8)
|
||||
return -EBADMSG;
|
||||
|
||||
size = le64toh( *(le64_t*)src );
|
||||
if (size < 0 || (unsigned) size != le64toh(*(le64_t*)src))
|
||||
size = unaligned_read_le64(src);
|
||||
if (size < 0 || (unsigned) size != unaligned_read_le64(src))
|
||||
return -EFBIG;
|
||||
if ((size_t) size > *dst_alloc_size) {
|
||||
out = realloc(*dst, size);
|
||||
|
Loading…
Reference in New Issue
Block a user