0001-01-01 02:30:17 +02:30
/*
0001-01-01 02:30:17 +02:30
samba - - Unix SMB / CIFS implementation .
0001-01-01 02:30:17 +02:30
Copyright ( C ) 2001 , 2002 by Martin Pool
0001-01-01 02:30:17 +02:30
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 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 ) ) ;
}
0001-01-01 02:30:17 +02:30
/**
* Respond to a POOL_USAGE message by sending back string form of memory
* usage stats .
* */
2005-09-30 21:13:37 +04:00
void msg_pool_usage ( int msg_type , struct process_id src_pid ,
0001-01-01 02:30:17 +02:30
void * UNUSED ( buf ) , size_t UNUSED ( len ) )
0001-01-01 02:30:17 +02:30
{
2006-08-29 20:54:12 +04:00
struct msg_pool_usage_state state ;
0001-01-01 02:30:17 +02:30
SMB_ASSERT ( msg_type = = MSG_REQ_POOL_USAGE ) ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
DEBUG ( 2 , ( " Got POOL_USAGE \n " ) ) ;
0001-01-01 02:30:17 +02:30
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 ;
}
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
message_send_pid ( src_pid , MSG_POOL_USAGE ,
2006-08-29 20:54:12 +04:00
state . s , strlen ( state . s ) + 1 , True ) ;
2005-11-30 02:01:39 +03:00
2006-12-16 08:02:21 +03:00
talloc_destroy ( state . mem_ctx ) ;
0001-01-01 02:30:17 +02:30
}
/**
* 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 " ) ) ;
}