mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-17 10:26:15 +00:00
Since we switched to using monatomically increasing timestamps,
they have been reported back to the userland as being in 1970. Add boot time to the timestamp to give the time in the scale of the 'current' real timescale. Not perfect if you change the time a lot but good enough to keep all the rules correct relative to each other correct in terms of time relative to "now".
This commit is contained in:
parent
74e69f9e66
commit
1bd69ee131
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=168328
@ -4328,7 +4328,9 @@ ipfw_getrules(struct ip_fw_chain *chain, void *buf, size_t space)
|
||||
char *ep = bp + space;
|
||||
struct ip_fw *rule;
|
||||
int i;
|
||||
time_t boot_seconds;
|
||||
|
||||
boot_seconds = boottime.tv_sec;
|
||||
/* XXX this can take a long time and locking will block packet flow */
|
||||
IPFW_RLOCK(chain);
|
||||
for (rule = chain->rules; rule ; rule = rule->next) {
|
||||
@ -4341,8 +4343,15 @@ ipfw_getrules(struct ip_fw_chain *chain, void *buf, size_t space)
|
||||
i = RULESIZE(rule);
|
||||
if (bp + i <= ep) {
|
||||
bcopy(rule, bp, i);
|
||||
/*
|
||||
* XXX HACK. Store the disable mask in the "next" pointer
|
||||
* in a wild attempt to keep the ABI the same.
|
||||
* Why do we do this on EVERY rule?
|
||||
*/
|
||||
bcopy(&set_disable, &(((struct ip_fw *)bp)->next_rule),
|
||||
sizeof(set_disable));
|
||||
if (((struct ip_fw *)bp)->timestamp)
|
||||
((struct ip_fw *)bp)->timestamp += boot_seconds;
|
||||
bp += i;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user