001-timeout-size.patch 741 B

12345678910111213141516171819202122232425262728
  1. diff --git a/lib/parse.c b/lib/parse.c
  2. index 8ea8542..440ef8f 100644
  3. --- a/lib/parse.c
  4. +++ b/lib/parse.c
  5. @@ -1292,15 +1292,20 @@ ipset_parse_timeout(struct ipset_session *session,
  6. enum ipset_opt opt, const char *str)
  7. {
  8. int err;
  9. - unsigned long long num = 0;
  10. + unsigned long long llnum = 0;
  11. + uint32_t num = 0;
  12. assert(session);
  13. assert(opt == IPSET_OPT_TIMEOUT);
  14. assert(str);
  15. - err = string_to_number_ll(session, str, 0, UINT_MAX/1000, &num);
  16. - if (err == 0)
  17. + err = string_to_number_ll(session, str, 0, UINT_MAX/1000, &llnum);
  18. + if (err == 0) {
  19. + /* Timeout is expected to be 32bits wide, so we have
  20. + to convert it here */
  21. + num = llnum;
  22. return ipset_session_data_set(session, opt, &num);
  23. + }
  24. return err;
  25. }