aboutsummaryrefslogtreecommitdiffstats
path: root/Projects/Webserver/Lib/uip
diff options
context:
space:
mode:
authorDean Camera <dean@fourwalledcubicle.com>2010-02-03 10:39:33 +0000
committerDean Camera <dean@fourwalledcubicle.com>2010-02-03 10:39:33 +0000
commit16ea5aa7a2e5f326f8ff129e740a19bb3fb7829f (patch)
treeaf3d7d3ccecbfb64d7cadbf1d731c7cfb5817e13 /Projects/Webserver/Lib/uip
parent77e86e7d82c65b1c2a75f965cb936b8f7ad97ac2 (diff)
downloadlufa-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.c5
-rw-r--r--Projects/Webserver/Lib/uip/clock.h1
-rw-r--r--Projects/Webserver/Lib/uip/uipopt.h60
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;
/** @} */