diff options
-rw-r--r-- | src/src/mytypes.h | 12 | ||||
-rw-r--r-- | src/src/readconf.c | 2 | ||||
-rw-r--r-- | src/src/store.c | 19 | ||||
-rw-r--r-- | src/src/store.h | 1 |
4 files changed, 14 insertions, 20 deletions
diff --git a/src/src/mytypes.h b/src/src/mytypes.h index 84baa9eea..aaa6e9052 100644 --- a/src/src/mytypes.h +++ b/src/src/mytypes.h @@ -125,9 +125,19 @@ functions that are called quite often; for other calls to external libraries #define Ustrtoul(s,t,b) strtoul(CCS(s),CSS(t),b) #define Uunlink(s) unlink(CCS(s)) -extern BOOL is_tainted(const void *); extern void die_tainted(const uschar *, const uschar *, int); +/* Predicate: if an address is in a tainted pool. +By extension, a variable pointing to this address is tainted. +*/ + +static inline BOOL +is_tainted(const void * p) +{ +extern void * tainted_base, * tainted_top; +return p >= tainted_base && p < tainted_top; +} + static inline uschar * __Ustrcat(uschar * dst, const uschar * src, const char * func, int line) { #ifndef COMPILE_UTILITY diff --git a/src/src/readconf.c b/src/src/readconf.c index 52c64830e..6ed2ea409 100644 --- a/src/src/readconf.c +++ b/src/src/readconf.c @@ -3337,7 +3337,7 @@ syscalls). It also assume we're on the relevant pool. */ if (statbuf.st_size > 8192) { rmark r = store_mark(); - store_get((int)statbuf.st_size, FALSE); + void * dummy = store_get((int)statbuf.st_size, FALSE); store_reset(r); } diff --git a/src/src/store.c b/src/src/store.c index 7871d0ccc..41ca43d65 100644 --- a/src/src/store.c +++ b/src/src/store.c @@ -106,8 +106,8 @@ static int yield_length[NPOOLS] = { -1, -1, -1, -1, -1, -1 }; a fast is_tainted implementation. We assume the kernel only allocates mmaps using one side or the other of data+heap, not both. */ -static void * tainted_base = (void *)-1; -static void * tainted_top = (void *)0; +void * tainted_base = (void *)-1; +void * tainted_top = (void *)0; /* pool_malloc holds the amount of memory used by the store pools; this goes up and down as store is reset or released. nonpool_malloc is the total got by @@ -159,21 +159,6 @@ static void internal_store_free(void *, const char *, int linenumber); /******************************************************************************/ -/* Predicate: if an address is in a tainted pool. -By extension, a variable pointing to this address is tainted. -*/ - -BOOL -is_tainted(const void * p) -{ -BOOL rc = p >= tainted_base && p < tainted_top; - -#ifndef COMPILE_UTILITY -DEBUG(D_memory) if (rc) debug_printf_indent("is_tainted: YES\n"); -#endif -return rc; -} - void die_tainted(const uschar * msg, const uschar * func, int line) { diff --git a/src/src/store.h b/src/src/store.h index 6464e32ed..52f211ef5 100644 --- a/src/src/store.h +++ b/src/src/store.h @@ -53,7 +53,6 @@ tracing information for debugging. */ /* The real functions */ typedef void ** rmark; -extern BOOL is_tainted(const void *); extern BOOL store_extend_3(void *, BOOL, int, int, const char *, int); extern void store_free_3(void *, const char *, int); extern void *store_get_3(int, BOOL, const char *, int) ALLOC ALLOC_SIZE(1) WARN_UNUSED_RESULT; |