Fixed serious bug which causes RNDIS task to end when non-data message are sent via RNDIS interface

This commit is contained in:
c_oflynn 2008-11-08 17:11:18 +00:00
parent f13ec95efa
commit b6e76a4947
3 changed files with 32 additions and 16 deletions

View file

@ -115,6 +115,8 @@ PROCESS_THREAD(rndis_process, ev, data_proc)
PROCESS_BEGIN(); PROCESS_BEGIN();
uint8_t bytecounter, headercounter; uint8_t bytecounter, headercounter;
uint16_t i, dataoffset; uint16_t i, dataoffset;
clock_time_t timediff;
clock_time_t thetime;
while(1) { while(1) {
@ -212,11 +214,19 @@ PROCESS_THREAD(rndis_process, ev, data_proc)
//Also mark the USB as "in use" //Also mark the USB as "in use"
//This is done as "flood control" by only allowing one IP packet per time limit //This is done as "flood control" by only allowing one IP packet per time limit
clock_time_t timediff = clock_time() - flood_timer.start; thetime = clock_time();
timediff = thetime - flood_timer.start;
//Oops, timer wrapped! Just ignore it for now
if (thetime < flood_timer.start) {
timediff = flood_timer.interval;
}
//If timer not yet expired //If timer not yet expired
if (timediff < flood_timer.interval) { //if (timediff < flood_timer.interval) {
if (!timer_expired(&flood_timer)) {
//Wait until timer expiers //Wait until timer expiers
usb_busy = 1; usb_busy = 1;
etimer_set(&et, flood_timer.interval - timediff); etimer_set(&et, flood_timer.interval - timediff);
@ -227,6 +237,7 @@ PROCESS_THREAD(rndis_process, ev, data_proc)
usb_busy = 0; usb_busy = 0;
} }
//Restart flood timer //Restart flood timer
timer_restart(&flood_timer); timer_restart(&flood_timer);
@ -236,10 +247,12 @@ PROCESS_THREAD(rndis_process, ev, data_proc)
//Try and read the header in //Try and read the header in
headercounter = sizeof(rndis_data_packet_t); headercounter = sizeof(rndis_data_packet_t);
uint8_t fail = 0;
//Hmm.. what's going on here //Hmm.. what's going on here
if (bytecounter < headercounter) { if (bytecounter < headercounter) {
Usb_ack_receive_out(); Usb_ack_receive_out();
break; fail = 1;
} }
i = 0; i = 0;
@ -253,16 +266,16 @@ PROCESS_THREAD(rndis_process, ev, data_proc)
//This is no good. Probably lost syncronization... just drop it for now //This is no good. Probably lost syncronization... just drop it for now
if(PBUF->MessageType != REMOTE_NDIS_PACKET_MSG) { if(PBUF->MessageType != REMOTE_NDIS_PACKET_MSG) {
Usb_ack_receive_out(); Usb_ack_receive_out();
break; fail = 1;
} }
//Looks like we've got a live one
rx_start_led();
//802.3 does not have OOB data, and we don't care about per-packet data //802.3 does not have OOB data, and we don't care about per-packet data
//so that just leave regular packet data... //so that just leave regular packet data...
if (PBUF->DataLength) { if (PBUF->DataLength && (fail == 0)) {
//Looks like we've got a live one
rx_start_led();
//Get offset //Get offset
dataoffset = PBUF->DataOffset; dataoffset = PBUF->DataOffset;
@ -323,6 +336,7 @@ PROCESS_THREAD(rndis_process, ev, data_proc)
uip_len = PBUF->DataLength; //uip_len includes LLH_LEN uip_len = PBUF->DataLength; //uip_len includes LLH_LEN
mac_ethernetToLowpan(uip_buf); mac_ethernetToLowpan(uip_buf);
} //if (PBUF->DataLength) } //if (PBUF->DataLength)
@ -345,7 +359,7 @@ PROCESS_THREAD(rndis_process, ev, data_proc)
/** /**
\brief Send data over RNDIS interface, data is in uipbuf and length is uiplen \brief Send data over RNDIS interface, data is in uipbuf and length is uiplen
*/ */
uint8_t rndis_send(uint8_t * senddata, uint16_t sendlen) uint8_t rndis_send(uint8_t * senddata, uint16_t sendlen, uint8_t led)
{ {
@ -390,7 +404,9 @@ uint8_t rndis_send(uint8_t * senddata, uint16_t sendlen)
while(!Is_usb_write_enabled()); while(!Is_usb_write_enabled());
} }
tx_end_led(); if (led) {
tx_end_led();
}
} }
Usb_send_in(); Usb_send_in();

View file

@ -60,7 +60,7 @@
//_____ D E C L A R A T I O N S ____________________________________________ //_____ D E C L A R A T I O N S ____________________________________________
uint8_t rndis_send(uint8_t * senddata, uint16_t sendlen); uint8_t rndis_send(uint8_t * senddata, uint16_t sendlen, uint8_t led);
void sof_action(void); void sof_action(void);
void rx_start_led(void); void rx_start_led(void);
void tx_end_led(void); void tx_end_led(void);

View file

@ -342,7 +342,7 @@ void mac_LowpanToEthernet(void)
uip_len += UIP_LLH_LEN; uip_len += UIP_LLH_LEN;
rndis_send(uip_buf, uip_len); rndis_send(uip_buf, uip_len, 1);
rndis_stat.rxok++; rndis_stat.rxok++;
uip_len = 0; uip_len = 0;
} }
@ -779,7 +779,7 @@ void mac_logTXtoEthernet(frame_create_params_t *p,frame_result_t *frame_result)
sendlen += UIP_LLH_LEN; sendlen += UIP_LLH_LEN;
rndis_send(raw_buf, sendlen); rndis_send(raw_buf, sendlen, 0);
rndis_stat.rxok++; rndis_stat.rxok++;
return; return;
@ -832,7 +832,7 @@ void mac_802154raw(const struct mac_driver *r)
sendlen += UIP_LLH_LEN; sendlen += UIP_LLH_LEN;
rndis_send(raw_buf, sendlen); rndis_send(raw_buf, sendlen, 1);
rndis_stat.rxok++; rndis_stat.rxok++;
return; return;