Improve memory administration for tx/rx packet manager
This commit is contained in:
@ -10,72 +10,56 @@
|
||||
+-+-+-+-+-+-+-+-+
|
||||
|
||||
Type: 41 for WTP Frame Tunnel Mode
|
||||
|
||||
Length: 1
|
||||
|
||||
********************************************************************/
|
||||
|
||||
struct capwap_wtpframetunnelmode_raw_element {
|
||||
unsigned char mode;
|
||||
} __attribute__((__packed__));
|
||||
|
||||
/* */
|
||||
struct capwap_message_element* capwap_wtpframetunnelmode_element_create(void* data, unsigned long datalength) {
|
||||
struct capwap_message_element* element;
|
||||
struct capwap_wtpframetunnelmode_raw_element* dataraw;
|
||||
struct capwap_wtpframetunnelmode_element* dataelement = (struct capwap_wtpframetunnelmode_element*)data;
|
||||
|
||||
static void capwap_wtpframetunnelmode_element_create(void* data, capwap_message_elements_handle handle, struct capwap_write_message_elements_ops* func) {
|
||||
struct capwap_wtpframetunnelmode_element* element = (struct capwap_wtpframetunnelmode_element*)data;
|
||||
|
||||
ASSERT(data != NULL);
|
||||
ASSERT(datalength >= sizeof(struct capwap_wtpframetunnelmode_element));
|
||||
|
||||
/* Alloc block of memory */
|
||||
element = capwap_alloc(sizeof(struct capwap_message_element) + sizeof(struct capwap_wtpframetunnelmode_raw_element));
|
||||
if (!element) {
|
||||
capwap_outofmemory();
|
||||
}
|
||||
|
||||
/* Create message element */
|
||||
memset(element, 0, sizeof(struct capwap_message_element) + sizeof(struct capwap_wtpframetunnelmode_raw_element));
|
||||
element->type = htons(CAPWAP_ELEMENT_WTPFRAMETUNNELMODE);
|
||||
element->length = htons(sizeof(struct capwap_wtpframetunnelmode_raw_element));
|
||||
|
||||
dataraw = (struct capwap_wtpframetunnelmode_raw_element*)element->data;
|
||||
dataraw->mode = dataelement->mode & CAPWAP_WTP_FRAME_TUNNEL_MODE_MASK;
|
||||
return element;
|
||||
/* */
|
||||
func->write_u8(handle, element->mode & CAPWAP_WTP_FRAME_TUNNEL_MODE_MASK);
|
||||
}
|
||||
|
||||
/* */
|
||||
int capwap_wtpframetunnelmode_element_validate(struct capwap_message_element* element) {
|
||||
/* TODO */
|
||||
return 1;
|
||||
}
|
||||
|
||||
/* */
|
||||
void* capwap_wtpframetunnelmode_element_parsing(struct capwap_message_element* element) {
|
||||
static void* capwap_wtpframetunnelmode_element_parsing(capwap_message_elements_handle handle, struct capwap_read_message_elements_ops* func) {
|
||||
struct capwap_wtpframetunnelmode_element* data;
|
||||
struct capwap_wtpframetunnelmode_raw_element* dataraw;
|
||||
|
||||
ASSERT(element);
|
||||
ASSERT(ntohs(element->type) == CAPWAP_ELEMENT_WTPFRAMETUNNELMODE);
|
||||
|
||||
if (ntohs(element->length) != 1) {
|
||||
|
||||
ASSERT(handle != NULL);
|
||||
ASSERT(func != NULL);
|
||||
|
||||
if (func->read_ready(handle) != 1) {
|
||||
capwap_logging_debug("Invalid WTP Frame Tunnel Mode element");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* */
|
||||
dataraw = (struct capwap_wtpframetunnelmode_raw_element*)element->data;
|
||||
data = (struct capwap_wtpframetunnelmode_element*)capwap_alloc(sizeof(struct capwap_wtpframetunnelmode_element));
|
||||
if (!data) {
|
||||
capwap_outofmemory();
|
||||
}
|
||||
|
||||
/* */
|
||||
data->mode = dataraw->mode & CAPWAP_WTP_FRAME_TUNNEL_MODE_MASK;
|
||||
/* Retrieve data */
|
||||
memset(data, 0, sizeof(struct capwap_wtpframetunnelmode_element));
|
||||
func->read_u8(handle, &data->mode);
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
/* */
|
||||
void capwap_wtpframetunnelmode_element_free(void* data) {
|
||||
static void capwap_wtpframetunnelmode_element_free(void* data) {
|
||||
ASSERT(data != NULL);
|
||||
|
||||
capwap_free(data);
|
||||
}
|
||||
|
||||
/* */
|
||||
struct capwap_message_elements_ops capwap_element_wtpframetunnelmode_ops = {
|
||||
.create_message_element = capwap_wtpframetunnelmode_element_create,
|
||||
.parsing_message_element = capwap_wtpframetunnelmode_element_parsing,
|
||||
.free_parsed_message_element = capwap_wtpframetunnelmode_element_free
|
||||
};
|
||||
|
Reference in New Issue
Block a user