mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-18 10:35:55 +00:00
- Update cachelimit after hashsize and bucketlimit were set.
Reported by: az Reviewed by: melifaro Approved by: kib (mentor) MFC after: 1 week
This commit is contained in:
parent
6a91a98054
commit
32fe38f123
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=241735
@ -174,6 +174,7 @@ static MALLOC_DEFINE(M_HOSTCACHE, "hostcache", "TCP hostcache");
|
||||
void
|
||||
tcp_hc_init(void)
|
||||
{
|
||||
u_int cache_limit;
|
||||
int i;
|
||||
|
||||
/*
|
||||
@ -182,23 +183,27 @@ tcp_hc_init(void)
|
||||
V_tcp_hostcache.cache_count = 0;
|
||||
V_tcp_hostcache.hashsize = TCP_HOSTCACHE_HASHSIZE;
|
||||
V_tcp_hostcache.bucket_limit = TCP_HOSTCACHE_BUCKETLIMIT;
|
||||
V_tcp_hostcache.cache_limit =
|
||||
V_tcp_hostcache.hashsize * V_tcp_hostcache.bucket_limit;
|
||||
V_tcp_hostcache.expire = TCP_HOSTCACHE_EXPIRE;
|
||||
V_tcp_hostcache.prune = TCP_HOSTCACHE_PRUNE;
|
||||
|
||||
TUNABLE_INT_FETCH("net.inet.tcp.hostcache.hashsize",
|
||||
&V_tcp_hostcache.hashsize);
|
||||
TUNABLE_INT_FETCH("net.inet.tcp.hostcache.cachelimit",
|
||||
&V_tcp_hostcache.cache_limit);
|
||||
TUNABLE_INT_FETCH("net.inet.tcp.hostcache.bucketlimit",
|
||||
&V_tcp_hostcache.bucket_limit);
|
||||
if (!powerof2(V_tcp_hostcache.hashsize)) {
|
||||
printf("WARNING: hostcache hash size is not a power of 2.\n");
|
||||
V_tcp_hostcache.hashsize = TCP_HOSTCACHE_HASHSIZE; /* default */
|
||||
}
|
||||
V_tcp_hostcache.hashmask = V_tcp_hostcache.hashsize - 1;
|
||||
|
||||
TUNABLE_INT_FETCH("net.inet.tcp.hostcache.bucketlimit",
|
||||
&V_tcp_hostcache.bucket_limit);
|
||||
|
||||
cache_limit = V_tcp_hostcache.hashsize * V_tcp_hostcache.bucket_limit;
|
||||
V_tcp_hostcache.cache_limit = cache_limit;
|
||||
TUNABLE_INT_FETCH("net.inet.tcp.hostcache.cachelimit",
|
||||
&V_tcp_hostcache.cache_limit);
|
||||
if (V_tcp_hostcache.cache_limit > cache_limit)
|
||||
V_tcp_hostcache.cache_limit = cache_limit;
|
||||
|
||||
/*
|
||||
* Allocate the hash table.
|
||||
*/
|
||||
|
Loading…
Reference in New Issue
Block a user