2002-01-03 06:53:41 +03:00
/*
2002-01-30 09:08:46 +03:00
samba - - Unix SMB / CIFS implementation .
2002-01-03 08:26:57 +03:00
Copyright ( C ) 2001 , 2002 by Martin Pool
2002-01-03 06:53:41 +03: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
2007-07-09 23:25:36 +04:00
the Free Software Foundation ; either version 3 of the License , or
2002-01-03 06:53:41 +03:00
( 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
2007-07-10 04:52:41 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2002-01-03 06:53:41 +03:00
*/
# include "includes.h"
/**
* @ file tallocmsg . c
*
* Glue code between talloc profiling and the Samba messaging system .
* */
2006-08-29 20:54:12 +04:00
struct msg_pool_usage_state {
2006-12-16 08:02:21 +03:00
TALLOC_CTX * mem_ctx ;
2006-08-29 20:54:12 +04:00
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 ) {
2006-12-16 08:02:21 +03:00
sprintf_append ( state - > mem_ctx , & state - > s , & state - > len , & state - > buflen ,
2006-08-29 20:54:12 +04:00
" %*sreference to: %s \n " , depth * 4 , " " , name ) ;
return ;
}
if ( depth = = 0 ) {
2006-12-16 08:02:21 +03:00
sprintf_append ( state - > mem_ctx , & state - > s , & state - > len , & state - > buflen ,
2006-08-29 20:54:12 +04:00
" %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 ;
}
2006-12-16 08:02:21 +03:00
sprintf_append ( state - > mem_ctx , & state - > s , & state - > len , & state - > buflen ,
2006-08-29 20:54:12 +04:00
" %*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 06:53:41 +03:00
/**
* Respond to a POOL_USAGE message by sending back string form of memory
* usage stats .
* */
2007-05-15 19:41:37 +04:00
static void msg_pool_usage ( struct messaging_context * msg_ctx ,
void * private_data ,
uint32_t msg_type ,
struct server_id src ,
DATA_BLOB * data )
2002-01-03 06:53:41 +03:00
{
2006-08-29 20:54:12 +04:00
struct msg_pool_usage_state state ;
2002-01-09 08:27:27 +03:00
SMB_ASSERT ( msg_type = = MSG_REQ_POOL_USAGE ) ;
2002-01-03 07:22:55 +03:00
2002-01-03 06:53:41 +03:00
DEBUG ( 2 , ( " Got POOL_USAGE \n " ) ) ;
2002-01-03 08:26:57 +03:00
2006-12-16 08:02:21 +03:00
state . mem_ctx = talloc_init ( " msg_pool_usage " ) ;
if ( ! state . mem_ctx ) {
return ;
}
2006-08-29 20:54:12 +04: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 ) {
2006-12-16 08:02:21 +03:00
talloc_destroy ( state . mem_ctx ) ;
2005-11-30 02:01:39 +03:00
return ;
}
2002-01-03 08:26:57 +03:00
2007-05-15 19:41:37 +04:00
messaging_send_buf ( msg_ctx , src , MSG_POOL_USAGE ,
( uint8 * ) state . s , strlen ( state . s ) + 1 ) ;
2005-11-30 02:01:39 +03:00
2006-12-16 08:02:21 +03:00
talloc_destroy ( state . mem_ctx ) ;
2002-01-03 06:53:41 +03:00
}
/**
* Register handler for MSG_REQ_POOL_USAGE
* */
2007-05-15 19:41:37 +04:00
void register_msg_pool_usage ( struct messaging_context * msg_ctx )
2002-01-03 06:53:41 +03:00
{
2007-05-15 19:41:37 +04:00
messaging_register ( msg_ctx , NULL , MSG_REQ_POOL_USAGE , msg_pool_usage ) ;
2002-01-03 06:53:41 +03:00
DEBUG ( 2 , ( " Registered MSG_REQ_POOL_USAGE \n " ) ) ;
}