version 1.2, 2001/12/13 14:53:49
|
version 1.34, 2004/07/19 06:06:56
|
|
|
//%////////////////////////////////////////////////////////////////////////// |
//%2003//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Development |
|
// Company, L. P., IBM Corp., The Open Group, Tivoli Systems. |
|
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L. P.; |
|
// IBM Corp.; EMC Corporation, The Open Group. |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// | // |
// Author: Mike Day (mdday@us.ibm.com) | // Author: Mike Day (mdday@us.ibm.com) |
// | // |
// Modified By: |
// Modified By: Amit K Arora, IBM (amita@in.ibm.com) for Bug#1188 |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
#include <Pegasus/Common/AsyncOpNode.h> | #include <Pegasus/Common/AsyncOpNode.h> |
|
#include <Pegasus/Common/InternalException.h> |
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
AsyncOpNode::AsyncOpNode(void) |
#if defined(PEGASUS_PLATFORM_WIN32_IX86_MSVC) |
: _client_sem(1), _mut(), _request(0), _response(0), |
#define snprintf _snprintf |
_state(0), _flags(0), _total_ops(0), _completed_ops(0), |
#endif |
_parent(0), _children(true) |
|
|
// AsyncOpNode * AsyncOpNode::_headOfFreeList; |
|
// const int AsyncOpNode::BLOCK_SIZE = 200; |
|
// Mutex AsyncOpNode::_alloc_mut; |
|
|
|
// void * AsyncOpNode::operator new(size_t size) |
|
// { |
|
// if(size != sizeof(AsyncOpNode)) |
|
// return :: operator new(size); |
|
|
|
// _alloc_mut.lock(pegasus_thread_self()); |
|
|
|
// AsyncOpNode *node = _headOfFreeList; |
|
// if(node) |
|
// _headOfFreeList = node->_parent; |
|
// else |
|
// { |
|
// AsyncOpNode * newBlock = |
|
// reinterpret_cast<AsyncOpNode *>(::operator new( BLOCK_SIZE * sizeof(AsyncOpNode))); |
|
// int i; |
|
// for( i = 1; i < BLOCK_SIZE - 1; ++i) |
|
// newBlock[i]._parent = &newBlock[i + 1]; |
|
// newBlock[BLOCK_SIZE - 1]._parent = NULL; |
|
// node = newBlock; |
|
// _headOfFreeList = &newBlock[1]; |
|
// } |
|
// _alloc_mut.unlock(); |
|
// return node; |
|
// } |
|
|
|
// void AsyncOpNode::operator delete(void *dead, size_t size) |
|
// { |
|
|
|
// if(dead == 0) |
|
// return; |
|
// if(size != sizeof(AsyncOpNode)) |
|
// { |
|
// ::operator delete(dead); |
|
// return; |
|
// } |
|
// AsyncOpNode *node = reinterpret_cast<AsyncOpNode *>(dead); |
|
// _alloc_mut.lock(pegasus_thread_self()); |
|
// node->_parent = _headOfFreeList; |
|
// _headOfFreeList = node; |
|
// _alloc_mut.unlock(); |
|
// } |
|
|
| |
|
AsyncOpNode::AsyncOpNode(void) |
|
: _client_sem(0), _request(true), _response(true), |
|
_state(0), _flags(0), _offered_count(0), _total_ops(0), _completed_ops(0), |
|
_user_data(0), _completion_code(0), _op_dest(0), |
|
_parent(0), _children(true), _async_callback(0),__async_callback(0), |
|
_callback_node(0), _callback_response_q(0), |
|
_callback_ptr(0), _callback_parameter(0), |
|
_callback_handle(0), _callback_notify(0), _callback_request_q(0) |
{ | { |
memset(&_start, 0x00, sizeof(struct timeval)); |
gettimeofday(&_start, NULL); |
memset(&_lifetime, 0x00, sizeof(struct timeval)); | memset(&_lifetime, 0x00, sizeof(struct timeval)); |
memset(&_updated, 0x00, sizeof(struct timeval)); | memset(&_updated, 0x00, sizeof(struct timeval)); |
memset(&_timeout_interval, 0xff, sizeof(struct timeval)); |
_timeout_interval.tv_sec = 60; |
|
_timeout_interval.tv_usec = 100; |
} | } |
| |
AsyncOpNode::~AsyncOpNode(void) | AsyncOpNode::~AsyncOpNode(void) |
{ | { |
delete _request; |
_request.empty_list(); |
delete _response; |
_response.empty_list(); |
} | } |
| |
|
|
void AsyncOpNode::_reset(unlocked_dq<AsyncOpNode> *dst_q) | void AsyncOpNode::_reset(unlocked_dq<AsyncOpNode> *dst_q) |
{ | { |
AsyncOpNode *child = _children.remove_first(); | AsyncOpNode *child = _children.remove_first(); |
|
|
} | } |
| |
_parent = 0; | _parent = 0; |
delete _request; |
_request.empty_list(); |
delete _response; |
_response.empty_list(); |
_operation_list.reset(); |
|
|
//_operation_list.reset(); |
_state = 0; | _state = 0; |
_flags = 0; | _flags = 0; |
|
_offered_count = 0; |
_total_ops = 0; | _total_ops = 0; |
_completed_ops = 0; | _completed_ops = 0; |
|
_user_data = 0; |
|
_completion_code = 0; |
|
_op_dest = 0; |
|
_async_callback = 0; |
|
__async_callback = 0; |
|
_callback_node =0; |
|
_callback_response_q = 0; |
|
_callback_ptr=0; |
|
_callback_parameter = 0; |
|
_callback_handle = 0; |
|
_callback_notify = 0; |
|
_callback_request_q = 0; |
dst_q->insert_first(this); | dst_q->insert_first(this); |
|
while ( _client_sem.count() ) |
|
_client_sem.wait(); |
|
PEGASUS_ASSERT( _client_sem.count() == 0 ); |
|
|
|
return; |
|
} |
|
|
|
void AsyncOpNode::print_to_buffer(Sint8 **buf) |
|
{ |
|
if(buf == NULL) |
|
return; |
|
|
|
#if !defined(PEGASUS_PLATFORM_ZOS_ZSERIES_IBM) |
|
static Sint8 work_buf[4096]; |
|
snprintf(work_buf, 4096, "AsyncOpNode %p\n" \ |
|
"\trq %d; rp %d; state %d; flags %d; op_dst q %p\n" \ |
|
"\tcallback node %p; callback rp q %p; callback ptr %p\n" \ |
|
"\tcallback parm %p; callback handle %p; callback notify %p\n" \ |
|
"\tcallback rq q %p; service %p; thread %p\n\n", |
|
this, _request.count(), _response.count(), |
|
_state, _flags, _op_dest, _callback_node, _callback_response_q, |
|
_callback_ptr, _callback_parameter, _callback_handle, _callback_notify, |
|
_callback_request_q, _service_ptr, _thread_ptr); |
|
*buf = strdup(work_buf); |
|
#endif |
return; | return; |
|
|
} | } |
| |
|
String AsyncOpNode::print_to_string(void) |
|
{ |
|
static Sint8 work_buf[4096]; |
|
#if !defined(PEGASUS_PLATFORM_ZOS_ZSERIES_IBM) |
|
snprintf(work_buf, 4096, "AsyncOpNode %p\n" \ |
|
"\trq %d; rp %d; state %d; flags %d; op_dst q %p\n" \ |
|
"\tcallback node %p; callback rp q %p; callback ptr %p\n" \ |
|
"\tcallback parm %p; callback handle %p; callback notify %p\n" \ |
|
"\tcallback rq q %p; service %p; thread %p\n\n", |
|
this, _request.count(), _response.count(), |
|
_state, _flags, _op_dest, _callback_node, _callback_response_q, |
|
_callback_ptr, _callback_parameter, _callback_handle, _callback_notify, |
|
_callback_request_q, _service_ptr, _thread_ptr); |
|
#else |
|
work_buf[0] = (char)0; |
|
#endif |
|
|
|
return String(work_buf); |
|
} |
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |