mtu discovery padding added
FossilOrigin-Name: 391a17b2ab460b54a220c3e128578a37610e71f524b3d127316f201bf4dfd4af
This commit is contained in:
parent
4171d208d0
commit
41688c4e60
@ -1,9 +1,9 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<CodeLite_Workspace Name="actube" Database="">
|
<CodeLite_Workspace Name="actube" Database="">
|
||||||
<Project Name="ac" Path="ac.project" Active="Yes"/>
|
<Project Name="ac" Path="ac.project" Active="No"/>
|
||||||
<Project Name="wtp" Path="wtp.project" Active="No"/>
|
<Project Name="wtp" Path="wtp.project" Active="No"/>
|
||||||
<Project Name="mod_cipwap" Path="mod_cipwap.project" Active="No"/>
|
<Project Name="mod_cipwap" Path="mod_cipwap.project" Active="No"/>
|
||||||
<Project Name="mod_capwap" Path="mod_capwap.project" Active="No"/>
|
<Project Name="mod_capwap" Path="mod_capwap.project" Active="Yes"/>
|
||||||
<Project Name="mod_cisco" Path="mod_cisco.project" Active="No"/>
|
<Project Name="mod_cisco" Path="mod_cisco.project" Active="No"/>
|
||||||
<Project Name="libcw" Path="libcw.project" Active="No"/>
|
<Project Name="libcw" Path="libcw.project" Active="No"/>
|
||||||
<Project Name="mod_capwap80211" Path="mod_capwap80211.project" Active="No"/>
|
<Project Name="mod_capwap80211" Path="mod_capwap80211.project" Active="No"/>
|
||||||
|
@ -93,7 +93,6 @@
|
|||||||
<File Name="src/cw/cw_in_wtp_reboot_statistics.c"/>
|
<File Name="src/cw/cw_in_wtp_reboot_statistics.c"/>
|
||||||
<File Name="src/cw/mlist.c"/>
|
<File Name="src/cw/mlist.c"/>
|
||||||
<File Name="src/cw/netconn.c"/>
|
<File Name="src/cw/netconn.c"/>
|
||||||
<File Name="src/cw/mavl_create_conststr.c"/>
|
|
||||||
<File Name="src/cw/cw_in_capwap_local_ipv6_address.c"/>
|
<File Name="src/cw/cw_in_capwap_local_ipv6_address.c"/>
|
||||||
<File Name="src/cw/cw_out_capwap_local_ip_address.c"/>
|
<File Name="src/cw/cw_out_capwap_local_ip_address.c"/>
|
||||||
<File Name="src/cw/cw_out_wtp_descriptor.c"/>
|
<File Name="src/cw/cw_out_wtp_descriptor.c"/>
|
||||||
@ -257,7 +256,6 @@
|
|||||||
<File Name="src/cw/lw_put_80211_wtp_wlan_radio_configuration.c"/>
|
<File Name="src/cw/lw_put_80211_wtp_wlan_radio_configuration.c"/>
|
||||||
<File Name="src/cw/cw_put_image_data.c"/>
|
<File Name="src/cw/cw_put_image_data.c"/>
|
||||||
<File Name="src/cw/cw_util.c"/>
|
<File Name="src/cw/cw_util.c"/>
|
||||||
<File Name="src/cw/cw_in_mtu_discovery_padding.c"/>
|
|
||||||
<File Name="src/cw/conn_create_noq.c"/>
|
<File Name="src/cw/conn_create_noq.c"/>
|
||||||
<File Name="src/cw/cw_addelem_cisco_wtp_radio_cfg.c"/>
|
<File Name="src/cw/cw_addelem_cisco_wtp_radio_cfg.c"/>
|
||||||
<File Name="src/cw/mavl_del.c"/>
|
<File Name="src/cw/mavl_del.c"/>
|
||||||
@ -322,10 +320,14 @@
|
|||||||
<File Name="src/cw/msget.h"/>
|
<File Name="src/cw/msget.h"/>
|
||||||
<File Name="src/cw/mavl_replace.c"/>
|
<File Name="src/cw/mavl_replace.c"/>
|
||||||
<File Name="src/cw/cw_kvt_add.c"/>
|
<File Name="src/cw/cw_kvt_add.c"/>
|
||||||
|
<File Name="src/cw/mlist_create.c"/>
|
||||||
|
<File Name="src/cw/mlist_append.c"/>
|
||||||
</VirtualDirectory>
|
</VirtualDirectory>
|
||||||
</VirtualDirectory>
|
</VirtualDirectory>
|
||||||
<Description/>
|
<Description/>
|
||||||
<Dependencies/>
|
<Dependencies/>
|
||||||
|
<Dependencies Name="Debug"/>
|
||||||
|
<Dependencies Name="Release"/>
|
||||||
<Settings Type="Static Library">
|
<Settings Type="Static Library">
|
||||||
<GlobalSettings>
|
<GlobalSettings>
|
||||||
<Compiler Options="" C_Options="" Assembler="">
|
<Compiler Options="" C_Options="" Assembler="">
|
||||||
@ -342,7 +344,7 @@
|
|||||||
</Compiler>
|
</Compiler>
|
||||||
<Linker Options="" Required="yes"/>
|
<Linker Options="" Required="yes"/>
|
||||||
<ResourceCompiler Options="" Required="no"/>
|
<ResourceCompiler Options="" Required="no"/>
|
||||||
<General OutputFile="" IntermediateDirectory="./Debug" Command="" CommandArguments="" UseSeparateDebugArgs="no" DebugArguments="" WorkingDirectory="$(IntermediateDirectory)" PauseExecWhenProcTerminates="yes" IsGUIProgram="no" IsEnabled="yes"/>
|
<General OutputFile="" IntermediateDirectory="./Debug" Command="$(WorkspacePath)/src/ac/actube" CommandArguments="" UseSeparateDebugArgs="no" DebugArguments="" WorkingDirectory="$(IntermediateDirectory)" PauseExecWhenProcTerminates="yes" IsGUIProgram="no" IsEnabled="yes"/>
|
||||||
<Environment EnvVarSetName="<Use Defaults>" DbgSetName="<Use Defaults>">
|
<Environment EnvVarSetName="<Use Defaults>" DbgSetName="<Use Defaults>">
|
||||||
<![CDATA[]]>
|
<![CDATA[]]>
|
||||||
</Environment>
|
</Environment>
|
||||||
@ -413,6 +415,4 @@
|
|||||||
</Completion>
|
</Completion>
|
||||||
</Configuration>
|
</Configuration>
|
||||||
</Settings>
|
</Settings>
|
||||||
<Dependencies Name="Debug"/>
|
|
||||||
<Dependencies Name="Release"/>
|
|
||||||
</CodeLite_Project>
|
</CodeLite_Project>
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
<File Name="src/mod/capwap/capwap_out_get_idle_timeout.c"/>
|
<File Name="src/mod/capwap/capwap_out_get_idle_timeout.c"/>
|
||||||
<File Name="src/mod/capwap/capwap_actions_ac.c"/>
|
<File Name="src/mod/capwap/capwap_actions_ac.c"/>
|
||||||
<File Name="src/mod/capwap/capwap_in_vendor_specific_payload.c"/>
|
<File Name="src/mod/capwap/capwap_in_vendor_specific_payload.c"/>
|
||||||
|
<File Name="src/mod/capwap/capwap_in_mtu_discovery_padding.c"/>
|
||||||
</VirtualDirectory>
|
</VirtualDirectory>
|
||||||
</VirtualDirectory>
|
</VirtualDirectory>
|
||||||
</VirtualDirectory>
|
</VirtualDirectory>
|
||||||
|
@ -153,11 +153,48 @@ int stcmp (const void * sa1, const void *sa2)
|
|||||||
|
|
||||||
int main (int argc, char *argv[])
|
int main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
mavl_t tree;
|
/* mavl_t tree;
|
||||||
int i;
|
int i;
|
||||||
mavliter_t it;
|
mavliter_t it;
|
||||||
|
|
||||||
|
|
||||||
|
mlist_t list;
|
||||||
|
struct mlistelem * elem;
|
||||||
|
|
||||||
|
int x;
|
||||||
|
|
||||||
|
list = mlist_create(NULL,sizeof(int));
|
||||||
|
|
||||||
|
x=8;
|
||||||
|
mlist_append(list,&x);
|
||||||
|
|
||||||
|
x=13;
|
||||||
|
mlist_append(list,&x);
|
||||||
|
|
||||||
|
x=11;
|
||||||
|
mlist_append(list,&x);
|
||||||
|
|
||||||
|
for(i=0; i<100000000; i++){
|
||||||
|
int val;
|
||||||
|
val = i;
|
||||||
|
mlistelem_t * result;
|
||||||
|
result = mlist_append(list,&val);
|
||||||
|
if (result == NULL){
|
||||||
|
printf("error\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("Count %d\n",list->count);
|
||||||
|
mlist_foreach(elem,list){
|
||||||
|
int * data = mlistelem_dataptr(elem);
|
||||||
|
printf("Here is %d\n",*data);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
exit(0);
|
||||||
|
*/
|
||||||
|
|
||||||
/*tree = mavl_create_ptr( (int(*)(const void*,const void*))strcmp,free);
|
/*tree = mavl_create_ptr( (int(*)(const void*,const void*))strcmp,free);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -307,7 +307,7 @@ errX:
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO XXXX
|
// TODO XXXX
|
||||||
mavl_conststr_t db_get_update_tasks(struct conn * conn,const char * wtpid)
|
mavl_t db_get_update_tasks(struct conn * conn,const char * wtpid)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
sqlite3_reset(get_tasks_stmt);
|
sqlite3_reset(get_tasks_stmt);
|
||||||
@ -391,7 +391,7 @@ errX:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
mavl_conststr_t db_get_radio_tasks(struct conn * conn,const char * wtpid)
|
mavl_t db_get_radio_tasks(struct conn * conn,const char * wtpid)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
//cw_dbg(DBG_X,"Get Radio Tasks for %s",wtpid);
|
//cw_dbg(DBG_X,"Get Radio Tasks for %s",wtpid);
|
||||||
|
@ -10,10 +10,10 @@ extern int db_init();
|
|||||||
int db_start();
|
int db_start();
|
||||||
int db_get_tasks(struct conn * conn,const char * wtpid);
|
int db_get_tasks(struct conn * conn,const char * wtpid);
|
||||||
void db_put_wtp_prop(const char *wtp_id,const char * id,const char *sub_id,const char * val);
|
void db_put_wtp_prop(const char *wtp_id,const char * id,const char *sub_id,const char * val);
|
||||||
mavl_conststr_t db_get_update_tasks(struct conn * conn,const char * wtpid);
|
mavl_t db_get_update_tasks(struct conn * conn,const char * wtpid);
|
||||||
|
|
||||||
void db_put_radio_prop(const char *wtp_id,const char *rid, const char * key,const char *sub_key,const char * val);
|
void db_put_radio_prop(const char *wtp_id,const char *rid, const char * key,const char *sub_key,const char * val);
|
||||||
extern mavl_conststr_t db_get_radio_tasks(struct conn * conn,const char * wtpid);
|
extern mavl_t db_get_radio_tasks(struct conn * conn,const char * wtpid);
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -598,7 +598,7 @@ static void wtpman_run(void *arg)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
mavl_conststr_t r;
|
mavl_t r;
|
||||||
r = db_get_update_tasks(conn, sock_addr2str(&conn->addr,sock_buf));
|
r = db_get_update_tasks(conn, sock_addr2str(&conn->addr,sock_buf));
|
||||||
if (r) {
|
if (r) {
|
||||||
|
|
||||||
|
@ -168,7 +168,7 @@ static int mout_cmp(void *elem1,void *elem2)
|
|||||||
|
|
||||||
struct outelem * cw_actionlist_mout_create(int msg_id)
|
struct outelem * cw_actionlist_mout_create(int msg_id)
|
||||||
{
|
{
|
||||||
struct outelem * o = malloc(sizeof(struct outelem));
|
/* struct outelem * o = malloc(sizeof(struct outelem));
|
||||||
if (!o)
|
if (!o)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -179,6 +179,7 @@ struct outelem * cw_actionlist_mout_create(int msg_id)
|
|||||||
}
|
}
|
||||||
o->msg_id=msg_id;
|
o->msg_id=msg_id;
|
||||||
return o;
|
return o;
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct outelem * cw_actionlist_out_get_outelem(cw_actionlist_out_t t, int msg_id)
|
static struct outelem * cw_actionlist_out_get_outelem(cw_actionlist_out_t t, int msg_id)
|
||||||
@ -220,7 +221,7 @@ cw_action_out_t *cw_actionlist_out_add(cw_actionlist_out_t t, struct cw_action_o
|
|||||||
mavl_add(t,o,NULL);
|
mavl_add(t,o,NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct mlist_elem * e = mlist_replace(o->mlist,NULL,a);
|
struct mlistelem * e = mlist_replace(o->mlist,NULL,a);
|
||||||
if (!e)
|
if (!e)
|
||||||
e = mlist_append(o->mlist,a);
|
e = mlist_append(o->mlist,a);
|
||||||
|
|
||||||
|
@ -238,7 +238,7 @@
|
|||||||
#define CW_ELEM_INITIATE_DOWNLOAD 27
|
#define CW_ELEM_INITIATE_DOWNLOAD 27
|
||||||
#define CW_ELEM_LOCATION_DATA 28
|
#define CW_ELEM_LOCATION_DATA 28
|
||||||
#define CW_ELEM_MAXIMUM_MESSAGE_LENGTH 29
|
#define CW_ELEM_MAXIMUM_MESSAGE_LENGTH 29
|
||||||
#define CW_ELEM_MTU_DISCOVERY_PADDING 52
|
#define CAPWAP_ELEM_MTU_DISCOVERY_PADDING 52
|
||||||
#define CW_ELEM_RADIO_ADMINISTRATIVE_STATE 31
|
#define CW_ELEM_RADIO_ADMINISTRATIVE_STATE 31
|
||||||
#define CW_ELEM_RADIO_OPERATIONAL_STATE 32
|
#define CW_ELEM_RADIO_OPERATIONAL_STATE 32
|
||||||
#define CW_ELEM_RESULT_CODE 33
|
#define CW_ELEM_RESULT_CODE 33
|
||||||
@ -469,7 +469,7 @@ extern int cw_readelem_statistics_timer(uint16_t * timer, int type, uint8_t * ms
|
|||||||
int len);
|
int len);
|
||||||
extern int cw_readelem_result_code(uint32_t * result_code, int type, uint8_t * msgelem,
|
extern int cw_readelem_result_code(uint32_t * result_code, int type, uint8_t * msgelem,
|
||||||
int len);
|
int len);
|
||||||
extern int cw_readelem_mtu_discovery_padding(int type, uint8_t * msgelem, int len);
|
|
||||||
extern int cw_readelem_vendor_specific_payload(void *data, int msgtype, int elemtype,
|
extern int cw_readelem_vendor_specific_payload(void *data, int msgtype, int elemtype,
|
||||||
uint8_t * msgelem, int len);
|
uint8_t * msgelem, int len);
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@ struct cw_strlist_elem capwap_strings_elem[] = {
|
|||||||
{CW_ELEM_INITIATE_DOWNLOAD, "Initiate Download"},
|
{CW_ELEM_INITIATE_DOWNLOAD, "Initiate Download"},
|
||||||
{CW_ELEM_LOCATION_DATA, "Location Data"},
|
{CW_ELEM_LOCATION_DATA, "Location Data"},
|
||||||
{CW_ELEM_MAXIMUM_MESSAGE_LENGTH, "Maximum Message Length"},
|
{CW_ELEM_MAXIMUM_MESSAGE_LENGTH, "Maximum Message Length"},
|
||||||
{CW_ELEM_MTU_DISCOVERY_PADDING, "MTU Discovery Padding"},
|
{CAPWAP_ELEM_MTU_DISCOVERY_PADDING, "MTU Discovery Padding"},
|
||||||
{CW_ELEM_RADIO_ADMINISTRATIVE_STATE, "Radio Administrative State"},
|
{CW_ELEM_RADIO_ADMINISTRATIVE_STATE, "Radio Administrative State"},
|
||||||
{CW_ELEM_RADIO_OPERATIONAL_STATE, "Radio Operational State"},
|
{CW_ELEM_RADIO_OPERATIONAL_STATE, "Radio Operational State"},
|
||||||
{CW_ELEM_RESULT_CODE, "Result Code"},
|
{CW_ELEM_RESULT_CODE, "Result Code"},
|
||||||
|
@ -233,6 +233,10 @@ void cw_read_elem(struct cw_ElemHandler * handler, struct conn * conn,
|
|||||||
static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
|
static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
|
||||||
struct sockaddr *from)
|
struct sockaddr *from)
|
||||||
{
|
{
|
||||||
|
mavl_t mand_found;
|
||||||
|
mlist_t unrecognized;
|
||||||
|
|
||||||
|
|
||||||
char sock_buf[SOCK_ADDR_BUFSIZE]; /**< to hold str from sockaddr2str */
|
char sock_buf[SOCK_ADDR_BUFSIZE]; /**< to hold str from sockaddr2str */
|
||||||
|
|
||||||
struct cw_action_in as, *af, *afm;
|
struct cw_action_in as, *af, *afm;
|
||||||
@ -365,9 +369,10 @@ static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
|
|||||||
uint8_t *elem;
|
uint8_t *elem;
|
||||||
|
|
||||||
/* Create an avltree to catch the found mandatory elements */
|
/* Create an avltree to catch the found mandatory elements */
|
||||||
conn->mand = stravltree_create();
|
//conn->mand = stravltree_create();
|
||||||
|
|
||||||
|
|
||||||
|
mand_found = mavl_create_conststr();
|
||||||
|
unrecognized = mlist_create(NULL,NULL,sizeof(uint8_t*));
|
||||||
|
|
||||||
/* iterate through message elements */
|
/* iterate through message elements */
|
||||||
cw_foreach_elem(elem, elems_ptr, elems_len) {
|
cw_foreach_elem(elem, elems_ptr, elems_len) {
|
||||||
@ -393,6 +398,7 @@ static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
|
|||||||
params.conn=conn;
|
params.conn=conn;
|
||||||
params.from=from;
|
params.from=from;
|
||||||
params.msgdata=message;
|
params.msgdata=message;
|
||||||
|
params.mand_found=mand_found;
|
||||||
|
|
||||||
result_code = cw_process_element(¶ms,0,0,elem_id,elem_data,elem_len);
|
result_code = cw_process_element(¶ms,0,0,elem_id,elem_data,elem_len);
|
||||||
|
|
||||||
@ -400,7 +406,10 @@ static int process_elements(struct conn *conn, uint8_t * rawmsg, int len,
|
|||||||
if (cw_result_is_ok(result_code))
|
if (cw_result_is_ok(result_code))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if (result_code == CAPWAP_RESULT_UNRECOGNIZED_MESSAGE_ELEMENT){
|
||||||
|
mlist_append(unrecognized,&elem);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -517,12 +526,27 @@ exit(0);
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
mavliter_init(&it,mand_found);
|
||||||
|
mavliter_foreach(&it){
|
||||||
|
printf("MAnd found: %s\n", mavliter_get_str(&it));
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
mlistelem_t *e;
|
||||||
|
mlist_foreach(e,unrecognized){
|
||||||
|
uint8_t * elem = *(uint8_t**)mlistelem_dataptr(e);
|
||||||
|
int elem_len = cw_get_elem_len(elem);
|
||||||
|
//int elem_data=cw_get_elem_data(elem);
|
||||||
|
int elem_id = cw_get_elem_id(elem);
|
||||||
|
printf("Unrecognized: %d %d\n",elem_id,elem_len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
mavl_destroy(mand_found);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//int result_code = 0;
|
//int result_code = 0;
|
||||||
int unrecognized =3;
|
//int unrecognized =3;
|
||||||
|
|
||||||
|
|
||||||
int rct = cw_in_check_generic(conn, afm, rawmsg, len, from);
|
int rct = cw_in_check_generic(conn, afm, rawmsg, len, from);
|
||||||
|
@ -341,9 +341,6 @@ extern int cw_in_check_generic_resp(struct conn *conn, struct cw_action_in *a,
|
|||||||
extern int cw_in_check_generic_req(struct conn *conn, struct cw_action_in *a,
|
extern int cw_in_check_generic_req(struct conn *conn, struct cw_action_in *a,
|
||||||
uint8_t * data, int len, struct sockaddr *from);
|
uint8_t * data, int len, struct sockaddr *from);
|
||||||
|
|
||||||
extern int cw_in_mtu_discovery_padding(struct conn *conn, struct cw_action_in *a,
|
|
||||||
uint8_t * data, int len, struct sockaddr *from);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -37,6 +37,10 @@ int cw_process_element(struct cw_ElemHandlerParams *params, int proto, int vendo
|
|||||||
return CAPWAP_RESULT_UNRECOGNIZED_MESSAGE_ELEMENT;
|
return CAPWAP_RESULT_UNRECOGNIZED_MESSAGE_ELEMENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (elem_data->mand){
|
||||||
|
mavl_add_str(params->mand_found,handler->key);
|
||||||
|
}
|
||||||
|
|
||||||
/* check the length of the message */
|
/* check the length of the message */
|
||||||
if (len < handler->min_len) {
|
if (len < handler->min_len) {
|
||||||
cw_dbg(DBG_ELEM_ERR,
|
cw_dbg(DBG_ELEM_ERR,
|
||||||
|
@ -68,12 +68,12 @@ int cw_put_msg(struct conn *conn, uint8_t * rawout)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
struct mlist_elem *e;
|
struct mlistelem *e;
|
||||||
|
|
||||||
int len = 0;
|
int len = 0;
|
||||||
|
|
||||||
for (e=m->first; e; e=e->next) {
|
for (e=m->first; e; e=e->next) {
|
||||||
cw_action_out_t *ae=(cw_action_out_t*)e->data;
|
cw_action_out_t *ae=(cw_action_out_t*)e;
|
||||||
|
|
||||||
//printf("Put %d %i %s\n",ae->msg_id,ae->elem_id,ae->item_id);
|
//printf("Put %d %i %s\n",ae->msg_id,ae->elem_id,ae->item_id);
|
||||||
if ( ae->item_id ) {
|
if ( ae->item_id ) {
|
||||||
@ -123,17 +123,21 @@ int cw_put_msg(struct conn *conn, uint8_t * rawout)
|
|||||||
* alread initilaized in buffer
|
* alread initilaized in buffer
|
||||||
* Message alements are taken fom actiondef in #conn->action
|
* Message alements are taken fom actiondef in #conn->action
|
||||||
*/
|
*/
|
||||||
int cw_put_custom_msg(struct conn *conn, uint8_t * rawout, mavl_conststr_t elems)
|
|
||||||
|
|
||||||
|
int cw_put_custom_msg(struct conn *conn, uint8_t * rawout, /*mavl_conststr_t elems*/ t)
|
||||||
{
|
{
|
||||||
/* rawout is already initialized, so we can get
|
|
||||||
msg type from buffer */
|
/*
|
||||||
|
// rawout is already initialized, so we can get
|
||||||
|
//msg type from buffer
|
||||||
uint8_t *msgptr = rawout + cw_get_hdr_msg_offset(rawout);
|
uint8_t *msgptr = rawout + cw_get_hdr_msg_offset(rawout);
|
||||||
int msg_id = cw_get_msg_type(msgptr);
|
int msg_id = cw_get_msg_type(msgptr);
|
||||||
|
|
||||||
MAVLITER_DEFINE(it,elems);
|
MAVLITER_DEFINE(it,elems);
|
||||||
mavliter_foreach(&it){
|
mavliter_foreach(&it){
|
||||||
const char *i= mavliter_get(&it);
|
const char *i= mavliter_get(&it);
|
||||||
/* preapare action search */
|
// preapare action search
|
||||||
cw_action_out_t as;
|
cw_action_out_t as;
|
||||||
as.msg_id=msg_id;
|
as.msg_id=msg_id;
|
||||||
as.item_id=i;
|
as.item_id=i;
|
||||||
@ -147,7 +151,7 @@ int cw_put_custom_msg(struct conn *conn, uint8_t * rawout, mavl_conststr_t elems
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* create search paramaters */
|
|
||||||
cw_action_out_t as;
|
cw_action_out_t as;
|
||||||
|
|
||||||
as.item_id = CW_ITEM_NONE;
|
as.item_id = CW_ITEM_NONE;
|
||||||
@ -182,7 +186,7 @@ MAVLITER_DEFINE(i,0);
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ae->msg_id != as.msg_id) {
|
if (ae->msg_id != as.msg_id) {
|
||||||
/* Element is from next msg, close action */
|
// Element is from next msg, close action
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
int l=0;
|
int l=0;
|
||||||
@ -206,15 +210,15 @@ MAVLITER_DEFINE(i,0);
|
|||||||
cw_set_msg_elems_len(msgptr, len);
|
cw_set_msg_elems_len(msgptr, len);
|
||||||
|
|
||||||
if (as.msg_id & 1) {
|
if (as.msg_id & 1) {
|
||||||
/* It's a request, so we have to set seqnum */
|
/// It's a request, so we have to set seqnum
|
||||||
int s = conn_get_next_seqnum(conn);
|
int s = conn_get_next_seqnum(conn);
|
||||||
cw_set_msg_seqnum(msgptr,s);
|
cw_set_msg_seqnum(msgptr,s);
|
||||||
// printf("Set seqnum to : %d\n",s);
|
// printf("Set seqnum to : %d\n",s);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
return 0; //len
|
||||||
return len;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ printf("MTU discovery len %d %d and pos %d:\n",conn->mtu,len,msg->pos);
|
|||||||
if (len < 0 )
|
if (len < 0 )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
uint32_t val = CW_ELEM_MTU_DISCOVERY_PADDING<<16|len;
|
uint32_t val = CAPWAP_ELEM_MTU_DISCOVERY_PADDING<<16|len;
|
||||||
*((uint32_t*)(msg->msgelems+msg->pos))=htonl(val);
|
*((uint32_t*)(msg->msgelems+msg->pos))=htonl(val);
|
||||||
memset(msg->msgelems+4+msg->pos,0xff,len);
|
memset(msg->msgelems+4+msg->pos,0xff,len);
|
||||||
msg->pos+=4+len;
|
msg->pos+=4+len;
|
||||||
|
@ -241,8 +241,10 @@ extern union mavldata * mavliter_seek ( mavliter_t *i, void *d );
|
|||||||
*/
|
*/
|
||||||
#define mavl_get_count(m) (m->count)
|
#define mavl_get_count(m) (m->count)
|
||||||
|
|
||||||
typedef mavl_t mavl_conststr_t;
|
/*
|
||||||
extern mavl_conststr_t mavl_create_conststr();
|
#typedef mavl_t mavl_conststr_t;
|
||||||
|
#extern mavl_conststr_t mavl_create_conststr();
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
//int mavl_cmp_str ( const union mavldata *e1, const union mavldata *e2 );
|
//int mavl_cmp_str ( const union mavldata *e1, const union mavldata *e2 );
|
||||||
@ -276,6 +278,7 @@ void mavl_freeptr(void *ptr);
|
|||||||
mavl_create(cmp,del,sizeof(void*))
|
mavl_create(cmp,del,sizeof(void*))
|
||||||
int mavl_cmpstr(const void *p1, const void *p2);
|
int mavl_cmpstr(const void *p1, const void *p2);
|
||||||
#define mavl_create_str() mavl_create_ptr(mavl_cmpstr,mavl_freeptr)
|
#define mavl_create_str() mavl_create_ptr(mavl_cmpstr,mavl_freeptr)
|
||||||
|
#define mavl_create_conststr() mavl_create_ptr(mavl_cmpstr,NULL)
|
||||||
|
|
||||||
void * mavl_get_ptr ( mavl_t tree, void * search );
|
void * mavl_get_ptr ( mavl_t tree, void * search );
|
||||||
void * mavl_add_ptr ( mavl_t tree, void *ptr );
|
void * mavl_add_ptr ( mavl_t tree, void *ptr );
|
||||||
|
@ -1,43 +0,0 @@
|
|||||||
/*
|
|
||||||
This file is part of actube.
|
|
||||||
|
|
||||||
actube is free software: you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation, either version 3 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
libcapwap is distributed in the hope that it will be useful,
|
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
GNU General Public License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
|
||||||
along with Foobar. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @file
|
|
||||||
* @brief Implementation of mavl_create_conststr
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#include "mavl.h"
|
|
||||||
|
|
||||||
static int cmp(const void *v1,const void*v2)
|
|
||||||
{
|
|
||||||
return strcmp( (char*)v1,(char*)v2);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a mavl object which holds pointers to strings.
|
|
||||||
* These strings have to be constant. So there is no
|
|
||||||
* free method called, when the mavl object is destroyed
|
|
||||||
* @return The created mavl object or NULL if an error
|
|
||||||
* has occured.
|
|
||||||
*/
|
|
||||||
|
|
||||||
mavl_conststr_t mavl_create_conststr()
|
|
||||||
{
|
|
||||||
return mavl_create(cmp,NULL,1312);
|
|
||||||
}
|
|
@ -3,42 +3,19 @@
|
|||||||
|
|
||||||
#include "mlist.h"
|
#include "mlist.h"
|
||||||
|
|
||||||
mlist_t mlist_create(int (*cmp) (const void *v1, const void *v2))
|
|
||||||
{
|
|
||||||
struct mlist * l = malloc(sizeof(struct mlist));
|
|
||||||
if (!l)
|
|
||||||
return NULL;
|
|
||||||
memset(l, 0, sizeof(struct mlist));
|
|
||||||
l->cmp = cmp;
|
|
||||||
return l;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct mlist_elem * mlist_append(mlist_t l, void *data)
|
|
||||||
{
|
|
||||||
|
|
||||||
struct mlist_elem **n = &l->first;
|
struct mlistelem * mlist_prepend(mlist_t l, void *data){
|
||||||
while (*n != NULL)
|
|
||||||
n = &(*n)->next;
|
|
||||||
*n = malloc(sizeof(struct mlist_elem));
|
|
||||||
if (!*n)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
(*n)->data = data;
|
|
||||||
(*n)->next = NULL;
|
|
||||||
|
|
||||||
return *n;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct mlist_elem * mlist_prepend(mlist_t l, void *data){
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
struct mlist_elem *mlist_find(mlist_t l, struct mlist_elem *start, void *data)
|
struct mlistelem *mlist_find(mlist_t l, struct mlistelem *start, void *data)
|
||||||
{
|
{
|
||||||
struct mlist_elem *e;
|
/*
|
||||||
|
struct mlistelem *e;
|
||||||
if (start)
|
if (start)
|
||||||
e = start;
|
e = start;
|
||||||
else
|
else
|
||||||
@ -51,22 +28,24 @@ struct mlist_elem *mlist_find(mlist_t l, struct mlist_elem *start, void *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
struct mlist_elem * mlist_replace(mlist_t l, struct mlist_elem *start, void *data)
|
struct mlistelem * mlist_replace(mlist_t l, struct mlistelem *start, void *data)
|
||||||
{
|
{
|
||||||
struct mlist_elem *e;
|
/*
|
||||||
|
struct mlistelem *e;
|
||||||
if (start)
|
if (start)
|
||||||
e = start;
|
e = start;
|
||||||
else
|
else
|
||||||
e = l->first;
|
e = l->first;
|
||||||
|
|
||||||
struct mlist_elem * f = mlist_find(l,e,data);
|
struct mlistelem * f = mlist_find(l,e,data);
|
||||||
if (!f)
|
if (!f)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
f->data = data;
|
f->data = data;
|
||||||
return f;
|
return f;
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,6 +24,10 @@
|
|||||||
* @brief Mlist Mini list
|
* @brief Mlist Mini list
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @defgroup MLIST MLIST
|
* @defgroup MLIST MLIST
|
||||||
* @{
|
* @{
|
||||||
@ -34,51 +38,43 @@
|
|||||||
* It's a simple connected list, just with pone connection to the
|
* It's a simple connected list, just with pone connection to the
|
||||||
* next element.
|
* next element.
|
||||||
*/
|
*/
|
||||||
struct mlist_elem {
|
struct mlistelem {
|
||||||
/** Pointer to data */
|
struct mlistelem *next;
|
||||||
void *data;
|
struct mlistelem *prev;
|
||||||
/**
|
|
||||||
* Pointer to next element
|
|
||||||
* The last element is determined by a NULL pointer
|
|
||||||
* */
|
|
||||||
struct mlist_elem *next;
|
|
||||||
struct mlist_elem *prev;
|
|
||||||
};
|
};
|
||||||
|
typedef struct mlistelem mlistelem_t;
|
||||||
|
|
||||||
struct mlist {
|
struct mlist {
|
||||||
void *data;
|
/* void *data;*/
|
||||||
int (*cmp) (const void *d1, const void *d2);
|
int (*cmp) (const void *d1, const void *d2);
|
||||||
struct mlist_elem *first;
|
void (*del) (void *data);
|
||||||
struct mlist_elem *last;
|
struct mlistelem *first;
|
||||||
|
struct mlistelem *last;
|
||||||
int count;
|
int count;
|
||||||
/* //size_t elem_size;*/
|
size_t data_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct mlist * mlist_t;
|
typedef struct mlist * mlist_t;
|
||||||
|
|
||||||
|
#define mlistelem_dataptr(elem) ((void*)(((uint8_t*)(elem))+sizeof(struct mlistelem)))
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* defgroup MLIST_FUNCTIONS
|
* defgroup MLIST_FUNCTIONS
|
||||||
* @{
|
* @{
|
||||||
*/
|
*/
|
||||||
extern mlist_t mlist_create(int (*cmp) (const void *v1, const void *v2));
|
mlist_t mlist_create(int (*cmp) (const void *v1, const void *v2), void (*del)(void *), size_t data_size);
|
||||||
extern struct mlist_elem *mlist_append(mlist_t l, void *data);
|
|
||||||
extern struct mlist_elem *mlist_find(mlist_t l, struct mlist_elem *start, void *data);
|
struct mlistelem *mlist_append(mlist_t l, void *data);
|
||||||
extern struct mlist_elem *mlist_replace(mlist_t l, struct mlist_elem *start, void *data);
|
|
||||||
|
extern struct mlistelem *mlist_find(mlist_t l, struct mlistelem *start, void *data);
|
||||||
|
extern struct mlistelem *mlist_replace(mlist_t l, struct mlistelem *start, void *data);
|
||||||
|
|
||||||
#define mlist_add mlist_append
|
#define mlist_add mlist_append
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define mlist_foreach(elem,list)\
|
||||||
|
for (elem=list->first; elem; elem=elem->next)
|
||||||
|
|
||||||
#define mlist_foreach(i,l)\
|
|
||||||
for (i=l->first; i; i=i->next)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @}
|
* @}
|
||||||
|
31
src/cw/mlist_append.c
Normal file
31
src/cw/mlist_append.c
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "mlist.h"
|
||||||
|
|
||||||
|
struct mlistelem *mlist_append(mlist_t l, void *data)
|
||||||
|
{
|
||||||
|
struct mlistelem *e;
|
||||||
|
|
||||||
|
e = malloc(sizeof(struct mlistelem) + l->data_size);
|
||||||
|
|
||||||
|
if (e == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
memcpy(mlistelem_dataptr(e), data, l->data_size);
|
||||||
|
|
||||||
|
if (l->first == NULL) {
|
||||||
|
l->first = e;
|
||||||
|
l->last = e;
|
||||||
|
e->prev=NULL;
|
||||||
|
e->next=NULL;
|
||||||
|
l->count++;
|
||||||
|
return e;
|
||||||
|
}
|
||||||
|
|
||||||
|
l->last->next=e;
|
||||||
|
e->prev=l->last;
|
||||||
|
e->next=NULL;
|
||||||
|
l->last=e;
|
||||||
|
l->count++;
|
||||||
|
return e;
|
||||||
|
}
|
18
src/cw/mlist_create.c
Normal file
18
src/cw/mlist_create.c
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
#include "mlist.h"
|
||||||
|
|
||||||
|
mlist_t mlist_create(int (*cmp) (const void *v1, const void *v2),
|
||||||
|
void (*del)(void*),
|
||||||
|
size_t data_size)
|
||||||
|
{
|
||||||
|
struct mlist * l = malloc(sizeof(struct mlist));
|
||||||
|
if (!l)
|
||||||
|
return NULL;
|
||||||
|
/*memset(l, 0, sizeof(struct mlist));*/
|
||||||
|
|
||||||
|
l->cmp = cmp;
|
||||||
|
l->data_size=data_size;
|
||||||
|
l->first=NULL;
|
||||||
|
l->last=NULL;
|
||||||
|
l->count=0;
|
||||||
|
return l;
|
||||||
|
}
|
19
src/cw/mod.c
19
src/cw/mod.c
@ -264,18 +264,25 @@ errX:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static struct mlist * mods_list = NULL;
|
static struct mlist * mods_list = NULL;
|
||||||
|
|
||||||
struct cw_Mod * cw_mod_add_to_list(struct cw_Mod * mod ){
|
struct cw_Mod * cw_mod_add_to_list(struct cw_Mod * mod ){
|
||||||
|
mlistelem_t *elem;
|
||||||
if (!mods_list){
|
if (!mods_list){
|
||||||
mods_list = mlist_create(mod_cmp_mlist);
|
mods_list = mlist_create(mod_cmp_mlist,NULL,sizeof(struct cw_Mod *));
|
||||||
if (!mods_list){
|
if (!mods_list){
|
||||||
cw_log(LOG_ERROR,"Can't init mods_list");
|
cw_log(LOG_ERROR,"Can't init mods_list");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return mlist_append(mods_list,mod)->data;
|
|
||||||
|
elem = mlist_append(mods_list,&mod);
|
||||||
|
printf("Append mod %p\n",mod);
|
||||||
|
if (elem == NULL)
|
||||||
|
return NULL;
|
||||||
|
return mlistelem_dataptr(elem);
|
||||||
|
|
||||||
|
/*return mlist_append(mods_list,mod)->data;*/
|
||||||
}
|
}
|
||||||
|
|
||||||
struct cw_Mod * cw_mod_detect(struct conn *conn,
|
struct cw_Mod * cw_mod_detect(struct conn *conn,
|
||||||
@ -283,16 +290,18 @@ struct cw_Mod * cw_mod_detect(struct conn *conn,
|
|||||||
int elems_len, struct sockaddr *from,
|
int elems_len, struct sockaddr *from,
|
||||||
int mode){
|
int mode){
|
||||||
|
|
||||||
struct mlist_elem * e;
|
struct mlistelem * e;
|
||||||
|
|
||||||
if (mods_list==NULL)
|
if (mods_list==NULL)
|
||||||
return MOD_NULL;
|
return MOD_NULL;
|
||||||
|
|
||||||
|
|
||||||
mlist_foreach(e,mods_list){
|
mlist_foreach(e,mods_list){
|
||||||
struct cw_Mod * mod = e->data;
|
/// 1312
|
||||||
|
struct cw_Mod * mod = *(struct cw_Mod**)(mlistelem_dataptr(e)); /* = e->data;*/
|
||||||
cw_dbg(DBG_MOD,"Checking mod: %s",mod->name);
|
cw_dbg(DBG_MOD,"Checking mod: %s",mod->name);
|
||||||
|
|
||||||
|
printf("Got the mod %p\n",mod);
|
||||||
/* if there is no detect method, skip */
|
/* if there is no detect method, skip */
|
||||||
if (!mod->detect)
|
if (!mod->detect)
|
||||||
continue;
|
continue;
|
||||||
|
@ -32,6 +32,7 @@ struct cw_ElemHandlerParams {
|
|||||||
struct conn * conn;
|
struct conn * conn;
|
||||||
struct cw_MsgData * msgdata;
|
struct cw_MsgData * msgdata;
|
||||||
struct sockaddr *from;
|
struct sockaddr *from;
|
||||||
|
mavl_t mand_found;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct cw_ElemHandler {
|
struct cw_ElemHandler {
|
||||||
|
206
src/cw/msgset.c
206
src/cw/msgset.c
@ -8,66 +8,70 @@
|
|||||||
|
|
||||||
#include "msget.h"
|
#include "msget.h"
|
||||||
|
|
||||||
static int cmp_cw_elemhandler_by_id(const void * elem1, const void *elem2){
|
static int cmp_cw_elemhandler_by_id(const void *elem1, const void *elem2)
|
||||||
const struct cw_ElemHandler * e1 = elem1;
|
{
|
||||||
const struct cw_ElemHandler * e2 = elem2;
|
const struct cw_ElemHandler *e1 = elem1;
|
||||||
|
const struct cw_ElemHandler *e2 = elem2;
|
||||||
int r;
|
int r;
|
||||||
r = e1->id - e2->id;
|
r = e1->id - e2->id;
|
||||||
if (r!=0)
|
if (r != 0)
|
||||||
return r;
|
return r;
|
||||||
r = e1->vendor - e2->vendor;
|
r = e1->vendor - e2->vendor;
|
||||||
if (r!=0)
|
if (r != 0)
|
||||||
|
return r;
|
||||||
|
r = e1->proto - e2->proto;
|
||||||
|
if (r != 0)
|
||||||
return r;
|
return r;
|
||||||
r = e1->proto - e2->proto;
|
|
||||||
if (r != 0)
|
|
||||||
return r;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cmp_cw_elemhandler_by_key(const void *elem1, const void *elem2){
|
static int cmp_cw_elemhandler_by_key(const void *elem1, const void *elem2)
|
||||||
const struct cw_ElemHandler * e1 = elem1;
|
{
|
||||||
const struct cw_ElemHandler * e2 = elem2;
|
const struct cw_ElemHandler *e1 = elem1;
|
||||||
return strcmp(e1->key,e2->key);
|
const struct cw_ElemHandler *e2 = elem2;
|
||||||
|
return strcmp(e1->key, e2->key);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cmp_msgdata(const void * elem1, const void *elem2)
|
static int cmp_msgdata(const void *elem1, const void *elem2)
|
||||||
{
|
{
|
||||||
const struct cw_MsgData * e1 = elem1;
|
const struct cw_MsgData *e1 = elem1;
|
||||||
const struct cw_MsgData * e2 = elem2;
|
const struct cw_MsgData *e2 = elem2;
|
||||||
return e1->type - e2->type;
|
return e1->type - e2->type;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cmp_elemdata(const void * elem1, const void *elem2)
|
static int cmp_elemdata(const void *elem1, const void *elem2)
|
||||||
{
|
{
|
||||||
const struct cw_ElemData * e1 = elem1;
|
const struct cw_ElemData *e1 = elem1;
|
||||||
const struct cw_ElemData * e2 = elem2;
|
const struct cw_ElemData *e2 = elem2;
|
||||||
int r;
|
int r;
|
||||||
r = e1->id - e2->id;
|
r = e1->id - e2->id;
|
||||||
if (r!=0)
|
if (r != 0)
|
||||||
return r;
|
return r;
|
||||||
r = e1->vendor - e2->vendor;
|
r = e1->vendor - e2->vendor;
|
||||||
if (r!=0)
|
if (r != 0)
|
||||||
|
return r;
|
||||||
|
r = e1->proto - e2->proto;
|
||||||
|
if (r != 0)
|
||||||
return r;
|
return r;
|
||||||
r = e1->proto - e2->proto;
|
|
||||||
if (r != 0)
|
|
||||||
return r;
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void msgdata_destroy(struct cw_MsgData *data){
|
static void msgdata_destroy(struct cw_MsgData *data)
|
||||||
|
{
|
||||||
if (!data)
|
if (!data)
|
||||||
return;
|
return;
|
||||||
/* if (data->elements_list)
|
/* if (data->elements_list)
|
||||||
mlist_destroy(data->elements_list);
|
mlist_destroy(data->elements_list);
|
||||||
*/
|
*/
|
||||||
if (data->elements_tree)
|
if (data->elements_tree)
|
||||||
mavl_destroy( data->elements_tree );
|
mavl_destroy(data->elements_tree);
|
||||||
free(data);
|
free(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void del_mavl_msdgdata( void * d ){
|
static void del_mavl_msdgdata(void *d)
|
||||||
|
{
|
||||||
msgdata_destroy(d);
|
msgdata_destroy(d);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,7 +80,8 @@ static void del_mavl_msdgdata( void * d ){
|
|||||||
* @brief Destroy a message set
|
* @brief Destroy a message set
|
||||||
* @param set Message set to destroy
|
* @param set Message set to destroy
|
||||||
*/
|
*/
|
||||||
void cw_msgset_destroy(struct cw_MsgSet * set){
|
void cw_msgset_destroy(struct cw_MsgSet *set)
|
||||||
|
{
|
||||||
if (set->msgdata)
|
if (set->msgdata)
|
||||||
mavl_destroy(set->msgdata);
|
mavl_destroy(set->msgdata);
|
||||||
if (set->handlers_by_id)
|
if (set->handlers_by_id)
|
||||||
@ -91,35 +96,36 @@ void cw_msgset_destroy(struct cw_MsgSet * set){
|
|||||||
* @brief Create a message set
|
* @brief Create a message set
|
||||||
* @return Message set create, NULL if an error has occured
|
* @return Message set create, NULL if an error has occured
|
||||||
*/
|
*/
|
||||||
struct cw_MsgSet * cw_msgset_create(){
|
struct cw_MsgSet *cw_msgset_create()
|
||||||
|
{
|
||||||
|
|
||||||
/* allocate memory for a message_set */
|
/* allocate memory for a message_set */
|
||||||
struct cw_MsgSet * set = malloc(sizeof(struct cw_MsgSet ));
|
struct cw_MsgSet *set = malloc(sizeof(struct cw_MsgSet));
|
||||||
if (set==NULL)
|
if (set == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
memset(set,0,sizeof(struct cw_MsgSet));
|
memset(set, 0, sizeof(struct cw_MsgSet));
|
||||||
|
|
||||||
/* create mavl for all_elems by id */
|
/* create mavl for all_elems by id */
|
||||||
set->handlers_by_id = mavl_create(cmp_cw_elemhandler_by_id,NULL,
|
set->handlers_by_id = mavl_create(cmp_cw_elemhandler_by_id, NULL,
|
||||||
sizeof(struct cw_ElemHandler));
|
sizeof(struct cw_ElemHandler));
|
||||||
if (set->handlers_by_id==NULL){
|
if (set->handlers_by_id == NULL) {
|
||||||
cw_msgset_destroy(set);
|
cw_msgset_destroy(set);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* create mavl for all_elems by key */
|
/* create mavl for all_elems by key */
|
||||||
set->handlers_by_key = mavl_create(cmp_cw_elemhandler_by_key,NULL,
|
set->handlers_by_key = mavl_create(cmp_cw_elemhandler_by_key, NULL,
|
||||||
sizeof(struct cw_ElemHandler));
|
sizeof(struct cw_ElemHandler));
|
||||||
if (set->handlers_by_key==NULL){
|
if (set->handlers_by_key == NULL) {
|
||||||
cw_msgset_destroy(set);
|
cw_msgset_destroy(set);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* create mavl for messages */
|
/* create mavl for messages */
|
||||||
set->msgdata = mavl_create(cmp_msgdata,del_mavl_msdgdata,
|
set->msgdata = mavl_create(cmp_msgdata, del_mavl_msdgdata,
|
||||||
sizeof(struct cw_MsgData));
|
sizeof(struct cw_MsgData));
|
||||||
if (set->msgdata==NULL){
|
if (set->msgdata == NULL) {
|
||||||
cw_msgset_destroy(set);
|
cw_msgset_destroy(set);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -127,120 +133,107 @@ struct cw_MsgSet * cw_msgset_create(){
|
|||||||
return set;
|
return set;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct cw_ElemHandler * cw_msgset_get_elemhandler(struct cw_MsgSet * set,
|
struct cw_ElemHandler *cw_msgset_get_elemhandler(struct cw_MsgSet *set,
|
||||||
int proto, int vendor, int id)
|
int proto, int vendor, int id)
|
||||||
{
|
{
|
||||||
struct cw_ElemHandler search;
|
struct cw_ElemHandler search;
|
||||||
search.proto=proto;
|
search.proto = proto;
|
||||||
search.vendor=vendor;
|
search.vendor = vendor;
|
||||||
search.id=id;
|
search.id = id;
|
||||||
return mavl_find(set->handlers_by_id,&search);
|
return mavl_find(set->handlers_by_id, &search);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int update_msgdata(struct cw_MsgSet * set, struct cw_MsgData * msgdata,
|
static int update_msgdata(struct cw_MsgSet *set, struct cw_MsgData *msgdata,
|
||||||
struct cw_MsgDef * msgdef)
|
struct cw_MsgDef *msgdef)
|
||||||
{
|
{
|
||||||
struct cw_ElemDef * elemdef;
|
struct cw_ElemDef *elemdef;
|
||||||
struct cw_ElemData ed, *result;
|
struct cw_ElemData ed, *result;
|
||||||
|
|
||||||
/* iterate through all defined elements */
|
/* iterate through all defined elements */
|
||||||
for(elemdef = msgdef->elements; elemdef->id; elemdef++){
|
for (elemdef = msgdef->elements; elemdef->id; elemdef++) {
|
||||||
struct cw_ElemHandler * handler;
|
struct cw_ElemHandler *handler;
|
||||||
int replaced;
|
int replaced;
|
||||||
|
|
||||||
handler = cw_msgset_get_elemhandler(set,
|
handler = cw_msgset_get_elemhandler(set,
|
||||||
elemdef->proto,
|
elemdef->proto,
|
||||||
elemdef->vendor,
|
elemdef->vendor, elemdef->id);
|
||||||
elemdef->id);
|
|
||||||
/* check if a handler for our element already exists */
|
/* check if a handler for our element already exists */
|
||||||
if (!handler){
|
if (!handler) {
|
||||||
cw_log(LOG_ERR, "No handler for message element: %d %d %d",
|
cw_log(LOG_ERR, "No handler for message element: %d %d %d",
|
||||||
elemdef->proto,
|
elemdef->proto, elemdef->vendor, elemdef->id);
|
||||||
elemdef->vendor,
|
|
||||||
elemdef->id);
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
ed.id=elemdef->id;
|
ed.id = elemdef->id;
|
||||||
ed.proto=elemdef->proto;
|
ed.proto = elemdef->proto;
|
||||||
ed.vendor=elemdef->vendor;
|
ed.vendor = elemdef->vendor;
|
||||||
ed.mand=elemdef->mand;
|
ed.mand = elemdef->mand;
|
||||||
|
|
||||||
|
|
||||||
result = mavl_replace(msgdata->elements_tree, &ed, &replaced);
|
result = mavl_replace(msgdata->elements_tree, &ed, &replaced);
|
||||||
|
|
||||||
if (!replaced){
|
if (!replaced) {
|
||||||
cw_dbg(DBG_MOD, " adding message element %d %d %d - %s",
|
cw_dbg(DBG_MOD, " adding message element %d %d %d - %s",
|
||||||
elemdef->proto,
|
elemdef->proto,
|
||||||
elemdef->vendor,
|
elemdef->vendor, elemdef->id, handler->name);
|
||||||
elemdef->id,
|
} else {
|
||||||
handler->name);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
cw_dbg(DBG_MOD, " replacing message element %d %d %d - %s",
|
cw_dbg(DBG_MOD, " replacing message element %d %d %d - %s",
|
||||||
elemdef->proto,
|
elemdef->proto,
|
||||||
elemdef->vendor,
|
elemdef->vendor, elemdef->id, handler->name);
|
||||||
elemdef->id,
|
|
||||||
handler->name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int cw_msgset_add(struct cw_MsgSet * set,
|
int cw_msgset_add(struct cw_MsgSet *set,
|
||||||
struct cw_MsgDef messages[],
|
struct cw_MsgDef messages[], struct cw_ElemHandler handlers[]
|
||||||
struct cw_ElemHandler handlers[]
|
)
|
||||||
){
|
{
|
||||||
|
|
||||||
struct cw_ElemHandler * handler;
|
struct cw_ElemHandler *handler;
|
||||||
struct cw_MsgDef * msgdef;
|
struct cw_MsgDef *msgdef;
|
||||||
|
|
||||||
/* Create mavl for all handlers */
|
/* Create mavl for all handlers */
|
||||||
for(handler = handlers; handler->id; handler++){
|
for (handler = handlers; handler->id; handler++) {
|
||||||
cw_dbg(DBG_MOD,"Adding handler for element %d - %s - with key: %s",
|
cw_dbg(DBG_MOD, "Adding handler for element %d - %s - with key: %s",
|
||||||
handler->id,
|
handler->id, handler->name, handler->key);
|
||||||
handler->name,
|
mavl_replace(set->handlers_by_id, handler, NULL);
|
||||||
handler->key);
|
mavl_replace(set->handlers_by_key, handler, NULL);
|
||||||
mavl_replace(set->handlers_by_id,handler,NULL);
|
|
||||||
mavl_replace(set->handlers_by_key,handler,NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (msgdef = messages; msgdef->type != 0; msgdef++) {
|
||||||
for (msgdef=messages; msgdef->type !=0; msgdef++){
|
|
||||||
struct cw_MsgData search;
|
struct cw_MsgData search;
|
||||||
struct cw_MsgData *msg;
|
struct cw_MsgData *msg;
|
||||||
int exists;
|
int exists;
|
||||||
|
|
||||||
/* Look if message already exists */
|
/* Look if message already exists */
|
||||||
search.type=msgdef->type;
|
search.type = msgdef->type;
|
||||||
msg = mavl_add(set->msgdata,&search,&exists);
|
msg = mavl_add(set->msgdata, &search, &exists);
|
||||||
|
|
||||||
if (msg == NULL){
|
if (msg == NULL) {
|
||||||
cw_log(LOG_ERR,"Can't create messae");
|
cw_log(LOG_ERR, "Can't create messae");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!exists){
|
if (!exists) {
|
||||||
msg->elements_tree = mavl_create(cmp_elemdata,NULL,
|
msg->elements_tree = mavl_create(cmp_elemdata, NULL,
|
||||||
sizeof(struct cw_ElemData));
|
sizeof(struct cw_ElemData));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Overwrite the found message */
|
/* Overwrite the found message */
|
||||||
if (msgdef->name)
|
if (msgdef->name)
|
||||||
msg->name=msgdef->name;
|
msg->name = msgdef->name;
|
||||||
if (msgdef->states)
|
if (msgdef->states)
|
||||||
msg->states=msgdef->states;
|
msg->states = msgdef->states;
|
||||||
msg->receiver=msgdef->receiver;
|
msg->receiver = msgdef->receiver;
|
||||||
|
|
||||||
|
|
||||||
cw_dbg(DBG_MOD, "Add message Type:%d - %s ",msgdef->type,msgdef->name);
|
cw_dbg(DBG_MOD, "Add message Type:%d - %s ", msgdef->type, msgdef->name);
|
||||||
|
|
||||||
|
|
||||||
update_msgdata(set,msg,msgdef);
|
update_msgdata(set, msg, msgdef);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -252,8 +245,9 @@ int cw_msgset_add(struct cw_MsgSet * set,
|
|||||||
* @param type message type to search for
|
* @param type message type to search for
|
||||||
* @return message data or NULL if not found
|
* @return message data or NULL if not found
|
||||||
*/
|
*/
|
||||||
struct cw_MsgData * cw_msgset_get_msgdata(struct cw_MsgSet *set,int type){
|
struct cw_MsgData *cw_msgset_get_msgdata(struct cw_MsgSet *set, int type)
|
||||||
|
{
|
||||||
struct cw_MsgData search;
|
struct cw_MsgData search;
|
||||||
search.type=type;
|
search.type = type;
|
||||||
return mavl_find_ptr(set->msgdata,&search);
|
return mavl_find_ptr(set->msgdata, &search);
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,7 @@ OBJS=\
|
|||||||
capwap_out_ac_ip_list.o \
|
capwap_out_ac_ip_list.o \
|
||||||
capwap_in_session_id.o \
|
capwap_in_session_id.o \
|
||||||
capwap_in_vendor_specific_payload.o \
|
capwap_in_vendor_specific_payload.o \
|
||||||
|
capwap_in_mtu_discovery_padding.o
|
||||||
|
|
||||||
|
|
||||||
LIBDIR := ../../../lib
|
LIBDIR := ../../../lib
|
||||||
|
@ -89,6 +89,18 @@ static struct cw_ElemHandler handlers[] = {
|
|||||||
}
|
}
|
||||||
,
|
,
|
||||||
|
|
||||||
|
{
|
||||||
|
"MTU Discovery Padding", /* name */
|
||||||
|
CAPWAP_ELEM_MTU_DISCOVERY_PADDING, /* Element ID */
|
||||||
|
0,0, /* Vendor / Proto */
|
||||||
|
0,0, /* min/max length */
|
||||||
|
NULL, /* type */
|
||||||
|
NULL, /* Key */
|
||||||
|
capwap_in_mtu_discovery_padding /* get */
|
||||||
|
}
|
||||||
|
,
|
||||||
|
|
||||||
|
|
||||||
{0,0,0,0,0,0,0,0}
|
{0,0,0,0,0,0,0,0}
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -97,10 +109,11 @@ static struct cw_ElemHandler handlers[] = {
|
|||||||
static int discovery_request_states[] = {CAPWAP_STATE_DISCOVERY,0};
|
static int discovery_request_states[] = {CAPWAP_STATE_DISCOVERY,0};
|
||||||
static struct cw_ElemDef discovery_request_elements[] ={
|
static struct cw_ElemDef discovery_request_elements[] ={
|
||||||
{0,0,CAPWAP_ELEM_DISCOVERY_TYPE, 1, 0},
|
{0,0,CAPWAP_ELEM_DISCOVERY_TYPE, 1, 0},
|
||||||
{0,0,CAPWAP_ELEM_WTP_MAC_TYPE, 1, 0},
|
|
||||||
{0,0,CAPWAP_ELEM_WTP_BOARD_DATA, 1, 0},
|
{0,0,CAPWAP_ELEM_WTP_BOARD_DATA, 1, 0},
|
||||||
{0,0,CAPWAP_ELEM_WTP_DESCRIPTOR, 1, 0},
|
{0,0,CAPWAP_ELEM_WTP_DESCRIPTOR, 1, 0},
|
||||||
{0,0,CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE, 1, 0},
|
{0,0,CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE, 1, 0},
|
||||||
|
{0,0,CAPWAP_ELEM_WTP_MAC_TYPE, 1, 0},
|
||||||
|
{0,0,CAPWAP_ELEM_MTU_DISCOVERY_PADDING, 0, 0},
|
||||||
{0,0,CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD, 0, 0},
|
{0,0,CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD, 0, 0},
|
||||||
{0,0,0,0,0}
|
{0,0,0,0,0}
|
||||||
|
|
||||||
|
@ -16,16 +16,18 @@
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "cw/capwap.h"
|
||||||
#include "cw.h"
|
#include "cw/msget.h"
|
||||||
#include "dbg.h"
|
#include "cw/dbg.h"
|
||||||
|
|
||||||
|
|
||||||
int cw_in_mtu_discovery_padding(struct conn *conn, struct cw_action_in *a,
|
int capwap_in_mtu_discovery_padding(struct cw_ElemHandler *eh,
|
||||||
uint8_t * data, int len,struct sockaddr *from)
|
struct cw_ElemHandlerParams *params, uint8_t * data,
|
||||||
|
int len)
|
||||||
|
|
||||||
{
|
{
|
||||||
int i, n = 0;
|
int i, n;
|
||||||
|
n = 0;
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; i++) {
|
||||||
if (data[i] != 0xff)
|
if (data[i] != 0xff)
|
||||||
n++;
|
n++;
|
||||||
@ -34,8 +36,8 @@ int cw_in_mtu_discovery_padding(struct conn *conn, struct cw_action_in *a,
|
|||||||
cw_dbg(DBG_RFC,
|
cw_dbg(DBG_RFC,
|
||||||
"MTU discovery padding msg elem contains %d non-0xFF byte(s) out of %d, See RFC 5415.",
|
"MTU discovery padding msg elem contains %d non-0xFF byte(s) out of %d, See RFC 5415.",
|
||||||
n, len);
|
n, len);
|
||||||
if (conn->strict_capwap)
|
if (params->conn->strict_capwap)
|
||||||
return 0;
|
return CAPWAP_RESULT_UNRECOGNIZED_MESSAGE_ELEMENT;
|
||||||
}
|
}
|
||||||
return 1;
|
return CAPWAP_RESULT_SUCCESS;
|
||||||
}
|
}
|
@ -25,6 +25,10 @@ int capwap_in_vendor_specific_payload(struct cw_ElemHandler *handler,
|
|||||||
struct cw_ElemHandlerParams *params,
|
struct cw_ElemHandlerParams *params,
|
||||||
uint8_t * data, int len);
|
uint8_t * data, int len);
|
||||||
|
|
||||||
|
int capwap_in_mtu_discovery_padding(struct cw_ElemHandler *eh,
|
||||||
|
struct cw_ElemHandlerParams *params, uint8_t * data,
|
||||||
|
int len);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
extern int capwap_out_wtp_descriptor(struct conn *conn, struct cw_action_out *a,
|
extern int capwap_out_wtp_descriptor(struct conn *conn, struct cw_action_out *a,
|
||||||
uint8_t * dst);
|
uint8_t * dst);
|
||||||
|
Loading…
Reference in New Issue
Block a user