1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-27 14:04:05 +03:00
Andrew Tridgell a877eae24b make sure we don't walk past the end of the current SMB buffer when
pulling a string
this might explain a serious filename corruption bug that Quantum QA spotted
-

42 lines
1.5 KiB
C

/*
Unix SMB/CIFS implementation.
server specific string routines
Copyright (C) Andrew Tridgell 2001
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 2 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, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include "includes.h"
int srvstr_push(void *base_ptr, void *dest, const char *src, int dest_len, int flags)
{
return push_string(base_ptr, dest, src, dest_len, flags);
}
int srvstr_pull(void *base_ptr, char *dest, const void *src, int dest_len, int src_len,
int flags)
{
return pull_string(base_ptr, dest, src, dest_len, src_len, flags);
}
/* pull a string from the smb_buf part of a packet. In this case the
string can either be null terminated or it can be terminated by the
end of the smbbuf area
*/
int srvstr_pull_buf(void *inbuf, char *dest, const void *src, int dest_len, int flags)
{
return pull_string(inbuf, dest, src, dest_len, smb_bufrem(inbuf, src), flags);
}