Skip to content
Snippets Groups Projects
Select Git revision
  • 20fb7a0bb45dcdf56f93ad7e75b106d79bca742b
  • master default
  • dbck-q-n-d-link
  • foutput-text_stat-override
  • generations
  • text-stat-sha256
  • use-nettle
  • import-nettle
  • refactor-cached_get_text
  • refactor-cached_get_text-part-2
  • add-text_store
  • introduce-generation_position
  • remove-reclamation
  • dbfile-temp-filenames
  • sstrdup
  • dbfile_open_read-check-magic
  • adns_dist
  • liboop_dist
  • search
  • isc
  • dbdbckmultiplechoice
  • last.cvs.revision
  • 2.1.2
  • 2.1.1
  • 2.1.0
  • adns_1_0
  • liboop_0_9
  • 2.0.7
  • search_bp
  • 2.0.6
  • 2.0.5
  • isc_1_01
  • Protocol-A-10.4
  • 2.0.4
  • 2.0.3
  • 2.0.2
  • 2.0.1
  • 2.0.0
  • isc_1_00
  • isc_merge_1999_05_01
  • isc_merge_1999_04_21
41 results

misc_items_a

Blame
  • block_alloc_h.h 2.50 KiB
    /*
    || This file is part of Pike. For copyright information see COPYRIGHT.
    || Pike is distributed under GPL, LGPL and MPL. See the file COPYING
    || for more information.
    || $Id: block_alloc_h.h,v 1.25 2008/05/01 21:44:32 mast Exp $
    */
    
    #undef BLOCK_ALLOC
    #undef PTR_HASH_ALLOC
    #undef PTR_HASH_ALLOC_FIXED
    #undef BLOCK_ALLOC_FILL_PAGES
    #undef PTR_HASH_ALLOC_FILL_PAGES
    #undef PTR_HASH_ALLOC_FIXED_FILL_PAGES
    
    #ifndef PIKE_HASH_T
    #define PIKE_HASH_T	size_t
    #endif /* !PIKE_HASH_T */
    
    #ifdef BLOCK_ALLOC_USED
    #error "block_alloc.h must be included after all uses of block_alloc_h.h"
    #endif /* BLOCK_ALLOC_USED */
    
    #define BLOCK_ALLOC(DATA,SIZE)						\
    struct DATA *PIKE_CONCAT(alloc_,DATA)(void);				\
    void PIKE_CONCAT3(new_,DATA,_context)(void);				\
    void PIKE_CONCAT3(really_free_,DATA,_unlocked)(struct DATA *d);		\
    void PIKE_CONCAT(really_free_,DATA)(struct DATA *d);			\
    void PIKE_CONCAT3(free_all_,DATA,_blocks)(void);			\
    void PIKE_CONCAT3(count_memory_in_,DATA,s)(size_t *num, size_t *size);	\
    void PIKE_CONCAT3(init_,DATA,_blocks)(void)
    
    
    #define PTR_HASH_ALLOC(DATA,BSIZE)				\
    BLOCK_ALLOC(DATA,BSIZE);					\
    extern struct DATA **PIKE_CONCAT(DATA,_hash_table);		\
    extern size_t PIKE_CONCAT(DATA,_hash_table_size);		\
    struct DATA *PIKE_CONCAT(find_,DATA)(void *ptr);		\
    struct DATA *PIKE_CONCAT3(make_,DATA,_unlocked)			\
    		(void *ptr, PIKE_HASH_T hval);			\
    struct DATA *PIKE_CONCAT(make_,DATA)(void *ptr);		\
    struct DATA *PIKE_CONCAT(get_,DATA)(void *ptr);			\
    int PIKE_CONCAT3(check_,DATA,_semaphore)(void *ptr);		\
    void PIKE_CONCAT(move_,DATA)(struct DATA *block, void *new_ptr); \
    int PIKE_CONCAT(remove_,DATA)(void *ptr);			\
    void PIKE_CONCAT3(low_init_,DATA,_hash)(size_t);		\
    void PIKE_CONCAT3(init_,DATA,_hash)(void);			\
    void PIKE_CONCAT3(exit_,DATA,_hash)(void)
    
    #define PTR_HASH_ALLOC_FIXED(DATA,BSIZE)			\
    PTR_HASH_ALLOC(DATA,BSIZE)
    
    #define BLOCK_ALLOC_FILL_PAGES(DATA,PAGES) BLOCK_ALLOC(DATA, n/a)
    #define PTR_HASH_ALLOC_FILL_PAGES(DATA,PAGES) PTR_HASH_ALLOC(DATA, n/a)
    #define PTR_HASH_ALLOC_FIXED_FILL_PAGES(DATA,PAGES) PTR_HASH_ALLOC_FIXED(DATA, n/a)
    
    #define PTR_HASH_LOOP(DATA,HVAL,PTR)					\
      for ((HVAL) = (PIKE_HASH_T)PIKE_CONCAT(DATA,_hash_table_size); (HVAL)-- > 0;)	\
        for ((PTR) = PIKE_CONCAT(DATA,_hash_table)[HVAL];			\
    	 (PTR); (PTR) = (PTR)->BLOCK_ALLOC_NEXT)
    
    /* The name of a member in the BLOCK_ALLOC struct big enough to
     * contain a void * (used for the free list). */
    #define BLOCK_ALLOC_NEXT next
    
    /* The name of a void * member in the PTR_HASH_ALLOC struct containing
     * the key. */
    #define PTR_HASH_ALLOC_DATA data