mirror of
https://github.com/samba-team/samba.git
synced 2025-01-19 10:03:58 +03:00
e799eb8da6
Jeremy.
64 lines
2.1 KiB
C
64 lines
2.1 KiB
C
/*
|
|
Unix SMB/CIFS implementation.
|
|
Samba utility functions
|
|
Copyright (C) Martin Pool 2003
|
|
Copyright (C) Andrew Bartlett 2003
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "includes.h"
|
|
|
|
#ifdef DEVELOPER
|
|
const char *global_clobber_region_function;
|
|
unsigned int global_clobber_region_line;
|
|
#endif
|
|
|
|
/**
|
|
* In developer builds, clobber a region of memory.
|
|
*
|
|
* If we think a string buffer is longer than it really is, this ought
|
|
* to make the failure obvious, by segfaulting (if in the heap) or by
|
|
* killing the return address (on the stack), or by trapping under a
|
|
* memory debugger.
|
|
*
|
|
* This is meant to catch possible string overflows, even if the
|
|
* actual string copied is not big enough to cause an overflow.
|
|
*
|
|
* In addition, under Valgrind the buffer is marked as uninitialized.
|
|
**/
|
|
void clobber_region(const char *fn, unsigned int line, char *dest, size_t len)
|
|
{
|
|
#ifdef DEVELOPER
|
|
global_clobber_region_function = fn;
|
|
global_clobber_region_line = line;
|
|
|
|
/* F1 is odd and 0xf1f1f1f1 shouldn't be a valid pointer */
|
|
memset(dest, 0xF1, len);
|
|
#ifdef VALGRIND
|
|
/* Even though we just wrote to this, from the application's
|
|
* point of view it is not initialized.
|
|
*
|
|
* (This is not redundant with the clobbering above. The
|
|
* marking might not actually take effect if we're not running
|
|
* under valgrind.) */
|
|
#if defined(VALGRIND_MAKE_MEM_UNDEFINED)
|
|
VALGRIND_MAKE_MEM_UNDEFINED(dest, len);
|
|
#elif defined(VALGRIND_MAKE_WRITABLE)
|
|
VALGRIND_MAKE_WRITABLE(dest, len);
|
|
#endif
|
|
#endif /* VALGRIND */
|
|
#endif /* DEVELOPER */
|
|
}
|