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