Commit 2d48113
committed
ncdb: derive coveritem flags from type defaults
The UCIS LRM defines IS_32BIT, HAS_GOAL, HAS_WEIGHT as structural
flags determined by cover type, not per-bin state. All CVGBIN items
have IS_32BIT|HAS_GOAL|HAS_WEIGHT (0x19); all others have IS_32BIT
(0x01). These are now stored in COVER_TYPE_DEFAULTS and applied
automatically during deserialization.
coveritem_flags.bin only stores flags that DIFFER from the type
default (exclusion flags, IS_BR_ELSE, IS_FSM_RESET, etc.). For
typical databases this means 0 entries → member not written.
Impact on merged.vdb benchmark (131K bins):
- coveritem_flags.bin: 264KB → 0 (not written)
- Read: 3.13s → 2.79s (-11%, ~340ms saved)
- Write: 2.71s → 2.63s (-3%, ~80ms saved)
- Merge: unchanged (fast path never touches flags)
Full test suite: 1002 passed, 0 failed1 parent ae8b3ff commit 2d48113
3 files changed
Lines changed: 27 additions & 18 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
67 | 67 | | |
68 | 68 | | |
69 | 69 | | |
70 | | - | |
71 | | - | |
72 | | - | |
73 | | - | |
74 | | - | |
75 | | - | |
76 | | - | |
77 | | - | |
78 | | - | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | | - | |
83 | | - | |
84 | | - | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
85 | 85 | | |
86 | 86 | | |
87 | 87 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
| 20 | + | |
20 | 21 | | |
21 | 22 | | |
22 | 23 | | |
| |||
32 | 33 | | |
33 | 34 | | |
34 | 35 | | |
35 | | - | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
36 | 39 | | |
37 | 40 | | |
38 | 41 | | |
| |||
83 | 86 | | |
84 | 87 | | |
85 | 88 | | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
86 | 93 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
265 | 265 | | |
266 | 266 | | |
267 | 267 | | |
268 | | - | |
| 268 | + | |
| 269 | + | |
269 | 270 | | |
270 | 271 | | |
271 | 272 | | |
| |||
344 | 345 | | |
345 | 346 | | |
346 | 347 | | |
347 | | - | |
| 348 | + | |
| 349 | + | |
348 | 350 | | |
349 | 351 | | |
350 | 352 | | |
| |||
0 commit comments