Modularizando o src
Dependencies: EALib EthernetInterface_vz mbed-rtos mbed
Fork of header_main_colinas_V0-20-09-14 by
prompt.h@104:62646ef786a3, 2015-02-25 (annotated)
- Committer:
- klauss
- Date:
- Wed Feb 25 18:44:11 2015 +0000
- Revision:
- 104:62646ef786a3
- Parent:
- 99:e80850c51106
- Child:
- 105:a930035b6556
- Remo??o do implementado para bootloader cbx.; - Remo??o do implementado para telemetria.; - Remo??o do implementado ( comentado ) em file_system_manager.cpp; - BUGFIX perda de conex?o serial quando recebido um comando via eth;
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 | 74:81c47fff88a5 | 12 | #include <stdint.h> |
klauss | 44:cc4996469404 | 13 | #include "mbed.h" |
klauss | 74:81c47fff88a5 | 14 | #include "EthernetInterface.h" |
klauss | 74:81c47fff88a5 | 15 | #include "utils.h" // need for convert_ext_to_port() |
klauss | 44:cc4996469404 | 16 | #include "flood.h" |
klauss | 74:81c47fff88a5 | 17 | #include "shared_variables.h" |
klauss | 74:81c47fff88a5 | 18 | #include "debug.h" |
klauss | 74:81c47fff88a5 | 19 | #include "wdt_manager.h" |
klauss | 74:81c47fff88a5 | 20 | #include "file_system_manager.h" |
klauss | 99:e80850c51106 | 21 | #include "fw.h" |
klauss | 104:62646ef786a3 | 22 | #include "vz_protocol.h" |
klauss | 44:cc4996469404 | 23 | |
klauss | 97:8985817e8847 | 24 | #define PVERSION 25 |
klauss | 81:3656f00ab3db | 25 | |
klauss | 78:1353744f01e1 | 26 | #define TCP_IDLE_MAX_TIME 360//90 |
klauss | 78:1353744f01e1 | 27 | ///< Define o tempo maximo de espera por um novo comando via eth, dado que já estamos em uma sessão TCP. |
klauss | 78:1353744f01e1 | 28 | |
klauss | 78:1353744f01e1 | 29 | #define TCP_ALIVE_IDLE_MAX_TIME 360 |
klauss | 78:1353744f01e1 | 30 | ///< 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 | 31 | |
klauss | 104:62646ef786a3 | 32 | #define DEBUGBUFSIZE __PROMPT_ETH_BUFFER_SIZE__ |
klauss | 69:65665afbad5d | 33 | ///< Define o tamanho do buffer de entrada de dados. |
klauss | 44:cc4996469404 | 34 | |
klauss | 17:67a6b557eda5 | 35 | extern uint8_t dog; |
klauss | 69:65665afbad5d | 36 | ///< Variável de controle que ativa a mensagem de boas vindas. |
klauss | 69:65665afbad5d | 37 | |
klauss | 69:65665afbad5d | 38 | extern FILE *fmask; ///< arquivo de mascara de rede |
klauss | 69:65665afbad5d | 39 | extern FILE *fgate; ///< arquivo de gateway ip |
klauss | 69:65665afbad5d | 40 | |
klauss | 69:65665afbad5d | 41 | extern FILE *fip; ///< arquivo de header ip |
klauss | 69:65665afbad5d | 42 | extern FILE *fext; ///< arquivo de header ext |
klauss | 69:65665afbad5d | 43 | extern FILE *fport; ///< arquivo de header sip port |
klauss | 69:65665afbad5d | 44 | |
klauss | 69:65665afbad5d | 45 | extern FILE *fsip; ///< arquivo de server sip ip |
klauss | 69:65665afbad5d | 46 | extern FILE *fserext; ///< arquivo de server sip ext |
klauss | 69:65665afbad5d | 47 | extern FILE *fsport; ///< arquivo de server sip port |
klauss | 69:65665afbad5d | 48 | |
klauss | 69:65665afbad5d | 49 | extern FILE *fudpport; ///< arquivo de porta udp que a header escuta |
klauss | 69:65665afbad5d | 50 | extern FILE *ftcpport; ///< arquivo de porta tcp que a header escuta |
klauss | 17:67a6b557eda5 | 51 | |
klauss | 74:81c47fff88a5 | 52 | extern bool flood_silence; |
klauss | 74:81c47fff88a5 | 53 | extern bool delayed_flood; |
klauss | 74:81c47fff88a5 | 54 | ///< Variável de controle do envio de pacotes de flood off |
klauss | 74:81c47fff88a5 | 55 | |
klauss | 78:1353744f01e1 | 56 | extern bool tcp_alive; |
klauss | 78:1353744f01e1 | 57 | ///< Flag que indica para não dar timeout na conexão tcp |
klauss | 78:1353744f01e1 | 58 | |
klauss | 78:1353744f01e1 | 59 | extern Timer tcp_timer; |
klauss | 78:1353744f01e1 | 60 | ///< Timer responsavel por dar timeout por não utilização de recurso. |
klauss | 78:1353744f01e1 | 61 | |
klauss | 69:65665afbad5d | 62 | /** |
klauss | 69:65665afbad5d | 63 | * @Synopsis Principal função de processamento de comandos. |
klauss | 69:65665afbad5d | 64 | * |
klauss | 69:65665afbad5d | 65 | * \note Apesar de formalmente receber apenas um parâmetro, esta função verifica uma porta TCP para verificar eventual |
klauss | 69:65665afbad5d | 66 | * envio de comandos, processando qualquer comando enviado por um usuário ligado na rede. |
klauss | 69:65665afbad5d | 67 | * |
klauss | 69:65665afbad5d | 68 | * @param ethernet_pkg Uma string de comando que será analisada, caso seja um comando válido, executa-o. |
klauss | 69:65665afbad5d | 69 | * |
klauss | 69:65665afbad5d | 70 | * @return NULL, sempre retorna NULL. |
klauss | 69:65665afbad5d | 71 | * |
klauss | 69:65665afbad5d | 72 | * Exemplo: |
klauss | 69:65665afbad5d | 73 | * @code |
klauss | 69:65665afbad5d | 74 | * ... |
klauss | 69:65665afbad5d | 75 | * char * returned_prompt = prompt_process( NULL ); |
klauss | 69:65665afbad5d | 76 | * ... |
klauss | 69:65665afbad5d | 77 | * @endcode |
klauss | 69:65665afbad5d | 78 | */ |
klauss | 69:65665afbad5d | 79 | char * prompt_process( char * ethernet_pkg ); |
klauss | 69:65665afbad5d | 80 | |
klauss | 69:65665afbad5d | 81 | /** |
klauss | 69:65665afbad5d | 82 | * @Synopsis Init file system and check if files exist |
klauss | 69:65665afbad5d | 83 | * |
klauss | 69:65665afbad5d | 84 | * Exemplo: |
klauss | 69:65665afbad5d | 85 | * @code |
klauss | 69:65665afbad5d | 86 | * ... |
klauss | 69:65665afbad5d | 87 | * init_fsystem(); |
klauss | 69:65665afbad5d | 88 | * ... |
klauss | 69:65665afbad5d | 89 | * @endcode |
klauss | 69:65665afbad5d | 90 | */ |
klauss | 69:65665afbad5d | 91 | void init_fsystem(); |
klauss | 28:94aec56c6329 | 92 | |
klauss | 69:65665afbad5d | 93 | /** |
klauss | 69:65665afbad5d | 94 | * @Synopsis Inicializa o prompt e os sockets de conexão eth |
klauss | 69:65665afbad5d | 95 | * |
klauss | 69:65665afbad5d | 96 | * Exemplo: |
klauss | 69:65665afbad5d | 97 | * @code |
klauss | 69:65665afbad5d | 98 | * ... |
klauss | 69:65665afbad5d | 99 | * init_prompt(); |
klauss | 69:65665afbad5d | 100 | * ... |
klauss | 69:65665afbad5d | 101 | * @endcode |
klauss | 69:65665afbad5d | 102 | */ |
klauss | 78:1353744f01e1 | 103 | void init_prompt_eth(); |
klauss | 69:65665afbad5d | 104 | |
klauss | 44:cc4996469404 | 105 | extern char * debug_buf; |
klauss | 69:65665afbad5d | 106 | ///< Buffer de entrada dos dados via serial. |
klauss | 17:67a6b557eda5 | 107 | |
klauss | 17:67a6b557eda5 | 108 | #endif |