top: just a small tweak to that history hash algorithm
This patch just raises the size of the hash table used to calculate elapsed task stuff. The net result should be less need for 'chaining' under pid hash collisions. [ the hash scheme is intentionally kept as primitive ] [ and, therefore, as fast as possible. it employs an ] [ 'and' approach versus a 'mod' operation since both ] [ yield similar distribution but the former approach ] [ was 4 fewer cpu instructions in terms of overhead. ] [ additionally, for hash collisions, 'chaining' uses ] [ an array index rather than the usual pointer since ] [ the HST_t guys may move when they are reallocated. ] Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
3e1c00d051
commit
d10c8fccc9
@ -190,7 +190,7 @@ static int HHist_siz; // max number of HST_t structs
|
|||||||
static HST_t *PHist_sav, // alternating 'old/new' HST_t anchors
|
static HST_t *PHist_sav, // alternating 'old/new' HST_t anchors
|
||||||
*PHist_new;
|
*PHist_new;
|
||||||
#ifndef OFF_HST_HASH
|
#ifndef OFF_HST_HASH
|
||||||
#define HHASH_SIZ 1024
|
#define HHASH_SIZ 4096
|
||||||
static int HHash_one [HHASH_SIZ], // actual hash tables ( hereafter known
|
static int HHash_one [HHASH_SIZ], // actual hash tables ( hereafter known
|
||||||
HHash_two [HHASH_SIZ], // as PHash_sav/PHash_new )
|
HHash_two [HHASH_SIZ], // as PHash_sav/PHash_new )
|
||||||
HHash_nul [HHASH_SIZ]; // 'empty' hash table image
|
HHash_nul [HHASH_SIZ]; // 'empty' hash table image
|
||||||
|
Loading…
x
Reference in New Issue
Block a user