2002-01-03 03:53:41 +00:00
/*
2002-01-30 06:08:46 +00:00
samba - - Unix SMB / CIFS implementation .
2002-01-03 05:26:57 +00:00
Copyright ( C ) 2001 , 2002 by Martin Pool
2002-01-03 03:53:41 +00:00
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 0213 9 , USA .
*/
# include "includes.h"
/**
* @ file tallocmsg . c
*
* Glue code between talloc profiling and the Samba messaging system .
* */
2006-08-29 16:54:12 +00:00
struct msg_pool_usage_state {
ssize_t len ;
size_t buflen ;
char * s ;
} ;
static void msg_pool_usage_helper ( const void * ptr , int depth , int max_depth , int is_ref , void * _s )
{
const char * name = talloc_get_name ( ptr ) ;
struct msg_pool_usage_state * state = ( struct msg_pool_usage_state * ) _s ;
if ( is_ref ) {
sprintf_append ( NULL , & state - > s , & state - > len , & state - > buflen ,
" %*sreference to: %s \n " , depth * 4 , " " , name ) ;
return ;
}
if ( depth = = 0 ) {
sprintf_append ( NULL , & state - > s , & state - > len , & state - > buflen ,
" %stalloc report on '%s' (total %6lu bytes in %3lu blocks) \n " ,
( max_depth < 0 ? " full " : " " ) , name ,
( unsigned long ) talloc_total_size ( ptr ) ,
( unsigned long ) talloc_total_blocks ( ptr ) ) ;
return ;
}
sprintf_append ( NULL , & state - > s , & state - > len , & state - > buflen ,
" %*s%-30s contains %6lu bytes in %3lu blocks (ref %d) \n " ,
depth * 4 , " " ,
name ,
( unsigned long ) talloc_total_size ( ptr ) ,
( unsigned long ) talloc_total_blocks ( ptr ) ,
talloc_reference_count ( ptr ) ) ;
}
2002-01-03 03:53:41 +00:00
/**
* Respond to a POOL_USAGE message by sending back string form of memory
* usage stats .
* */
2005-09-30 17:13:37 +00:00
void msg_pool_usage ( int msg_type , struct process_id src_pid ,
2002-01-09 05:27:27 +00:00
void * UNUSED ( buf ) , size_t UNUSED ( len ) )
2002-01-03 03:53:41 +00:00
{
2006-08-29 16:54:12 +00:00
struct msg_pool_usage_state state ;
2002-01-09 05:27:27 +00:00
SMB_ASSERT ( msg_type = = MSG_REQ_POOL_USAGE ) ;
2002-01-03 04:22:55 +00:00
2002-01-03 03:53:41 +00:00
DEBUG ( 2 , ( " Got POOL_USAGE \n " ) ) ;
2002-01-03 05:26:57 +00:00
2006-08-29 16:54:12 +00:00
state . len = 0 ;
state . buflen = 512 ;
state . s = NULL ;
talloc_report_depth_cb ( NULL , 0 , - 1 , msg_pool_usage_helper , & state ) ;
if ( ! state . s ) {
2005-11-29 23:01:39 +00:00
return ;
}
2002-01-03 05:26:57 +00:00
2002-01-03 04:22:55 +00:00
message_send_pid ( src_pid , MSG_POOL_USAGE ,
2006-08-29 16:54:12 +00:00
state . s , strlen ( state . s ) + 1 , True ) ;
2005-11-29 23:01:39 +00:00
2006-08-29 16:54:12 +00:00
SAFE_FREE ( state . s ) ;
2002-01-03 03:53:41 +00:00
}
/**
* Register handler for MSG_REQ_POOL_USAGE
* */
void register_msg_pool_usage ( void )
{
message_register ( MSG_REQ_POOL_USAGE , msg_pool_usage ) ;
DEBUG ( 2 , ( " Registered MSG_REQ_POOL_USAGE \n " ) ) ;
}