Skip to content

Commit

Permalink
lib/limits.c: setrlimit_value(): Reimplement in terms of a2i()
Browse files Browse the repository at this point in the history
Signed-off-by: Alejandro Colomar <[email protected]>
  • Loading branch information
alejandro-colomar committed Mar 21, 2024
1 parent 30d634b commit 97d5ce5
Showing 1 changed file with 8 additions and 13 deletions.
21 changes: 8 additions & 13 deletions lib/limits.c
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,10 @@
#include "shadowlog.h"
#include <sys/resource.h>

#include "atoi/a2i.h"
#include "atoi/str2i.h"
#include "memzero.h"
#include "typetraits.h"


#ifndef LIMITS_FILE
Expand All @@ -49,28 +51,21 @@ static int setrlimit_value (unsigned int resource,
const char *value,
unsigned int multiplier)
{
char *end;
long l;
rlim_t limit;
rlim_t l, limit;
struct rlimit rlim;

/* The "-" is special, not belonging to a strange negative limit.
* It is infinity, in a controlled way.
*/
if ('-' == value[0]) {
limit = RLIM_INFINITY;
}
else {
/* We cannot use str2sl() here because it fails when there
* is more to the value than just this number!
* Also, we are limited to base 10 here (hex numbers will not
* work with the limit string parser as is anyway)
*/
errno = 0;
l = strtol(value, &end, 10);

if (value == end || errno != 0)
} else {
if (a2i(rlim_t, &l, value, NULL, 10, 0, type_max(rlim_t)) == -1
&& errno != ENOTSUP)
{
return 0; // FIXME: We could instead throw an error, though.
}

if (__builtin_mul_overflow(l, multiplier, &limit)) {
/* FIXME: Again, silent error handling...
Expand Down

0 comments on commit 97d5ce5

Please sign in to comment.