comparison src/mc-alloc.c @ 2775:05d62157e048

[xemacs-hg @ 2005-05-15 16:37:52 by crestani] New allocator improvements lisp/ChangeLog addition: 2005-05-15 Marcus Crestani <crestani@xemacs.org> * diagnose.el: Lrecord and string data statistics. * diagnose.el (show-memory-usage): Add output for additional lrecord statistics (currently only string data). * diagnose.el (show-lrecord-stats): New. Print detailed lrecord statistics. src/ChangeLog addition: 2005-05-15 Marcus Crestani <crestani@xemacs.org> * alloc.c: Add string data statistics. * alloc.c (dec_lrecord_stats): Use size of lrecord for statistics and cons counter bookkeeping. * alloc.c (finalize_string): Add string data statistics. * alloc.c (make_uninit_string): Add string data statistics. * alloc.c (make_string_nocopy): Add string data statistics. * alloc.c (kkcc_marking): Move break out of #ifdef. * alloc.c (Flrecord_stats): New. Collect lrecord statistics. * alloc.c (Fgarbage_collect): Use Flrecord_stats. * alloc.c (syms_of_alloc): Add Flrecord_stats. * dumper.c: Fix hash table. * dumper.c (pdump_make_hash): Fix hash table. * dumper.c (pdump_get_mc_addr): Fix hash table. * dumper.c (pdump_put_mc_addr): Fix hash table. * dumper.c (pdump_reloc_one_mc): Fix indentation. * dumper.c (pdump_load_finish): Add lrecord statistics bookkeeping. * lrecord.h: Add string data statistics. * mc-alloc.c (remove_cell): Lrecord statistics, fix indentation. * mule-charset.c: Marking through *_unicode_description not needed. * symbols.c (init_symbols_once_early): Bump lrecord statistics. * window.c: Marking through line_start_cache not needed. * xemacs.def.in.in: Fix typo.
author crestani
date Sun, 15 May 2005 16:38:14 +0000
parents c474585a3460
children 6c70efc2b5b1
comparison
equal deleted inserted replaced
2774:d72eefd1305a 2775:05d62157e048
1482 PLH_USED_SPACE (PH_PLH (ph)) -= 1482 PLH_USED_SPACE (PH_PLH (ph)) -=
1483 detagged_lisp_object_size ((const struct lrecord_header *) ptr); 1483 detagged_lisp_object_size ((const struct lrecord_header *) ptr);
1484 else 1484 else
1485 PLH_USED_SPACE (PH_PLH (ph)) -= PH_CELL_SIZE (ph); 1485 PLH_USED_SPACE (PH_PLH (ph)) -= PH_CELL_SIZE (ph);
1486 #endif 1486 #endif
1487 if (PH_ON_USED_LIST_P (ph))
1488 {
1489 #ifdef MC_ALLOC_TYPE_STATS
1490 dec_lrecord_stats (PH_CELL_SIZE (ph),
1491 (const struct lrecord_header *) ptr);
1492 #endif /* MC_ALLOC_TYPE_STATS */
1487 #ifdef ERROR_CHECK_GC 1493 #ifdef ERROR_CHECK_GC
1488 if (PH_ON_USED_LIST_P (ph)) { 1494 assert (!LRECORD_FREE_P (ptr));
1489 #ifdef MC_ALLOC_TYPE_STATS 1495 deadbeef_memory (ptr, PH_CELL_SIZE (ph));
1490 dec_lrecord_stats (PH_CELL_SIZE (ph), 1496 MARK_LRECORD_AS_FREE (ptr);
1491 (const struct lrecord_header *) ptr); 1497 #endif
1492 #endif /* MC_ALLOC_TYPE_STATS */ 1498 }
1493 assert (!LRECORD_FREE_P (ptr));
1494 deadbeef_memory (ptr, PH_CELL_SIZE (ph));
1495 MARK_LRECORD_AS_FREE (ptr);
1496 }
1497 #endif
1498 1499
1499 /* hooks cell into free list */ 1500 /* hooks cell into free list */
1500 NEXT_FREE (ptr) = PH_FREE_LIST (ph); 1501 NEXT_FREE (ptr) = PH_FREE_LIST (ph);
1501 PH_FREE_LIST (ph) = FREE_LIST (ptr); 1502 PH_FREE_LIST (ph) = FREE_LIST (ptr);
1502 /* decrease cells used */ 1503 /* decrease cells used */