Add patch to fix ipset timeout setting problem
Fixes #14325 Signed-off-by: Nikolay Martynov <mar.kolya@gmail.com> SVN-Revision: 38779
This commit is contained in:
parent
c9bc0e12a9
commit
7ad5350dfb
1 changed files with 28 additions and 0 deletions
28
package/network/utils/ipset/patches/001-timeout-size.patch
Normal file
28
package/network/utils/ipset/patches/001-timeout-size.patch
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
diff --git a/lib/parse.c b/lib/parse.c
|
||||||
|
index 8ea8542..440ef8f 100644
|
||||||
|
--- a/lib/parse.c
|
||||||
|
+++ b/lib/parse.c
|
||||||
|
@@ -1292,15 +1292,20 @@ ipset_parse_timeout(struct ipset_session *session,
|
||||||
|
enum ipset_opt opt, const char *str)
|
||||||
|
{
|
||||||
|
int err;
|
||||||
|
- unsigned long long num = 0;
|
||||||
|
+ unsigned long long llnum = 0;
|
||||||
|
+ uint32_t num = 0;
|
||||||
|
|
||||||
|
assert(session);
|
||||||
|
assert(opt == IPSET_OPT_TIMEOUT);
|
||||||
|
assert(str);
|
||||||
|
|
||||||
|
- err = string_to_number_ll(session, str, 0, UINT_MAX/1000, &num);
|
||||||
|
- if (err == 0)
|
||||||
|
+ err = string_to_number_ll(session, str, 0, UINT_MAX/1000, &llnum);
|
||||||
|
+ if (err == 0) {
|
||||||
|
+ /* Timeout is expected to be 32bits wide, so we have
|
||||||
|
+ to convert it here */
|
||||||
|
+ num = llnum;
|
||||||
|
return ipset_session_data_set(session, opt, &num);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
return err;
|
||||||
|
}
|
Loading…
Reference in a new issue