Improved handling of message elements parsed. Reduces the memory occupied but
it introduces a small overhead in retrieving of message elements parsed.
This commit is contained in:
@ -20,36 +20,12 @@ static void capwap_wtpfallback_element_create(void* data, capwap_message_element
|
||||
struct capwap_wtpfallback_element* element = (struct capwap_wtpfallback_element*)data;
|
||||
|
||||
ASSERT(data != NULL);
|
||||
ASSERT((element->mode == CAPWAP_WTP_FALLBACK_ENABLED) || (element->mode == CAPWAP_WTP_FALLBACK_DISABLED));
|
||||
|
||||
/* */
|
||||
func->write_u8(handle, element->mode);
|
||||
}
|
||||
|
||||
/* */
|
||||
static void* capwap_wtpfallback_element_parsing(capwap_message_elements_handle handle, struct capwap_read_message_elements_ops* func) {
|
||||
struct capwap_wtpfallback_element* data;
|
||||
|
||||
ASSERT(handle != NULL);
|
||||
ASSERT(func != NULL);
|
||||
|
||||
if (func->read_ready(handle) != 1) {
|
||||
capwap_logging_debug("Invalid WTP Fallback element");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* */
|
||||
data = (struct capwap_wtpfallback_element*)capwap_alloc(sizeof(struct capwap_wtpfallback_element));
|
||||
if (!data) {
|
||||
capwap_outofmemory();
|
||||
}
|
||||
|
||||
/* Retrieve data */
|
||||
memset(data, 0, sizeof(struct capwap_wtpfallback_element));
|
||||
func->read_u8(handle, &data->mode);
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
/* */
|
||||
static void capwap_wtpfallback_element_free(void* data) {
|
||||
ASSERT(data != NULL);
|
||||
@ -57,6 +33,35 @@ static void capwap_wtpfallback_element_free(void* data) {
|
||||
capwap_free(data);
|
||||
}
|
||||
|
||||
/* */
|
||||
static void* capwap_wtpfallback_element_parsing(capwap_message_elements_handle handle, struct capwap_read_message_elements_ops* func) {
|
||||
struct capwap_wtpfallback_element* data;
|
||||
|
||||
ASSERT(handle != NULL);
|
||||
ASSERT(func != NULL);
|
||||
|
||||
if (func->read_ready(handle) != 1) {
|
||||
capwap_logging_debug("Invalid WTP Fallback element: underbuffer");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* */
|
||||
data = (struct capwap_wtpfallback_element*)capwap_alloc(sizeof(struct capwap_wtpfallback_element));
|
||||
if (!data) {
|
||||
capwap_outofmemory();
|
||||
}
|
||||
|
||||
/* Retrieve data */
|
||||
func->read_u8(handle, &data->mode);
|
||||
if ((data->mode != CAPWAP_WTP_FALLBACK_ENABLED) && (data->mode != CAPWAP_WTP_FALLBACK_DISABLED)) {
|
||||
capwap_wtpfallback_element_free((void*)data);
|
||||
capwap_logging_debug("Invalid WTP Fallback element: invalid mode");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
/* */
|
||||
struct capwap_message_elements_ops capwap_element_wtpfallback_ops = {
|
||||
.create_message_element = capwap_wtpfallback_element_create,
|
||||
|
Reference in New Issue
Block a user