2013-06-02 22:21:49 +02:00
|
|
|
#include "capwap.h"
|
|
|
|
#include "capwap_element.h"
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
|
|
|
|
0 1 2 3
|
|
|
|
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
|
|
|
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
|
|
| Num of Entries| Length | MAC Address ...
|
|
|
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
|
|
|
|
|
|
|
Type: 17 for Delete MAC ACL Entry
|
|
|
|
|
|
|
|
Length: >= 8
|
|
|
|
|
|
|
|
********************************************************************/
|
|
|
|
|
|
|
|
/* */
|
|
|
|
static void capwap_deletemacacl_element_create(void* data, capwap_message_elements_handle handle, struct capwap_write_message_elements_ops* func) {
|
|
|
|
struct capwap_deletemacacl_element* element = (struct capwap_deletemacacl_element*)data;
|
|
|
|
|
|
|
|
ASSERT(data != NULL);
|
2013-06-09 17:41:52 +02:00
|
|
|
ASSERT(element->entry > 0);
|
|
|
|
ASSERT(IS_VALID_MACADDRESS_LENGTH(element->length));
|
2013-06-02 22:21:49 +02:00
|
|
|
|
|
|
|
func->write_u8(handle, element->entry);
|
|
|
|
func->write_u8(handle, element->length);
|
|
|
|
func->write_block(handle, element->address, element->entry * element->length);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* */
|
|
|
|
static void capwap_deletemacacl_element_free(void* data) {
|
|
|
|
struct capwap_deletemacacl_element* element = (struct capwap_deletemacacl_element*)data;
|
|
|
|
|
|
|
|
ASSERT(data != NULL);
|
|
|
|
|
|
|
|
if (element->address) {
|
|
|
|
capwap_free(element->address);
|
|
|
|
}
|
|
|
|
|
2013-06-09 17:41:52 +02:00
|
|
|
capwap_free(data);
|
2013-06-02 22:21:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* */
|
|
|
|
static void* capwap_deletemacacl_element_parsing(capwap_message_elements_handle handle, struct capwap_read_message_elements_ops* func) {
|
|
|
|
unsigned short length;
|
|
|
|
struct capwap_deletemacacl_element* data;
|
|
|
|
|
|
|
|
ASSERT(handle != NULL);
|
|
|
|
ASSERT(func != NULL);
|
|
|
|
|
|
|
|
length = func->read_ready(handle);
|
|
|
|
if (length < 8) {
|
2013-06-09 17:41:52 +02:00
|
|
|
capwap_logging_debug("Invalid Delete MAC ACL Entry element: underbuffer");
|
2013-06-02 22:21:49 +02:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
length -= 2;
|
|
|
|
|
|
|
|
/* */
|
|
|
|
data = (struct capwap_deletemacacl_element*)capwap_alloc(sizeof(struct capwap_deletemacacl_element));
|
|
|
|
if (!data) {
|
|
|
|
capwap_outofmemory();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Retrieve data */
|
|
|
|
memset(data, 0, sizeof(struct capwap_deletemacacl_element));
|
|
|
|
func->read_u8(handle, &data->entry);
|
|
|
|
func->read_u8(handle, &data->length);
|
|
|
|
|
2013-06-09 17:41:52 +02:00
|
|
|
if (!data->entry) {
|
|
|
|
capwap_deletemacacl_element_free((void*)data);
|
|
|
|
capwap_logging_debug("Invalid Delete MAC ACL Entry element: invalid entry");
|
|
|
|
return NULL;
|
|
|
|
} else if (!IS_VALID_MACADDRESS_LENGTH(data->length)) {
|
|
|
|
capwap_deletemacacl_element_free((void*)data);
|
|
|
|
capwap_logging_debug("Invalid Delete MAC ACL Entry element: invalid length");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-06-02 22:21:49 +02:00
|
|
|
if (length != (data->entry * data->length)) {
|
|
|
|
capwap_deletemacacl_element_free((void*)data);
|
|
|
|
capwap_logging_debug("Invalid Delete MAC ACL Entry element");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
data->address = (uint8_t*)capwap_alloc(length);
|
|
|
|
if (!data->address) {
|
|
|
|
capwap_outofmemory();
|
|
|
|
}
|
|
|
|
|
|
|
|
func->read_block(handle, data->address, length);
|
|
|
|
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* */
|
|
|
|
struct capwap_message_elements_ops capwap_element_deletemacacl_ops = {
|
|
|
|
.create_message_element = capwap_deletemacacl_element_create,
|
|
|
|
.parsing_message_element = capwap_deletemacacl_element_parsing,
|
|
|
|
.free_parsed_message_element = capwap_deletemacacl_element_free
|
|
|
|
};
|