mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
Memory leak fixes.
Jeremy.
This commit is contained in:
parent
1da9c5531a
commit
34b63896ab
@ -2443,6 +2443,7 @@ BOOL sec_io_desc_buf(char *desc, SEC_DESC_BUF **ppsdb, prs_struct *ps, int depth
|
|||||||
BOOL make_systemtime(SYSTEMTIME *systime, struct tm *unixtime);
|
BOOL make_systemtime(SYSTEMTIME *systime, struct tm *unixtime);
|
||||||
BOOL smb_io_notify_info_data_strings(char *desc,SPOOL_NOTIFY_INFO_DATA *data,
|
BOOL smb_io_notify_info_data_strings(char *desc,SPOOL_NOTIFY_INFO_DATA *data,
|
||||||
prs_struct *ps, int depth);
|
prs_struct *ps, int depth);
|
||||||
|
void free_spoolss_devmode(DEVICEMODE *devmode);
|
||||||
BOOL make_spoolss_q_open_printer_ex(SPOOL_Q_OPEN_PRINTER_EX *q_u,
|
BOOL make_spoolss_q_open_printer_ex(SPOOL_Q_OPEN_PRINTER_EX *q_u,
|
||||||
const fstring printername,
|
const fstring printername,
|
||||||
const fstring datatype,
|
const fstring datatype,
|
||||||
@ -2450,6 +2451,7 @@ BOOL make_spoolss_q_open_printer_ex(SPOOL_Q_OPEN_PRINTER_EX *q_u,
|
|||||||
const fstring clientname,
|
const fstring clientname,
|
||||||
const fstring user_name);
|
const fstring user_name);
|
||||||
BOOL spoolss_io_q_open_printer_ex(char *desc, SPOOL_Q_OPEN_PRINTER_EX *q_u, prs_struct *ps, int depth);
|
BOOL spoolss_io_q_open_printer_ex(char *desc, SPOOL_Q_OPEN_PRINTER_EX *q_u, prs_struct *ps, int depth);
|
||||||
|
void free_spoolss_q_open_printer_ex(SPOOL_Q_OPEN_PRINTER_EX *q_u);
|
||||||
BOOL spoolss_io_r_open_printer_ex(char *desc, SPOOL_R_OPEN_PRINTER_EX *r_u, prs_struct *ps, int depth);
|
BOOL spoolss_io_r_open_printer_ex(char *desc, SPOOL_R_OPEN_PRINTER_EX *r_u, prs_struct *ps, int depth);
|
||||||
BOOL spoolss_io_q_getprinterdata(char *desc, SPOOL_Q_GETPRINTERDATA *q_u, prs_struct *ps, int depth);
|
BOOL spoolss_io_q_getprinterdata(char *desc, SPOOL_Q_GETPRINTERDATA *q_u, prs_struct *ps, int depth);
|
||||||
BOOL spoolss_io_r_getprinterdata(char *desc, SPOOL_R_GETPRINTERDATA *r_u, prs_struct *ps, int depth);
|
BOOL spoolss_io_r_getprinterdata(char *desc, SPOOL_R_GETPRINTERDATA *r_u, prs_struct *ps, int depth);
|
||||||
|
@ -605,6 +605,15 @@ static BOOL spoolss_io_devmode(char *desc, prs_struct *ps, int depth, DEVICEMODE
|
|||||||
return True;
|
return True;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void free_spoolss_devmode(DEVICEMODE *devmode)
|
||||||
|
{
|
||||||
|
if (devmode == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
safe_free(devmode->private);
|
||||||
|
safe_free(devmode);
|
||||||
|
}
|
||||||
|
|
||||||
/*******************************************************************
|
/*******************************************************************
|
||||||
Read or write a DEVICEMODE container
|
Read or write a DEVICEMODE container
|
||||||
********************************************************************/
|
********************************************************************/
|
||||||
@ -752,6 +761,11 @@ BOOL spoolss_io_q_open_printer_ex(char *desc, SPOOL_Q_OPEN_PRINTER_EX *q_u, prs_
|
|||||||
return True;
|
return True;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void free_spoolss_q_open_printer_ex(SPOOL_Q_OPEN_PRINTER_EX *q_u)
|
||||||
|
{
|
||||||
|
free_spoolss_devmode(q_u->printer_default.devmode_cont.devmode);
|
||||||
|
}
|
||||||
|
|
||||||
/*******************************************************************
|
/*******************************************************************
|
||||||
* write a structure.
|
* write a structure.
|
||||||
* called from static spoolss_r_open_printer_ex (srv_spoolss.c)
|
* called from static spoolss_r_open_printer_ex (srv_spoolss.c)
|
||||||
|
@ -52,7 +52,7 @@ static BOOL api_spoolss_open_printer_ex(prs_struct *data, prs_struct *rdata)
|
|||||||
&r_u.handle);
|
&r_u.handle);
|
||||||
|
|
||||||
/* we _really_ need to switch to talloc() */
|
/* we _really_ need to switch to talloc() */
|
||||||
safe_free(q_u.printer_default.devmode_cont.devmode);
|
free_spoolss_q_open_printer_ex(&q_u);
|
||||||
|
|
||||||
if (!spoolss_io_r_open_printer_ex("",&r_u,rdata,0)){
|
if (!spoolss_io_r_open_printer_ex("",&r_u,rdata,0)){
|
||||||
DEBUG(0,("spoolss_io_r_open_printer_ex: unable to marshall SPOOL_R_OPEN_PRINTER_EX.\n"));
|
DEBUG(0,("spoolss_io_r_open_printer_ex: unable to marshall SPOOL_R_OPEN_PRINTER_EX.\n"));
|
||||||
|
@ -3109,7 +3109,8 @@ uint32 _spoolss_fcpn(const POLICY_HND *handle)
|
|||||||
Printer->notify.options=0;
|
Printer->notify.options=0;
|
||||||
Printer->notify.localmachine[0]='\0';
|
Printer->notify.localmachine[0]='\0';
|
||||||
Printer->notify.printerlocal=0;
|
Printer->notify.printerlocal=0;
|
||||||
safe_free(Printer->notify.option->ctr.type);
|
if (Printer->notify.option)
|
||||||
|
safe_free(Printer->notify.option->ctr.type);
|
||||||
safe_free(Printer->notify.option);
|
safe_free(Printer->notify.option);
|
||||||
Printer->notify.option=NULL;
|
Printer->notify.option=NULL;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user