Modularizando o src
Dependencies: EALib EthernetInterface_vz mbed-rtos mbed
Fork of header_main_colinas_V0-20-09-14 by
Diff: call_box_manager.cpp
- Revision:
- 104:62646ef786a3
- Parent:
- 92:92df17f538a8
- Child:
- 105:a930035b6556
diff -r e3cabfc2f533 -r 62646ef786a3 call_box_manager.cpp --- a/call_box_manager.cpp Thu Feb 19 18:04:33 2015 +0000 +++ b/call_box_manager.cpp Wed Feb 25 18:44:11 2015 +0000 @@ -20,7 +20,6 @@ if( cb != NULL ){ timer_refresh.reset(); - //cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ( ~BIT7 ) ); cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ~BIT7 ); send2callboxes( __build_cb_package__( cb->get_ext(), cb->get_port(), __REGISTRY__, @@ -42,7 +41,6 @@ if( cb_master != NULL && cb_master->status != cb_idle ) return( 0x20 ); } - //cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ( ~BIT7 ) ); cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ~BIT7 ); send2callboxes( __build_cb_package__( cb->get_ext(), cb->get_port(), __REGISTRY__, @@ -73,69 +71,68 @@ } } -/* - A ideia desse cara aqui ... a cada x sec. ele vai passar pelos cbx registrados na logica, - contidos em v_cb e verificar quais estao ausentes ( pares, masters, slaves ) e mandar um - registry pra cada um deles ... um por ver ... mantendo uma lista com os que estao ainda - off, e deveriam estar on, e atualizar essa lista ... por exemplo a cada 3 sec. - -*/ void wake_all_up( Vector * v_cb, uint8_t * data, uint8_t * write_buffer ){ +/** + * Esta função busca por, dado uma lista de cbx, procura por buracos, + * ou seja, slaves/masters que deveriam estar registrados uma vez que + * o outro master/slave esta registrado, e manda um "ping" para esse cbx, + * para efetivamente criar ele na lógica. + */ if( v_cb != NULL && data != NULL && write_buffer != NULL ){ - static int ext_list[ __MAX_CB_IN_A_BRANCH__ ]; + static int ext_list[ __MAX_CB_IN_A_BRANCH__ + 1 ]; + static uint8_t last_size = 0; uint8_t size = v_cb->size(); + static int wake_all_up_index = 0; - bool once = true; - - if( size > 0 ){ + if( last_size != size ) + { for( register int i = 0; i < size; i++ ){ ext_list[ i ] = ( ( Call_Box * )v_cb->get_element( i ) )->get_ext(); } qsort( ext_list, v_cb->size(), sizeof( int ), ls_comp ); - - for( register int i = 0; i < size; i++ ){ - // testa se eh o master - if( ( ext_list[ i ] % 2 ) == 0 ){ - //testa se o slave nao esta registrado - //FIXME resolver o que acontece com o ultimo carinha == master, provavelmente fazendo um || ( i == size ) - if( ( ( i + 1 ) < size ) && ( ext_list[ i + 1 ] != ( ext_list[ i ] + 1 ) ) || ( size == 1 ) ){ - if( debug_wake ) debug_msg("Mestre %d encontrado sem slave %d", ext_list[ i ], ext_list[ i ] + 1 ); - if( once ){ - strcpy( ( char * )data, "ping\r\r\r\n" ); - Call_Box * cb = __find_CB__( v_cb, ext_list[ i ] ); - if( cb != NULL ){ - //cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ( ~BIT7 ) ); - cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ~BIT7 ); - - send2callboxes( __build_cb_package__( ( cb->get_ext() + 1 ), ( cb->get_port() + 1 ), __PROMPT__, - ( char * )data, cb->get_msg_id(), __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__, write_buffer ) ); + } + + if( size > 0 ) + { + // testa se eh o master + if( ( ext_list[ wake_all_up_index ] % 2 ) == 0 ) + { + //testa se o slave nao esta registrado + if( ( size == 1 ) || ( ( wake_all_up_index + 1 ) == size ) || ( ext_list[ wake_all_up_index + 1 ] != ( ext_list[ wake_all_up_index ] + 1 ) ) ) + { + strcpy( ( char * )data, "ping\r\r\r\n" ); + Call_Box * cb = __find_CB__( v_cb, ext_list[ wake_all_up_index ] ); + if( cb != NULL ) + { + cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ~BIT7 ); + + send2callboxes( __build_cb_package__( ( cb->get_ext() + 1 ), ( cb->get_port() + 1 ), __PROMPT__, + ( char * )data, cb->get_msg_id(), __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__, write_buffer ) ); + + if( debug_wake ) send_msg("%d without %d - ping sent to %d", + ext_list[ wake_all_up_index ], ext_list[ wake_all_up_index ] + 1, cb->get_ext() + 1 ); + } + } - if( debug_wake ) debug_msg("Slave %d pingado", cb->get_ext() + 1 ); - } - once = false; - } - } - }else{ - if( ( ( i - 1 ) > 0 ) && ( ext_list[ i - 1 ] != ( ext_list[ i ] - 1 ) ) || ( size == 1 ) ){ - if( debug_wake ) debug_msg("Escravo revolucionario %d encontrado sem master %d", ext_list[ i ], ext_list[ i ] - 1 ); - if( once ){ - strcpy( ( char * )data, "ping\r\r\r\n" ); - Call_Box * cb = __find_CB__( v_cb, ( ext_list[ i ] ) ); - if( cb != NULL ){ - //cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ( ~BIT7 ) ); - cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ~BIT7 ); - - send2callboxes( __build_cb_package__( ( cb->get_ext() - 1 ), ( cb->get_port() - 1 ), __PROMPT__, - ( char * )data, cb->get_msg_id(), __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__, write_buffer ) ); - - if( debug_wake ) debug_msg("Master %d pingado", cb->get_ext() - 1 ); - } - once = false; - } + }else{ + if( ( size == 1 ) || ( wake_all_up_index == 0 ) || ( wake_all_up_index >= 1 ) && ( ext_list[ wake_all_up_index - 1 ] != ( ext_list[ wake_all_up_index ] - 1 ) ) ) + { + strcpy( ( char * )data, "ping\r\r\r\n" ); + Call_Box * cb = __find_CB__( v_cb, ( ext_list[ wake_all_up_index ] ) ); + if( cb != NULL ) + { + cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ~BIT7 ); + + send2callboxes( __build_cb_package__( ( cb->get_ext() - 1 ), ( cb->get_port() - 1 ), __PROMPT__, + ( char * )data, cb->get_msg_id(), __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__, write_buffer ) ); + + if( debug_wake ) send_msg("%d without %d - ping sent to %d", + ext_list[ wake_all_up_index ], ext_list[ wake_all_up_index ] - 1, cb->get_ext() - 1 ); } } } } + if( ++wake_all_up_index >= size ) wake_all_up_index = 0; } } \ No newline at end of file