#include <Transport_Cache_Manager.h>
Collaboration diagram for TAO_Transport_Cache_Manager:
Public Types | |
typedef ACE_Hash_Map_Manager< TAO_Cache_ExtId, TAO_Cache_IntId, ACE_Null_Mutex> | HASH_MAP |
typedef ACE_Hash_Map_Iterator< TAO_Cache_ExtId, TAO_Cache_IntId, ACE_Null_Mutex> | HASH_MAP_ITER |
typedef ACE_Hash_Map_Entry< TAO_Cache_ExtId, TAO_Cache_IntId> | HASH_MAP_ENTRY |
Public Methods | |
TAO_Transport_Cache_Manager (TAO_ORB_Core &orb_core) | |
Constructor. | |
virtual | ~TAO_Transport_Cache_Manager (void) |
Destructor. | |
int | cache_transport (TAO_Transport_Descriptor_Interface *prop, TAO_Transport *transport) |
Add the transport to the cache. The transport has the property definition based on which caching can be done. | |
int | find_transport (TAO_Transport_Descriptor_Interface *prop, TAO_Transport *&transport) |
Check the Transport Cache to check whether the connection exists in the Cache and return the connection. | |
int | purge (void) |
Remove entries from the cache depending upon the strategy. | |
int | purge_entry (HASH_MAP_ENTRY *&) |
Purge the entry from the Cache Map. | |
void | mark_invalid (HASH_MAP_ENTRY *&) |
Mark the entry as invalid for use but keep it in cache. | |
int | make_idle (HASH_MAP_ENTRY *&entry) |
Make the entry idle and ready for use. | |
int | close (ACE_Handle_Set &reactor_registered, TAO_EventHandlerSet &unregistered) |
Close the underlying hash map manager and return the handle set that have been registered with the reactor. | |
size_t | current_size (void) const |
Return the current size of the cache. | |
size_t | total_size (void) const |
Return the total size of the cache. | |
Private Types | |
typedef HASH_MAP_ENTRY** | DESCRIPTOR_SET |
Private Methods | |
int | bind (TAO_Cache_ExtId &ext_id, TAO_Cache_IntId &int_id) |
Associate <ext_id> with <int_id>. Grabs the lock and calls the implementation function bind_i. | |
int | find (const TAO_Cache_ExtId &key, TAO_Cache_IntId &value) |
Lookup entry<key,value> in the cache. Grabs the lock and calls the implementation function find_i. | |
int | rebind (const TAO_Cache_ExtId &key, const TAO_Cache_IntId &value) |
Reassociate the <key> with <value>. Grabs the lock and calls the implementation function find_i. | |
int | unbind (const TAO_Cache_ExtId &key) |
Remove <key> from the cache. | |
int | unbind (const TAO_Cache_ExtId &key, TAO_Cache_IntId &value) |
Remove <key> from the cache, and return the <value> associated with <key>. | |
int | bind_i (TAO_Cache_ExtId &ext_id, TAO_Cache_IntId &int_id) |
int | find_i (const TAO_Cache_ExtId &key, TAO_Cache_IntId &value) |
int | rebind_i (const TAO_Cache_ExtId &key, const TAO_Cache_IntId &value) |
Non-locking version and actual implementation of rebind () call. | |
int | unbind_i (const TAO_Cache_ExtId &key) |
Non-locking version and actual implementation of unbind () call. | |
int | unbind_i (const TAO_Cache_ExtId &key, TAO_Cache_IntId &value) |
Non-locking version and actual implementation of unbind () call. | |
int | make_idle_i (HASH_MAP_ENTRY *&entry) |
Non-locking version and actual implementation of make_idle (). | |
int | close_i (ACE_Handle_Set &reactor_registered, TAO_EventHandlerSet &unregistered) |
Non-locking version and actual implementation of close (). | |
int | purge_entry_i (HASH_MAP_ENTRY *&entry) |
Purge the entry from the Cache Map. | |
void | mark_invalid_i (HASH_MAP_ENTRY *&) |
Mark the entry as invalid for use but keep it in cache. | |
int | get_last_index_bind (TAO_Cache_ExtId &key, TAO_Cache_IntId &val, HASH_MAP_ENTRY *&entry) |
int | is_entry_idle (HASH_MAP_ENTRY *&entry) |
void | sort_set (DESCRIPTOR_SET& entries, int size) |
Sort the list of entries. | |
int | fill_set_i (DESCRIPTOR_SET& sorted_set) |
Fill sorted_set in with the TAO_Transport_Descriptor_Interface's in a sorted order. | |
void | close_entries (DESCRIPTOR_SET& sorted_set, int size) |
Look through the sorted set and close the connection on the required number of items in the set. | |
Private Attributes | |
int | percent_ |
The percentage of the cache to purge at one time. | |
TAO_Connection_Purging_Strategy* | purging_strategy_ |
The underlying connection purging strategy. | |
HASH_MAP | cache_map_ |
The hash map that has the connections. | |
ACE_Lock* | cache_lock_ |
Lock for the map. | |
Static Private Methods | |
int | cpscmp (const void* a, const void* b) |
Used by qsort. |
|
|
|
|
|
|
|
|
|
Constructor.
|
|
Destructor.
|
|
Associate <ext_id> with <int_id>. Grabs the lock and calls the implementation function bind_i.
|
|
Non-Locking version and actual implementation of bind () call. Calls bind on the Hash_Map_Manager that it holds. If the bind succeeds, it adds the Hash_Map_Entry in to the Transport for its reference. If the bind fails because of an exiting entry, this method calls the get_last_index_bind (). |
|
Add the transport to the cache. The transport has the property definition based on which caching can be done.
|
|
Close the underlying hash map manager and return the handle set that have been registered with the reactor.
|
|
Look through the sorted set and close the connection on the required number of items in the set.
|
|
Non-locking version and actual implementation of close ().
|
|
Used by qsort.
|
|
Return the current size of the cache.
|
|
Fill sorted_set in with the TAO_Transport_Descriptor_Interface's in a sorted order.
|
|
Lookup entry<key,value> in the cache. Grabs the lock and calls the implementation function find_i.
|
|
Non-locking version and actual implementation of find () call. This calls the find () on the underlying Hash_Map_Manager. If the find succeeds, it calls the get_idle_transport (). |
|
Check the Transport Cache to check whether the connection exists in the Cache and return the connection.
|
|
This is called by the bind () call when a bind fails with a available entry. When a new connection is created in TAO with an already existing endpoint, in addition to an exisitng one, we mark the connections with an index. This method, finds out the last highest index and binds the entry with an index = (last highest index + 1). |
|
Tries to find if the <int_id_> in entry is idle for use. If it is idle it is immediately markes as busy and returns a value of 1, else it returns a value of 0 |
|
Make the entry idle and ready for use.
|
|
Non-locking version and actual implementation of make_idle ().
|
|
Mark the entry as invalid for use but keep it in cache.
|
|
Mark the entry as invalid for use but keep it in cache.
|
|
Remove entries from the cache depending upon the strategy.
|
|
Purge the entry from the Cache Map.
|
|
Purge the entry from the Cache Map.
|
|
Reassociate the <key> with <value>. Grabs the lock and calls the implementation function find_i.
|
|
Non-locking version and actual implementation of rebind () call.
|
|
Sort the list of entries.
|
|
Return the total size of the cache.
|
|
Remove <key> from the cache, and return the <value> associated with <key>.
|
|
Remove <key> from the cache.
|
|
Non-locking version and actual implementation of unbind () call.
|
|
Non-locking version and actual implementation of unbind () call.
|
|
Lock for the map.
|
|
The hash map that has the connections.
|
|
The percentage of the cache to purge at one time.
|
|
The underlying connection purging strategy.
|