diff --git a/src/ac/wtpman.c b/src/ac/wtpman.c index 57f2a4d0..c689c6d5 100644 --- a/src/ac/wtpman.c +++ b/src/ac/wtpman.c @@ -239,9 +239,8 @@ static int wtpman_join(void *arg, time_t timer) struct conn * conn = wtpman->conn; -conn->capwap_mode=CW_MODE_CIPWAP; - +conn->strict_capwap=1; cw_dbg(DBG_INFO,"Join State - %s",sock_addr2str(&conn->addr)); diff --git a/src/capwap/cw_in_check_join_resp.c b/src/capwap/cw_in_check_join_resp.c index aadded42..ff9b4b3e 100644 --- a/src/capwap/cw_in_check_join_resp.c +++ b/src/capwap/cw_in_check_join_resp.c @@ -13,6 +13,16 @@ int cw_in_check_join_resp(struct conn *conn, struct cw_action_in *a, uint8_t * d cw_action_in_t * mlist[60]; + mbag_item_t * jresult = mbag_get(conn->incomming,CW_ITEM_RESULT_CODE); + if (jresult ) { + if (!cw_rcok(jresult->dword)){ + return jresult->dword; + } + + + } + + /* Check for mandatory elements */ int n = cw_check_missing_mand(mlist,conn,a); if (n && conn->strict_capwap) { @@ -27,7 +37,6 @@ int cw_in_check_join_resp(struct conn *conn, struct cw_action_in *a, uint8_t * d - mbag_item_t * jresult = mbag_get(conn->incomming, CW_ITEM_RESULT_CODE); if ( jresult ) { return jresult->dword; diff --git a/src/capwap/cw_out_wtp_descriptor.c b/src/capwap/cw_out_wtp_descriptor.c index baa02088..e4c99301 100644 --- a/src/capwap/cw_out_wtp_descriptor.c +++ b/src/capwap/cw_out_wtp_descriptor.c @@ -5,10 +5,12 @@ #include "capwap_items.h" #include "capwap.h" -static int cw_put_encryption_subelems(uint8_t *dst) +static int cw_put_encryption_subelems(uint8_t *dst,int capwap_mode) { -cw_put_word(dst,0x01); -return 2; + if (capwap_mode==CW_MODE_CISCO){ + cw_put_word(dst,0x01); + return 2; + } int n=2; @@ -34,9 +36,10 @@ int cw_out_wtp_descriptor(struct conn *conn, struct cw_action_out *a, uint8_t * // XXX Dummy WTP Descriptor Header uint8_t *d = dst+4; - d+=cw_put_byte(d,2); //max radios + d+=cw_put_byte(d,conn->radios->count); //max radios d+=cw_put_byte(d,2); //radios in use - d+=cw_put_encryption_subelems(d); + + d+=cw_put_encryption_subelems(d,conn->capwap_mode); mbag_item_t * i; i = mbag_get(mbag,CW_ITEM_WTP_HARDWARE_VERSION); diff --git a/src/wtp/join.c b/src/wtp/join.c index cb85e2d5..1309d212 100644 --- a/src/wtp/join.c +++ b/src/wtp/join.c @@ -168,12 +168,19 @@ int run_join(struct conn * conn) int rc = cw_send_request(conn,CW_MSG_JOIN_REQUEST); if (!cw_rcok(rc) ) { - cw_log(LOG_ERR,"Can't Join AC at %s: %d - %s.", + if (rc>0 ){ + cw_log(LOG_ERR,"Can't Join AC at %s, AC said: %d - %s.", sock_addr2str(&conn->addr),rc,cw_strerror(rc)); + + } + else{ + cw_log(LOG_ERR,"Can't Join AC at %s: %d - %s.", + sock_addr2str(&conn->addr),errno,cw_strerror(rc)); + } return 0; } - cw_dbg(DBG_ELEM,"Join Result: %d - %s",rc,cw_strresult(rc)); + cw_dbg(DBG_ELEM,"Joined AC at %s, Join Result: %d - %s",sock_addr2str(&conn->addr),rc,cw_strresult(rc)); return 1; } @@ -183,7 +190,6 @@ int run_join(struct conn * conn) int join() { struct conn * conn = get_conn(); -conn->capwap_mode=CW_MODE_CISCO; cw_aciplist_t iplist = mbag_get_avltree(conn->local,CW_ITEM_CAPWAP_CONTROL_IP_ADDRESS_LIST); if (!iplist){ diff --git a/src/wtp/wtp_main.c b/src/wtp/wtp_main.c index 3b1a8210..b876d625 100644 --- a/src/wtp/wtp_main.c +++ b/src/wtp/wtp_main.c @@ -111,7 +111,7 @@ mavl_destroy(b); - cw_register_actions_cipwap_wtp(&capwap_actions); + cw_register_actions_capwap_wtp(&capwap_actions); cw_register_actions_capwap_80211_wtp(&capwap_actions); @@ -130,7 +130,10 @@ mavl_destroy(b); conn->incomming = mbag_create(); conn->local = mbag_create(); conn->base_rmac=get_base_rmac(); - conn->capwap_mode = CW_MODE_CISCO; + +conn->capwap_mode = CW_MODE_STD; +the_conn->strict_capwap=1; + conn->config=mbag_create(); @@ -168,7 +171,6 @@ cw_set_msg_end_callback(conn,CW_STATE_CONFIGURE,CW_MSG_CONFIGURATION_STATUS_RESP -the_conn->strict_capwap=1; if (!discovery()) return -1; if (!join())