![](/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
prompt.h
- Committer:
- klauss
- Date:
- 2015-04-23
- Revision:
- 116:39a41ebb675c
- Parent:
- 114:472502b31a12
- Child:
- 117:e9facba9db27
File content as of revision 116:39a41ebb675c:
/** * @file prompt.h * @Synopsis Implementa as funcionalidades de prompt/prompt-eth da Header. * @author Fernando Cola / Jhontan Casale * @version 1 * @date 2014-11-05 */ #ifndef _PROMPT_H #define _PROMPT_H #include <stdint.h> #include "mbed.h" #include "EthernetInterface.h" #include "utils.h" // need for convert_ext_to_port() #include "flood.h" #include "shared_variables.h" #include "debug.h" #include "wdt_manager.h" #include "file_system_manager.h" #include "fw.h" const uint8_t PVERSION = 25; const uint8_t PROMPT_UDP_COMMAND_SIZE = 64; const uint8_t PERSISTENT_TCP_IDLE_MAX_TIME = 30; const uint16_t TCP_IDLE_MAX_TIME = 360; ///< Define o tempo maximo de espera por um novo comando via eth, dado que já estamos em uma sessão TCP. const uint16_t TCP_ALIVE_IDLE_MAX_TIME = 360; ///< Define o tempo maximo de espera por um novo comando via eth dado que já estamos em uma sessão TCP e a flag tcp_alive esta on. const uint16_t DEBUGBUFSIZE = __PROMPT_ETH_BUFFER_SIZE__; ///< Define o tamanho do buffer de entrada de dados. extern uint8_t dog; ///< Variável de controle que ativa a mensagem de boas vindas. extern FILE *fmask; ///< arquivo de mascara de rede extern FILE *fgate; ///< arquivo de gateway ip extern FILE *fip; ///< arquivo de header ip extern FILE *fext; ///< arquivo de header ext extern FILE *fport; ///< arquivo de header sip port extern FILE *fsip; ///< arquivo de server sip ip extern FILE *fserext; ///< arquivo de server sip ext extern FILE *fsport; ///< arquivo de server sip port extern FILE *fudpport; ///< arquivo de porta udp que a header escuta extern FILE *ftcpport; ///< arquivo de porta tcp que a header escuta extern FILE *fshift_port; extern bool flood_silence; extern bool delayed_flood; ///< Variável de controle do envio de pacotes de flood off extern bool tcp_alive; ///< Flag que indica para não dar timeout na conexão tcp extern Timer tcp_timer; ///< Timer responsavel por dar timeout por não utilização de recurso. /** * @Synopsis Principal função de processamento de comandos. * * \note Apesar de formalmente receber apenas um parâmetro, esta função verifica uma porta TCP para verificar eventual * envio de comandos, processando qualquer comando enviado por um usuário ligado na rede. * * @param ethernet_pkg Uma string de comando que será analisada, caso seja um comando válido, executa-o. * * @return NULL, sempre retorna NULL. * * Exemplo: * @code * ... * char * returned_prompt = prompt_process( NULL ); * ... * @endcode */ char * prompt_process( char * msg_from_cb, int length ); /** * @Synopsis Init file system and check if files exist * * Exemplo: * @code * ... * init_fsystem(); * ... * @endcode */ void init_fsystem(); /** * @Synopsis Inicializa o prompt e os sockets de conexão eth * * Exemplo: * @code * ... * init_prompt(); * ... * @endcode */ void init_prompt_eth(); extern char * debug_buf; ///< Buffer de entrada dos dados via serial. inline void reconnect_udp_prompt_process( void ) { udp_client.close(); udp_client.set_blocking( false, 0 ); udp_client.bind( UDP_PORT_LISTENER ); } #endif