Can now go through the join process with a Cisco 1131ag ...

... until change state even request is reached.
Then wtpman exits.
Image upgrade with 1130 does not work.
The 1131 sends crazy response messages when receiving image data request.

FossilOrigin-Name: 466eaa82073f25147a8ccaa37567a8dfc4cf6d9230b3491399c9a174d9b73f0d
This commit is contained in:
7u83@mail.ru 2014-08-17 23:45:08 +00:00
parent 6c583e2168
commit 3bc505ce1a

View File

@ -101,6 +101,7 @@ void send_image_file(struct conn * conn,const char * filename)
} }
else{ else{
printf("Respnse Timeout\n"); printf("Respnse Timeout\n");
exit(0);
} }
@ -217,8 +218,7 @@ static void wtpman_run(void *arg)
/* start DTLS handshake */ /* start DTLS handshake */
cw_dbg(DBG_DTLS,"Establishing DTLS session with %s",CLIENT_IP); cw_dbg(DBG_DTLS,"Establishing DTLS session with %s",CLIENT_IP);
wtpman->conn->dtls_wait_timer=15; time_t timer = cw_timer_start(wtpman->conn->wait_dtls);
time_t timer = cw_timer_start(wtpman->conn->dtls_wait_timer);
wtpman->conn->dtls_cipher=CAPWAP_CIPHER; wtpman->conn->dtls_cipher=CAPWAP_CIPHER;
@ -257,14 +257,14 @@ static void wtpman_run(void *arg)
/* DTLS handshake done */ /* DTLS handshake done */
wtpman->conn->strict_capwap=1; timer = cw_timer_start(wtpman->conn->wait_join);
/* In join state, wait for join request */
/* In join state, wait for join request */
cwrmsg = wtpman_wait_for_message(wtpman,timer); cwrmsg = wtpman_wait_for_message(wtpman,timer);
if (!cwrmsg){ if (!cwrmsg){
cw_dbg(DBG_CW_MSG_ERR,"No join request from %s after %d seconds, WTP died.", cw_dbg(DBG_CW_MSG_ERR,"No join request from %s after %d seconds, WTP died.",
sock_addr2str(&wtpman->conn->addr),wtpman->conn->dtls_wait_timer); sock_addr2str(&wtpman->conn->addr),wtpman->conn->wait_join);
wtpman_remove(wtpman); wtpman_remove(wtpman);
return; return;
} }
@ -311,22 +311,49 @@ wtpman->conn->strict_capwap=1;
cwrmsg = wtpman_wait_for_message(wtpman,timer); cwrmsg = wtpman_wait_for_message(wtpman,timer);
if (!cwrmsg){ if (!cwrmsg){
cw_dbg(DBG_CW_MSG_ERR,"No config or update request from %s after %d seconds, WTP died.", cw_dbg(DBG_CW_MSG_ERR,"No config or update request from %s after %d seconds, WTP died.",
sock_addr2str(&wtpman->conn->addr),wtpman->conn->dtls_wait_timer); sock_addr2str(&wtpman->conn->addr),wtpman->conn->wait_join);
wtpman_remove(wtpman); wtpman_remove(wtpman);
return; return;
} }
cwread_configuration_status_request(&wtpman->wtpinfo,cwrmsg->msgelems, cwrmsg->msgelems_len);
cwsend_conf_status_response(wtpman->conn,cwrmsg->seqnum,result_code,&radioinfo,acinfo,&wtpman->wtpinfo);
if (cwrmsg->type==CWMSG_IMAGE_DATA_REQUEST){ char wtpinfostr[8192];
cwread_image_data_request(0,cwrmsg->msgelems,cwrmsg->msgelems_len); wtpinfo_print(wtpinfostr,&wtpman->wtpinfo);
cwsend_image_data_response(wtpman->conn,cwrmsg->seqnum,CW_RESULT_SUCCESS); cw_dbg(DBG_ALL,"WTP conf_status\n%s",wtpinfostr);
cwrmsg = wtpman_wait_for_message(wtpman,timer);
if (cwrmsg){
if (cwrmsg->type == CWMSG_CHANGE_STATE_EVENT_REQUEST){
int rc = cwread_change_state_event_request(&wtpman->wtpinfo,cwrmsg->msgelems,cwrmsg->msgelems_len);
printf("Change state RC: %d\n",rc);
}
} }
exit(0); exit(0);
if (cwrmsg->type==CWMSG_IMAGE_DATA_REQUEST){
cwread_image_data_request(0,cwrmsg->msgelems,cwrmsg->msgelems_len);
cwsend_image_data_response(wtpman->conn,cwrmsg->seqnum,CW_RESULT_FAILURE);
}
/*
printf("Sending image file\n"); printf("Sending image file\n");
send_image_file(wtpman->conn,"/home/tube/Downloads/c1130-rcvk9w8-tar.124-25e.JAO5.tar"); send_image_file(wtpman->conn,"/home/tube/Downloads/c1130-rcvk9w8-tar.124-25e.JAO5.tar");
printf("Back from sending image file\n"); printf("Back from sending image file\n");
*/
exit(0);
timer = cw_timer_start(30); timer = cw_timer_start(30);
@ -458,7 +485,6 @@ struct wtpman * wtpman_create(int socklistindex,struct sockaddr * srcaddr)
int sockfd = socklist[socklistindex].reply_sockfd; int sockfd = socklist[socklistindex].reply_sockfd;
// wtpman->conn=conn_create(sockfd,srcaddr,process_discovery,wtpman,100);
wtpman->conn=conn_create(sockfd,srcaddr,100); wtpman->conn=conn_create(sockfd,srcaddr,100);
if (!wtpman->conn){ if (!wtpman->conn){
wtpman_destroy(wtpman); wtpman_destroy(wtpman);