diff options
author | Dean Camera <dean@fourwalledcubicle.com> | 2010-02-03 10:39:33 +0000 |
---|---|---|
committer | Dean Camera <dean@fourwalledcubicle.com> | 2010-02-03 10:39:33 +0000 |
commit | 16ea5aa7a2e5f326f8ff129e740a19bb3fb7829f (patch) | |
tree | af3d7d3ccecbfb64d7cadbf1d731c7cfb5817e13 /Projects/Webserver/Lib/uip | |
parent | 77e86e7d82c65b1c2a75f965cb936b8f7ad97ac2 (diff) | |
download | lufa-16ea5aa7a2e5f326f8ff129e740a19bb3fb7829f.tar.gz lufa-16ea5aa7a2e5f326f8ff129e740a19bb3fb7829f.tar.bz2 lufa-16ea5aa7a2e5f326f8ff129e740a19bb3fb7829f.zip |
Add a TELNET server to the webserver project, which currently can list active TCP connections.
Diffstat (limited to 'Projects/Webserver/Lib/uip')
-rw-r--r-- | Projects/Webserver/Lib/uip/clock.c | 5 | ||||
-rw-r--r-- | Projects/Webserver/Lib/uip/clock.h | 1 | ||||
-rw-r--r-- | Projects/Webserver/Lib/uip/uipopt.h | 60 |
3 files changed, 45 insertions, 21 deletions
diff --git a/Projects/Webserver/Lib/uip/clock.c b/Projects/Webserver/Lib/uip/clock.c index e8a676b1a..299a747bc 100644 --- a/Projects/Webserver/Lib/uip/clock.c +++ b/Projects/Webserver/Lib/uip/clock.c @@ -29,9 +29,10 @@ clock_time_t clock_time() {
clock_time_t time; - cli(); + ATOMIC_BLOCK(ATOMIC_FORCEON) + { time = clock_datetime; - sei(); + } return time; } diff --git a/Projects/Webserver/Lib/uip/clock.h b/Projects/Webserver/Lib/uip/clock.h index 0852cde15..3e42e4a59 100644 --- a/Projects/Webserver/Lib/uip/clock.h +++ b/Projects/Webserver/Lib/uip/clock.h @@ -2,6 +2,7 @@ #define __CLOCK_ARCH_H__
#include <stdint.h>
+#include <util/atomic.h>
typedef uint16_t clock_time_t;
#define CLOCK_SECOND 100
diff --git a/Projects/Webserver/Lib/uip/uipopt.h b/Projects/Webserver/Lib/uip/uipopt.h index 23bce28a3..c8b3ad59e 100644 --- a/Projects/Webserver/Lib/uip/uipopt.h +++ b/Projects/Webserver/Lib/uip/uipopt.h @@ -346,14 +346,18 @@ * * \hideinitializer */ +#if !defined(UIP_URGDATA) #define UIP_URGDATA 0 +#endif /** * The initial retransmission timeout counted in timer pulses. * * This should not be changed. */ +#if !defined(UIP_RTO) #define UIP_RTO 3 +#endif /** * The maximum number of times a segment should be retransmitted @@ -361,7 +365,9 @@ * * This should not be changed. */ +#if !defined(UIP_MAXRTX) #define UIP_MAXRTX 8 +#endif /** * The maximum number of times a SYN segment should be retransmitted @@ -370,7 +376,9 @@ * * This should not need to be changed. */ +#if !defined(UIP_MAXSYNRTX) #define UIP_MAXSYNRTX 5 +#endif /** * The TCP maximum segment size. @@ -654,7 +662,7 @@ typedef uint32_t uip_stats_t; typedef struct httpd_state uip_tcp_appstate_t \endcode */ -#define UIP_UDP_APPCALL DHCPApp_Callback +#define UIP_UDP_APPCALL uIPManagement_UDPCallback void UIP_UDP_APPCALL(void); /** @@ -664,7 +672,7 @@ void UIP_UDP_APPCALL(void); * response to TCP/IP events. * */ -#define UIP_APPCALL HTTPServerApp_Callback +#define UIP_APPCALL uIPManagement_TCPCallback void UIP_APPCALL(void); /** @@ -674,16 +682,27 @@ void UIP_APPCALL(void); * uip_conn structure. This usually is typedef:ed to a struct holding * application state information. */ -typedef struct +typedef union { - uint8_t CurrentState; - uint8_t NextState; + struct + { + uint8_t CurrentState; + uint8_t NextState; + + char FileName[30]; + FIL FileHandle; + bool FileOpen; + uint32_t ACKedFilePos; + uint16_t SentChunkSize; + } HTTPServer; - char FileName[30]; - FIL FileHandle; - bool FileOpen; - uint32_t ACKedFilePos; - uint16_t SentChunkSize; + struct + { + uint8_t CurrentState; + uint8_t NextState; + + uint8_t IssuedCommand; + } TELNETServer; } uip_tcp_appstate_t; /** @@ -693,18 +712,21 @@ typedef struct * uip_conn structure. This usually is typedef:ed to a struct holding * application state information. */ -typedef struct +typedef union { - uint8_t CurrentState; - struct uip_udp_conn* Connection; - struct { - uint8_t AllocatedIP[4]; - uint8_t Netmask[4]; - uint8_t GatewayIP[4]; - uint8_t ServerIP[4]; - } DHCPOffer_Data; + uint8_t CurrentState; + struct uip_udp_conn* Connection; + + struct + { + uint8_t AllocatedIP[4]; + uint8_t Netmask[4]; + uint8_t GatewayIP[4]; + uint8_t ServerIP[4]; + } DHCPOffer_Data; + } DHCPClient; } uip_udp_appstate_t; /** @} */ |