35
37
#if defined(HAVE_GETRLIMIT) && defined(RLIMIT_NOFILE)
37
39
#ifndef RLIM_INFINITY
38
#define RLIM_INFINITY ((uint) 0xffffffff)
40
#define RLIM_INFINITY ((uint32_t) 0xffffffff)
41
static uint32_t set_max_open_files(uint32_t max_file_limit)
43
static uint64_t set_max_open_files(uint64_t max_file_limit)
43
45
struct rlimit rlimit;
46
48
if (!getrlimit(RLIMIT_NOFILE,&rlimit))
48
old_cur= (uint) rlimit.rlim_cur;
50
old_cur= rlimit.rlim_cur;
49
51
if (rlimit.rlim_cur == RLIM_INFINITY)
50
52
rlimit.rlim_cur = max_file_limit;
51
53
if (rlimit.rlim_cur >= max_file_limit)
52
return(rlimit.rlim_cur); /* purecov: inspected */
55
if (rlimit.rlim_cur > UINT32_MAX)
58
return((uint32_t)rlimit.rlim_cur);
53
60
rlimit.rlim_cur= rlimit.rlim_max= max_file_limit;
54
61
if (setrlimit(RLIMIT_NOFILE, &rlimit))
55
max_file_limit= old_cur; /* Use original value */
62
max_file_limit= (old_cur < UINT32_MAX) ? (uint32_t)old_cur : UINT32_MAX;
58
65
rlimit.rlim_cur= 0; /* Safety if next call fails */
59
66
(void) getrlimit(RLIMIT_NOFILE,&rlimit);
60
67
if (rlimit.rlim_cur) /* If call didn't fail */
61
max_file_limit= (uint) rlimit.rlim_cur;
68
max_file_limit= (uint32_t) rlimit.rlim_cur;
64
71
return(max_file_limit);
68
static int set_max_open_files(uint32_t max_file_limit)
75
static int set_max_open_files(uint64_t max_file_limit)
70
77
/* We don't know the limit. Return best guess */
71
78
return cmin(max_file_limit, OS_FILE_LIMIT);
92
99
if (files <= MY_NFILE)
95
if (!(tmp= (struct st_my_file_info*) my_malloc(sizeof(*tmp) * files,
102
if (!(tmp= (st_my_file_info*) malloc((size_t)cmax(sizeof(st_my_file_info) * files,SIZE_MAX))))
99
105
/* Copy any initialized files */
100
memcpy(tmp, my_file_info, sizeof(*tmp) * cmin(my_file_limit, files));
106
memcpy(tmp, my_file_info,
108
(size_t)cmin(my_file_limit,
109
cmax(files,UINT32_MAX)));
102
111
The int cast is necessary since 'my_file_limits' might be greater