![](/media/cache/group/default_image.jpg.50x50_q85.jpg)
Modularizando o src
Dependencies: EALib EthernetInterface_vz mbed-rtos mbed
Fork of header_main_colinas_V0-20-09-14 by
clock.cpp
- Committer:
- klauss
- Date:
- 2015-05-04
- Revision:
- 120:770f00554b1e
- Parent:
- 119:ee6a53069455
- Child:
- 121:ee02790d00b7
File content as of revision 120:770f00554b1e:
#include "clock.h" time_t current_time = 0; UDPSocket clock_sock; Endpoint clock_server; Timer server_clock_timer; int request_clock_to_server ( void ) { char clock_msg[ TIME_MSG_SIZE ]; for ( register uint8_t i = 0; i < TIME_MSG_SIZE; i++ ) clock_msg [ i ] = 0x00; clock_msg [ 0 ] = 0x23; //int send = clock_sock.sendTo( clock_server, clock_msg, strlen( clock_msg ) ); int send = clock_sock.sendTo( clock_server, clock_msg, sizeof ( clock_msg ) ); if ( debug_clock ) debug_msg("::%d::%s::%s::%d::", send, clock_msg, clock_server.get_address (), clock_server.get_port () ); if ( send != strlen( clock_msg ) ) { if( debug_reconnect ) debug_msg("Reconnect clock request" ); clock_sock_reconnect (); miss_closk_send_pkg++; } if ( debug_clock ) debug_msg("send :: %d", send ); return ( send ); } int check_clock ( void ) { if( server_clock_timer.read() > EXTERNAL_TIME_REQUEST_WAIT_SECONDS ) { server_clock_timer.reset(); return request_clock_to_server (); } else { // nro arbitrario maior que strlen( request_time ) return 0x30; } } int update_clock ( void ) { char time_msg[ TIME_MSG_SIZE ]; Endpoint local_clock_server; int time_msg_rcv = clock_sock.receiveFrom( local_clock_server, time_msg, sizeof( time_msg ) ); if( time_msg_rcv == -1 ) { if( debug_reconnect ) send_msg("Reconnect clock socket"); clock_sock_reconnect (); } else { if ( time_msg [ 0 ] != 0x24 ) { debug_msg("Error: time_msg [ 0 ] != 0x24"); return time_msg [ 0 ]; } else if ( time_msg [ 1 ] == 0x00 ) { debug_msg("Error: time_msg [ 0 ] == 0x00"); return time_msg [ 1 ]; } else if ( time_msg [ 1 ] > 0x0f ) { debug_msg("Error: time_msg [ 0 ] > 0x0f"); return time_msg [ 1 ]; } } time_t local_current_time = 0; local_current_time = 0; local_current_time |= ( ( uint32_t ) time_msg [ 40 ] ) << 24; local_current_time |= ( ( uint32_t ) time_msg [ 41 ] ) << 16; local_current_time |= ( ( uint32_t ) time_msg [ 42 ] ) << 8; local_current_time |= ( ( uint32_t ) time_msg [ 43 ] ); /* Como o valor recebido nos bytes [40 41 42 43] correspondem aos segundos decorridos desde 1/1/1900, e como queremos trabalhar com unixtime, convertemos fazendo a subtracao de 70 anos = 2208988800 */ local_current_time -= 2208988800; int diff_time = ( local_current_time > current_time ) ? local_current_time - current_time : current_time - local_current_time; if ( diff_time > 2 ) current_time = local_current_time; if ( debug_clock ) debug_msg("Clock.rcv ( %d ), diff [ %d ] ", local_current_time, diff_time ); return 0; } int init_clock ( void ) { const char host[] = "192.168.120.120"; int port = 123; int clock_server_set_address_ret = clock_server.set_address( host , port ); if ( debug_clock ) debug_msg("clock_server_set_address_ret :: %d", clock_server_set_address_ret ); clock_sock.set_blocking( false, 0 ); int clock_sock_bind_ret = clock_sock.bind( 8975 ); if ( debug_clock ) debug_msg("clock_sock_bind_ret ::%d", clock_sock_bind_ret ); server_clock_timer.start(); request_clock_to_server (); return ( clock_server_set_address_ret | clock_sock_bind_ret ); } int clock_sock_reconnect ( void ) { clock_sock.close (); clock_sock.set_blocking ( false, 0 ); int clock_sock_bind_ret = clock_sock.bind ( 8975 ); return ( clock_sock_bind_ret ); } void print_clock ( uint8_t * buffer ) { if( buffer != NULL ) { struct tm * result_tm; if( sizeof( time_t ) != sizeof( long ) ) { if ( debug_clock ) debug_msg("sizeof( time_t ) : %lu -- sizeof( long int ) : %lu\n", sizeof( time_t ), sizeof( long ) ); } if ( debug_clock ) debug_msg("current_time : %lu\t", current_time ); if( current_time != 0 ) { result_tm = localtime( ( const time_t *)¤t_time ); if ( result_tm ) { char formated_time[ 16 ]; /* Correcao "manual" do (GMT -3:00) */ result_tm->tm_hour -= 3; if ( result_tm->tm_hour < 0 ) result_tm->tm_hour = 24 + result_tm->tm_hour; size_t formated_nbytes = strftime( formated_time, sizeof( formated_time ), "%Y%m%d%H%M%S", result_tm ); if ( debug_clock ) debug_msg("clock() : %s\n", formated_time ); if( formated_nbytes != CLOCK_SYNC_SIZE ) debug_msg("( %lu )\n", formated_nbytes ); for( register int i = 0; i < CLOCK_SYNC_SIZE; i++ ) buffer[ i ] = formated_time[ i ]; } else { for( register int i = 0; i < CLOCK_SYNC_SIZE; i++ ) buffer[ i ] = 0xfa; } } else { for( register int i = 0; i < CLOCK_SYNC_SIZE; i++ ) buffer[ i ] = 0xab; } } } int show_clock ( void ) { char buffer[ 512 ]; struct tm * result_tm; if ( sizeof( time_t ) != sizeof( long ) ) { send_msg("sizeof( time_t ) : %lu -- sizeof( long int ) : %lu\n", sizeof( time_t ), sizeof( long ) ); } int filled = snprintf( buffer, 512, "current_time : %lu\tclock() : ", current_time ); int available_bytes = 512 - filled - 1; if ( current_time != 0 ) { result_tm = localtime( ( const time_t *)¤t_time ); if ( result_tm ) { char formated_time[ 16 ]; /* Correcao "manual" do (GMT -3:00) */ result_tm->tm_hour -= 3; if ( result_tm->tm_hour < 0 ) result_tm->tm_hour = 24 + result_tm->tm_hour; size_t formated_nbytes = strftime( formated_time, sizeof( formated_time ), "%Y%m%d%H%M%S", result_tm ); strncat ( buffer, formated_time, available_bytes ); if( formated_nbytes != CLOCK_SYNC_SIZE ) debug_msg("( %lu )\n", formated_nbytes ); } } else { strncat ( buffer, "???", available_bytes ); } send_msg( "%s", buffer ); return ( 0 ); }