Modularizando o src
Dependencies: EALib EthernetInterface_vz mbed-rtos mbed
Fork of header_main_colinas_V0-20-09-14 by
prompt.h@127:e7160a463b6c, 2015-05-24 (annotated)
- 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?
User | Revision | Line number | New 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 |