Modularizando o src

Dependencies:   EALib EthernetInterface_vz mbed-rtos mbed

Fork of header_main_colinas_V0-20-09-14 by VZTECH

Revision:
104:62646ef786a3
Parent:
92:92df17f538a8
Child:
105:a930035b6556
--- 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