Modularizando o src

Dependencies:   EALib EthernetInterface_vz mbed-rtos mbed

Fork of header_main_colinas_V0-20-09-14 by VZTECH

Committer:
klauss
Date:
Sun May 24 16:07:14 2015 +0000
Revision:
127:e7160a463b6c
Parent:
126:1f90756250fb
Child:
128:3ae1c74773a8
versao para merge de monitoramento de bateria

Who changed what in which revision?

UserRevisionLine numberNew contents of line
klauss 69:65665afbad5d 1 /**
klauss 69:65665afbad5d 2 * @file prompt.h
klauss 69:65665afbad5d 3 * @Synopsis Implementa as funcionalidades de prompt/prompt-eth da Header.
klauss 69:65665afbad5d 4 * @author Fernando Cola / Jhontan Casale
klauss 69:65665afbad5d 5 * @version 1
klauss 69:65665afbad5d 6 * @date 2014-11-05
klauss 69:65665afbad5d 7 */
klauss 69:65665afbad5d 8
klauss 17:67a6b557eda5 9 #ifndef _PROMPT_H
klauss 17:67a6b557eda5 10 #define _PROMPT_H
klauss 17:67a6b557eda5 11
klauss 44:cc4996469404 12 #include "mbed.h"
klauss 127:e7160a463b6c 13 #include "debug.h"
klauss 74:81c47fff88a5 14 #include "shared_variables.h"
klauss 127:e7160a463b6c 15
klauss 121:ee02790d00b7 16 #include "bits.h"
klauss 127:e7160a463b6c 17
klauss 121:ee02790d00b7 18 #include "flood.h"
klauss 127:e7160a463b6c 19
klauss 126:1f90756250fb 20 #include "vz_protocol.h"
klauss 127:e7160a463b6c 21
klauss 126:1f90756250fb 22 #include <stdlib.h>
klauss 44:cc4996469404 23
klauss 119:ee6a53069455 24 const uint8_t PVERSION = 25;
klauss 119:ee6a53069455 25 const uint8_t PROMPT_UDP_COMMAND_SIZE = 64;
klauss 119:ee6a53069455 26 const uint8_t PERSISTENT_TCP_IDLE_MAX_TIME = 30;
klauss 81:3656f00ab3db 27
klauss 119:ee6a53069455 28 const uint16_t TCP_IDLE_MAX_TIME = 360;
klauss 78:1353744f01e1 29 ///< Define o tempo maximo de espera por um novo comando via eth, dado que já estamos em uma sessão TCP.
klauss 78:1353744f01e1 30
klauss 119:ee6a53069455 31 const uint16_t TCP_ALIVE_IDLE_MAX_TIME = 360;
klauss 78:1353744f01e1 32 ///< 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.
klauss 69:65665afbad5d 33
klauss 121:ee02790d00b7 34 const uint16_t PROMPT_ETH_BUFFER_SIZE = 1024;
klauss 121:ee02790d00b7 35 ///< Representa o tamanho máximo do pacote recebido pelo prompt da Header.
klauss 121:ee02790d00b7 36
klauss 121:ee02790d00b7 37 const uint16_t DEBUGBUFSIZE = PROMPT_ETH_BUFFER_SIZE;
klauss 69:65665afbad5d 38 ///< Define o tamanho do buffer de entrada de dados.
klauss 44:cc4996469404 39
klauss 17:67a6b557eda5 40 extern uint8_t dog;
klauss 69:65665afbad5d 41 ///< Variável de controle que ativa a mensagem de boas vindas.
klauss 69:65665afbad5d 42
klauss 121:ee02790d00b7 43 extern bool flood_silence;
klauss 69:65665afbad5d 44
klauss 74:81c47fff88a5 45 extern bool delayed_flood;
klauss 74:81c47fff88a5 46 ///< Variável de controle do envio de pacotes de flood off
klauss 74:81c47fff88a5 47
klauss 78:1353744f01e1 48 extern bool tcp_alive;
klauss 78:1353744f01e1 49 ///< Flag que indica para não dar timeout na conexão tcp
klauss 78:1353744f01e1 50
klauss 114:472502b31a12 51 extern Timer tcp_timer;
klauss 78:1353744f01e1 52 ///< Timer responsavel por dar timeout por não utilização de recurso.
klauss 78:1353744f01e1 53
klauss 69:65665afbad5d 54 /**
klauss 69:65665afbad5d 55 * @Synopsis Principal função de processamento de comandos.
klauss 69:65665afbad5d 56 *
klauss 69:65665afbad5d 57 * \note Apesar de formalmente receber apenas um parâmetro, esta função verifica uma porta TCP para verificar eventual
klauss 69:65665afbad5d 58 * envio de comandos, processando qualquer comando enviado por um usuário ligado na rede.
klauss 69:65665afbad5d 59 *
klauss 69:65665afbad5d 60 * @param ethernet_pkg Uma string de comando que será analisada, caso seja um comando válido, executa-o.
klauss 69:65665afbad5d 61 *
klauss 69:65665afbad5d 62 * @return NULL, sempre retorna NULL.
klauss 69:65665afbad5d 63 *
klauss 69:65665afbad5d 64 * Exemplo:
klauss 69:65665afbad5d 65 * @code
klauss 69:65665afbad5d 66 * ...
klauss 69:65665afbad5d 67 * char * returned_prompt = prompt_process( NULL );
klauss 69:65665afbad5d 68 * ...
klauss 69:65665afbad5d 69 * @endcode
klauss 69:65665afbad5d 70 */
klauss 121:ee02790d00b7 71 char * prompt_process ( char * msg_from_cb, int length );
klauss 28:94aec56c6329 72
klauss 69:65665afbad5d 73 /**
klauss 69:65665afbad5d 74 * @Synopsis Inicializa o prompt e os sockets de conexão eth
klauss 69:65665afbad5d 75 *
klauss 69:65665afbad5d 76 * Exemplo:
klauss 69:65665afbad5d 77 * @code
klauss 69:65665afbad5d 78 * ...
klauss 69:65665afbad5d 79 * init_prompt();
klauss 69:65665afbad5d 80 * ...
klauss 69:65665afbad5d 81 * @endcode
klauss 69:65665afbad5d 82 */
klauss 121:ee02790d00b7 83 int init_prompt_eth ( void );
klauss 69:65665afbad5d 84
klauss 44:cc4996469404 85 extern char * debug_buf;
klauss 69:65665afbad5d 86 ///< Buffer de entrada dos dados via serial.
klauss 17:67a6b557eda5 87
klauss 119:ee6a53069455 88 inline void reconnect_udp_prompt_process( void )
klauss 119:ee6a53069455 89 {
klauss 119:ee6a53069455 90 udp_client.close();
klauss 119:ee6a53069455 91 udp_client.set_blocking( false, 0 );
klauss 119:ee6a53069455 92 udp_client.bind( UDP_PORT_LISTENER );
klauss 119:ee6a53069455 93 }
klauss 119:ee6a53069455 94
klauss 17:67a6b557eda5 95 #endif