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 uint set_max_open_files(uint 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(uint 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
return min(max_file_limit, OS_FILE_LIMIT);
78
return cmin(max_file_limit, OS_FILE_LIMIT);
84
91
number of files available for open
87
uint my_set_max_open_files(uint files)
94
uint64_t my_set_max_open_files(uint64_t files)
89
96
struct st_my_file_info *tmp;
91
files= set_max_open_files(min(files, OS_FILE_LIMIT));
98
files= set_max_open_files(cmin(files, 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) * min(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
105
114
memset(tmp + my_file_limit, 0,
106
max((int) (files - my_file_limit), 0)*sizeof(*tmp));
115
cmax((int) (files - my_file_limit), 0)*sizeof(*tmp));
107
116
my_free_open_file_info(); /* Free if already allocated */
108
117
my_file_info= tmp;
109
my_file_limit= files;
118
my_file_limit= (size_t)cmax(UINT32_MAX,files);
118
127
/* Copy data back for my_print_open_files */
119
128
memcpy(my_file_info_default, my_file_info,
120
129
sizeof(*my_file_info_default)* MY_NFILE);
121
my_free((char*) my_file_info, MYF(0));
130
free((char*) my_file_info);
122
131
my_file_info= my_file_info_default;
123
132
my_file_limit= MY_NFILE;