interprocess_buffer.c File Reference

SNMP statistic module, interprocess buffer. More...

#include <net-snmp/net-snmp-config.h>
#include <net-snmp/net-snmp-includes.h>
#include <net-snmp/agent/net-snmp-agent-includes.h>
#include "interprocess_buffer.h"
#include "openserSIPContactTable.h"
#include "openserSIPRegUserTable.h"
#include "hashTable.h"
#include "utilities.h"
#include "../usrloc/ul_callback.h"

Include dependency graph for interprocess_buffer.c:

Go to the source code of this file.

Functions

void consumeInterprocessBuffer (void)
static void executeInterprocessBufferCmd (interprocessBuffer_t *currentBuffer)
void freeInterprocessBuffer (void)
void handleContactCallbacks (ucontact_t *contactInfo, int type, void *param)
int initInterprocessBuffers (void)

Variables

interprocessBuffer_tendRegUserTableBuffer
interprocessBuffer_tfrontRegUserTableBuffer
hashSlot_thashTable
gen_lock_t * interprocessCBLock


Detailed Description

SNMP statistic module, interprocess buffer.

This file implements the interprocess buffer, used for marshalling data exchange from the usrloc module to the openserSIPRegUserTable, openserSIPContactTable, and indirectly the openserSIPRegUserLookupTable.

Details on why the interprocess buffer is needed can be found in the comments at the top of interprocess_buffer.h

Definition in file interprocess_buffer.c.


Function Documentation

void consumeInterprocessBuffer ( void   ) 

Interprocess Buffer consumption Function. This function will iterate over every element of the interprocess buffer, and add or remove the specified contacts and users. Whether the contacts are added or removed is dependent on if the original element was added as a result of a UL_CONTACT_INSERT or UL_CONTACT_EXPIRE callback.

The function will free any memory occupied by the interprocess buffer.

Note:
This function is believed to be thread safe. Specifically, it protects corruption of the interprocess buffer through the interprocessCBLock. This ensures no corruption of the buffer by race conditions. The lock has been designed to be occupied for as short a period as possible, so as to prevent long waits. Specifically, once we start consumption of the list, other processes are free to continue even before we are done. This is made possible by simply changing the head of the interprocess buffer, and then releasing the lock.

Definition at line 208 of file interprocess_buffer.c.

References executeInterprocessBufferCmd(), interprocessCBLock, interprocessBuffer::next, NULL, shm_free, interprocessBuffer::stringContact, and interprocessBuffer::stringName.

Referenced by openserSIPContactTable_get_value(), openserSIPRegUserLookupTable_set_action(), and openserSIPRegUserTable_get_value().

static void executeInterprocessBufferCmd ( interprocessBuffer_t currentBuffer  )  [static]

void freeInterprocessBuffer ( void   ) 

void handleContactCallbacks ( ucontact_t contactInfo,
int  type,
void *  param 
)

USRLOC Callback Handler:

This function should be registered to receive callbacks from the usrloc module. It can be called for any of the callbacks listed in ul_callback.h. The callback type will be passed in 'type', and the contact the callback applies to will be supplied in 'contactInfo. This information will be copied into the interprocess buffer. The interprocess buffer will be consumed at a later time, when consumeInterprocessBuffer() is called.

This callback is thread safe with respect to the consumeInterprocessBuffer() function. Specifically, the interprocess buffer should not be corrupted by any race conditions between this function and the consumeInterprocessBuffer() function.

Definition at line 136 of file interprocess_buffer.c.

References ucontact::aor, ucontact::c, interprocessBuffer::callbackType, interprocessBuffer::contactInfo, convertStrToCharString(), interprocessCBLock, LM_ERR, interprocessBuffer::next, NULL, _str::s, shm_malloc(), interprocessBuffer::stringContact, and interprocessBuffer::stringName.

Referenced by registerForUSRLOCCallbacks().

int initInterprocessBuffers ( void   ) 

Initialize shared memory used to buffer communication between the usrloc module and the SNMPStats module. (Specifically, the user and contact tables)

Definition at line 85 of file interprocess_buffer.c.

References createHashTable(), HASH_SIZE, interprocessCBLock, LM_ERR, NULL, shm_free, and shm_malloc().

Referenced by mod_init().


Variable Documentation

Definition at line 68 of file interprocess_buffer.c.

All interprocess communication is stored between these two declarations.

Definition at line 67 of file interprocess_buffer.c.

The hash table:

1) maps all aor's to snmp's UserIndex for help in deleting SNMP Rows.

2) maps a given aor to a contact list.

Definition at line 64 of file interprocess_buffer.c.

Referenced by createHashTable(), openserSIPRegUserLookupTable_set_action(), and updateUser().

gen_lock_t* interprocessCBLock

This is to protect the potential racecondition in which a command is added to the buffer while it is being consumed

Definition at line 72 of file interprocess_buffer.c.

Referenced by consumeInterprocessBuffer(), handleContactCallbacks(), and initInterprocessBuffers().


Generated on Wed May 23 08:01:16 2012 for Kamailio - The Open Source SIP Server by  doxygen 1.5.6