changes for new msgsets

FossilOrigin-Name: 3e55d675e155fb9e23f9916fb365f677ca0d949e7c91e8afbb31ec7c95a1c9c5
This commit is contained in:
7u83@mail.ru 2018-02-24 22:57:12 +00:00
parent 3f33eda837
commit f4723a33da

View File

@ -17,6 +17,7 @@
*/ */
#include "cw/cw.h" #include "cw/cw.h"
#include "cw/log.h" #include "cw/log.h"
#include "cw/action.h" #include "cw/action.h"
@ -28,70 +29,73 @@
#include "mod_capwap.h" #include "mod_capwap.h"
static cw_message_element_t elements[] = { static cw_message_element_t _DISCOVERY_TYPE = {
{
.id = CAPWAP_ELEM_DISCOVERY_TYPE,
.name = "Discovery Type", .name = "Discovery Type",
.id = CAPWAP_ELEM_DISCOVERY_TYPE,
//.start = cw_in_generic2, //.start = cw_in_generic2,
//.item_id = "discovery_type", //.item_id = "discovery_type",
.min_len = 1, .min_len = 1,
.max_len = 1 .max_len = 1
}, };
{ static cw_message_element_t _WTP_BOARD_DATA = {
.id = CAPWAP_ELEM_WTP_BOARD_DATA,
.name = "WTP Board Data", .name = "WTP Board Data",
.id = CAPWAP_ELEM_WTP_BOARD_DATA,
// .start = cw_in_wtp_board_data, // .start = cw_in_wtp_board_data,
// .item_id = CW_ITEM_WTP_BOARD_DATA, // .item_id = CW_ITEM_WTP_BOARD_DATA,
}, };
{ static cw_message_element_t _WTP_DESCRIPTOR = {
.id = CAPWAP_ELEM_WTP_DESCRIPTOR, .id = CAPWAP_ELEM_WTP_DESCRIPTOR,
.name = "WTP Descriptor", .name = "WTP Descriptor",
//.start = capwap_in_wtp_descriptor, //.start = capwap_in_wtp_descriptor,
//.item_id = "wtp_descriptor", //.item_id = "wtp_descriptor",
};
} static cw_message_element_t _WTP_FRAME_TUNNEL_MODE = {
,
{
.id = CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE, .id = CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE,
.name = "WTP Frame Tunnel Mode", .name = "WTP Frame Tunnel Mode",
// .start = cw_in_generic2, // .start = cw_in_generic2,
// .item_id = CW_ITEM_WTP_FRAME_TUNNEL_MODE, // .item_id = CW_ITEM_WTP_FRAME_TUNNEL_MODE,
.min_len = 1, .min_len = 1,
.max_len = 1 .max_len = 1
} };
,
{
static cw_message_element_t _WTP_MAC_TYPE = {
.id = CAPWAP_ELEM_WTP_MAC_TYPE, .id = CAPWAP_ELEM_WTP_MAC_TYPE,
.name = "WTP Mac Type", .name = "WTP Mac Type",
// .start = cw_in_generic2, // .start = cw_in_generic2,
// .item_id = CW_ITEM_WTP_MAC_TYPE, // .item_id = CW_ITEM_WTP_MAC_TYPE,
.min_len = 1, .min_len = 1,
.max_len = 1 .max_len = 1
}, };
/* MTU Discovery Padding */ /* MTU Discovery Padding */
{ static cw_message_element_t _MTU_DISCOVERY_PADDING = {
.id = CW_ELEM_MTU_DISCOVERY_PADDING, .id = CW_ELEM_MTU_DISCOVERY_PADDING,
.name = "MTU Discovery Padding" .name = "MTU Discovery Padding"
// .start = cw_in_mtu_discovery_padding, // .start = cw_in_mtu_discovery_padding,
} };
,
{
.id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, static cw_message_element_t _VENDOR_SPECIFIC_PAYLOAD = {
.name = "Vendor Specific Payload", .name = "Vendor Specific Payload",
.id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
// .start = cw_in_vendor_specific_payload, // .start = cw_in_vendor_specific_payload,
.min_len=7 .min_len=7
}
,
{.id=0}
}; };
/* AC Descriptor - Discovery Response */
static cw_message_element_t _AC_DESCRIPTOR = {
.name = "AC Descriptor",
.id = CAPWAP_ELEM_AC_DESCRIPTOR,
//.item_id = CW_ITEM_AC_DESCRIPTOR,
//.start = cw_in_ac_descriptor,
.min_len = 12,
.max_len = 8192,
};
static cw_message_t messages[] = { static cw_message_t messages[] = {
/* Discovery Request Message*/ /* Discovery Request Message*/
@ -100,13 +104,24 @@ static cw_message_t messages[] = {
.type = CAPWAP_MSG_DISCOVERY_REQUEST, .type = CAPWAP_MSG_DISCOVERY_REQUEST,
.states = (int[]){CAPWAP_STATE_DISCOVERY,0}, .states = (int[]){CAPWAP_STATE_DISCOVERY,0},
.elements = (cw_messagedef_t []){ .elements = (cw_messagedef_t []){
{0,0,CAPWAP_ELEM_DISCOVERY_TYPE,1}, {&_DISCOVERY_TYPE,1},
{0,0,CAPWAP_ELEM_WTP_BOARD_DATA,1}, {&_WTP_BOARD_DATA,1},
{0,0,CAPWAP_ELEM_WTP_DESCRIPTOR,1}, {&_WTP_DESCRIPTOR,1},
{0,0,CAPWAP_ELEM_WTP_FRAME_TUNNEL_MODE,1}, {&_WTP_FRAME_TUNNEL_MODE,1},
{0,0,CAPWAP_ELEM_WTP_MAC_TYPE,1}, {&_WTP_MAC_TYPE,1},
{0,0,CW_ELEM_MTU_DISCOVERY_PADDING,0}, {&_MTU_DISCOVERY_PADDING,0},
{0,0,CW_ELEM_VENDOR_SPECIFIC_PAYLOAD,0} {&_VENDOR_SPECIFIC_PAYLOAD,0},
{0,0},
}
},
/* Discovery Request Response */
{
.name = "Discovery Response",
.type = CAPWAP_MSG_DISCOVERY_RESPONSE,
.states = (int[]){CAPWAP_STATE_DISCOVERY,0},
.elements = (cw_messagedef_t[]){
{&_AC_DESCRIPTOR,1},
{0,0},
} }
} }
}; };
@ -120,7 +135,7 @@ void test_sets(){
return; return;
} }
cw_message_set_add(set,messages,elements); cw_message_set_add(set,messages);
cw_message_element_t el, *result; cw_message_element_t el, *result;
memset(&el,0,sizeof(el)); memset(&el,0,sizeof(el));
@ -243,7 +258,7 @@ static cw_action_in_t actions_in[] = {
{ {
.capwap_state = CAPWAP_STATE_DISCOVERY, .capwap_state = CAPWAP_STATE_DISCOVERY,
.msg_id = CAPWAP_MSG_DISCOVERY_REQUEST, .msg_id = CAPWAP_MSG_DISCOVERY_REQUEST,
.elem_id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, .elem_id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
.start = cw_in_vendor_specific_payload, .start = cw_in_vendor_specific_payload,
.min_len=7 .min_len=7
} }
@ -434,7 +449,7 @@ static cw_action_in_t actions_in[] = {
{ {
.capwap_state = CW_STATE_JOIN, .capwap_state = CW_STATE_JOIN,
.msg_id = CAPWAP_MSG_JOIN_REQUEST, .msg_id = CAPWAP_MSG_JOIN_REQUEST,
.elem_id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, .elem_id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
.start = cw_in_vendor_specific_payload, .start = cw_in_vendor_specific_payload,
.min_len=7 .min_len=7
} }
@ -512,7 +527,7 @@ static cw_action_in_t actions_in[] = {
{ {
.capwap_state = CW_STATE_CONFIGURE, .capwap_state = CW_STATE_CONFIGURE,
.msg_id = CAPWAP_MSG_CONFIGURATION_STATUS_REQUEST, .msg_id = CAPWAP_MSG_CONFIGURATION_STATUS_REQUEST,
.elem_id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, .elem_id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
.start = cw_in_vendor_specific_payload, .start = cw_in_vendor_specific_payload,
} }
, ,
@ -559,7 +574,7 @@ static cw_action_in_t actions_in[] = {
{ {
.capwap_state = CW_STATE_CONFIGURE, .capwap_state = CW_STATE_CONFIGURE,
.msg_id = CW_MSG_CHANGE_STATE_EVENT_REQUEST, .msg_id = CW_MSG_CHANGE_STATE_EVENT_REQUEST,
.elem_id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, .elem_id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
.start = cw_in_vendor_specific_payload, .start = cw_in_vendor_specific_payload,
.min_len=7 .min_len=7
} }
@ -608,7 +623,7 @@ static cw_action_in_t actions_in[] = {
{ {
.capwap_state = CW_STATE_RUN, .capwap_state = CW_STATE_RUN,
.msg_id = CW_MSG_CHANGE_STATE_EVENT_REQUEST, .msg_id = CW_MSG_CHANGE_STATE_EVENT_REQUEST,
.elem_id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, .elem_id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
.start = cw_in_vendor_specific_payload, .start = cw_in_vendor_specific_payload,
.min_len=7 .min_len=7
} }
@ -631,7 +646,7 @@ static cw_action_in_t actions_in[] = {
{ {
.capwap_state = CW_STATE_RUN, .capwap_state = CW_STATE_RUN,
.msg_id = CW_MSG_ECHO_REQUEST, .msg_id = CW_MSG_ECHO_REQUEST,
.elem_id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, .elem_id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
.start = cw_in_vendor_specific_payload, .start = cw_in_vendor_specific_payload,
} }
, ,
@ -651,7 +666,7 @@ static cw_action_in_t actions_in[] = {
{ {
.capwap_state = CW_STATE_RUN, .capwap_state = CW_STATE_RUN,
.msg_id = CW_MSG_WTP_EVENT_REQUEST, .msg_id = CW_MSG_WTP_EVENT_REQUEST,
.elem_id = CW_ELEM_VENDOR_SPECIFIC_PAYLOAD, .elem_id = CAPWAP_ELEM_VENDOR_SPECIFIC_PAYLOAD,
.start = cw_in_vendor_specific_payload, .start = cw_in_vendor_specific_payload,
} }
, ,