Modularizando o src

Dependencies:   EALib EthernetInterface_vz mbed-rtos mbed

Fork of header_main_colinas_V0-20-09-14 by VZTECH

Committer:
klauss
Date:
Sat Jan 10 16:59:08 2015 +0000
Revision:
94:579628502c3e
Parent:
81:3656f00ab3db
Child:
97:8985817e8847
v21

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