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:
- 116:39a41ebb675c
- Parent:
- 114:472502b31a12
- Child:
- 117:e9facba9db27
--- a/call_box_manager.cpp Thu Apr 23 13:57:54 2015 +0000 +++ b/call_box_manager.cpp Thu Apr 23 20:24:09 2015 +0000 @@ -6,58 +6,55 @@ Call_Box * __find_CB__( Vector * v_cb, int ext ){ Call_Box * cb = NULL; - for( register int i = 0; i < v_cb->size(); i++ ){ + for ( register int i = 0; i < v_cb->size (); i++ ) + { cb = ( Call_Box * )v_cb->get_element( i ); - if( cb->get_ext() == ext ) return( cb ); + if ( cb != NULL ) + { + if( cb->get_ext() == ext ) return( cb ); + } } return( NULL ); } -int refresh( Vector * v_cb, uint8_t * data, uint8_t * write_buffer, Call_Box * cb ){ - if( v_cb != NULL && data != NULL && write_buffer != NULL ){ +int refresh ( Vector * v_cb ) +{ + if( v_cb != NULL) + { static int lst_index = 0; - - 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__, - ( char * )data, cb->get_msg_id(), __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__, write_buffer ) ); - - if( debug_refresh ) send_msg("Refresh specific %d", cb->get_ext() ); + if( v_cb->size() > 0 ) + { + //FIXME pode acontecder problemas por ser static + static uint8_t data[ CB_BUFFER_SIZE ], write_buffer[ CB_BUFFER_SIZE ]; - return( 0x10 ); - }else{ - if( v_cb->size() > 0 ){ - if( lst_index >= v_cb->size() ) lst_index = 0; + led4 = 0; + if( lst_index >= v_cb->size() ) lst_index = 0; + + Call_Box * cb = (Call_Box * )v_cb->get_element( lst_index++ ); + + if( cb != NULL && cb->status == cb_idle ){ - Call_Box * cb = (Call_Box * )v_cb->get_element( lst_index++ ); + if( cb->get_ext() % 2 == 1 ){ + Call_Box * cb_master = __find_CB__( v_cb, cb->get_ext() - 1 ); + if( cb_master != NULL && cb_master->status != cb_idle ) return( 0x20 ); + } + + cb->set_msg_id( ( cb->get_msg_id() + 1 ) & ~BIT7 ); + + send2callboxes( build_cb_package( cb->get_ext(), cb->get_port(), __REGISTRY__, + ( char * )data, cb->get_msg_id(), CB_BUFFER_SIZE - __VZ_HEADER_OFFSET__, write_buffer ) ); - if( cb != NULL && cb->status == cb_idle ){ - - if( cb->get_ext() % 2 == 1 ){ - Call_Box * cb_master = __find_CB__( v_cb, cb->get_ext() - 1 ); - 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__, - ( char * )data, cb->get_msg_id(), __CB_BUFFER_SIZE__ - __VZ_HEADER_OFFSET__, write_buffer ) ); - - if( debug_refresh ) send_msg("Refresh %d", cb->get_ext() ); - - return( 0 ); - }else return( -5 ); - }else return( -3 ); - } + if( debug_refresh ) send_msg("Refresh %d", cb->get_ext() ); + + return( 0 ); + }else return( -5 ); + }else return( -3 ); }else return( -1 ); } //FiXME se validar, nao preciso de tantos parametros ... +/* void registry_aging( Vector * v_cb, uint8_t * data, uint8_t * write_buffer ){ for( register int i = 0; i < v_cb->size(); i++ ){ Call_Box * cb = (Call_Box * )v_cb->get_element( i ); @@ -72,70 +69,86 @@ } } } - -/* - 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 ){ - if( v_cb != NULL && data != NULL && write_buffer != NULL ){ - static int ext_list[ __MAX_CB_IN_A_BRANCH__ ]; +void wake_all_up( Vector * v_cb ) +{ + /*** + [ Principio ] + -- Procurar por CBx que constem sem seus pares registrados na lógica. + -- Mandar uma mensagem do tipo prompt-ping para este elemento + + -- Fluxo -- + - Verificar se possui uma lista ordenada de CBx atualizada + - Caso nao possua, gerar esta lista. + - Para cada iteraçao + - Verifica se o CBx é master ou slave + - Verifica se o par deste esta registrado + - Caso contratio + - Verifica se o CBx encontrado esta em ligaçao + - Caso nao esteja, encaminha mensagem de ping para o CBx ausente da dupla. + ***/ + + uint8_t data[ CB_BUFFER_SIZE ], write_buffer[ CB_BUFFER_SIZE ]; + if( ( v_cb != NULL ) ){ + 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" ); + Call_Box * cb = __find_CB__( v_cb, ext_list[ wake_all_up_index ] ); + + // verifica se o master esta em chamada. + if( cb != NULL && cb->status == cb_idle ) + { + 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" ); + Call_Box * cb = __find_CB__( v_cb, ( ext_list[ wake_all_up_index ] ) ); + + // verifica se o slave esta em chamada. + if( cb != NULL && cb->status == cb_idle ) + { + 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