Add optional build without internal webserver

This commit is contained in:
dak664 2011-03-13 11:59:17 -04:00
parent a883c9bcbc
commit 14246ef811
2 changed files with 26 additions and 11 deletions

View file

@ -5,10 +5,17 @@ CONTIKI=../../..
WITH_UIP6=1 WITH_UIP6=1
UIP_CONF_IPV6=1 UIP_CONF_IPV6=1
APPS += webserver #Override inclusion of internal webserver with make WITH_WEBSERVER=0
WITH_WEBSERVER=1
ifeq ($(WITH_WEBSERVER), 0)
CFLAGS += -DPROJECT_CONF_H=\"project-conf.h\" CFLAGS += -DPROJECT_CONF_H=\"project-conf.h\"
PROJECT_SOURCEFILES += slip-bridge.c
else
APPS += webserver
CFLAGS += -DPROJECT_CONF_H=\"project-conf.h\" -DWEBSERVER
PROJECT_SOURCEFILES += slip-bridge.c httpd-simple.c PROJECT_SOURCEFILES += slip-bridge.c httpd-simple.c
endif
include $(CONTIKI)/Makefile.include include $(CONTIKI)/Makefile.include

View file

@ -45,11 +45,13 @@
#include "net/netstack.h" #include "net/netstack.h"
#include "dev/button-sensor.h" #include "dev/button-sensor.h"
#include "dev/slip.h" #include "dev/slip.h"
#define INTERNAL_WEBSERVER 1
#if INTERNAL_WEBSERVER /* For internal webserver Makefile must set APPS += webserver and PROJECT_SOURCEFILES += httpd-simple.c */
#if WEBSERVER
#include "webserver-nogui.h" #include "webserver-nogui.h"
#include "httpd-simple.h" #include "httpd-simple.h"
#endif #endif
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
@ -68,7 +70,8 @@ static uint8_t prefix_set;
PROCESS(border_router_process, "Border router process"); PROCESS(border_router_process, "Border router process");
AUTOSTART_PROCESSES(&border_router_process); AUTOSTART_PROCESSES(&border_router_process);
#if INTERNAL_WEBSERVER
#if WEBSERVER
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
/* Only one single web request at time */ /* Only one single web request at time */
static const char *TOP = "<html><head><title>ContikiRPL</title></head><body>\n"; static const char *TOP = "<html><head><title>ContikiRPL</title></head><body>\n";
@ -155,6 +158,9 @@ httpd_simple_get_script(const char *name)
{ {
return generate_routes; return generate_routes;
} }
#endif /* WEBSERVER */
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
static void static void
print_local_addresses(void) print_local_addresses(void)
@ -162,18 +168,17 @@ print_local_addresses(void)
int i; int i;
uint8_t state; uint8_t state;
PRINTF("Server IPv6 addresses:\n"); PRINTA("Server IPv6 addresses:\n");
for(i = 0; i < UIP_DS6_ADDR_NB; i++) { for(i = 0; i < UIP_DS6_ADDR_NB; i++) {
state = uip_ds6_if.addr_list[i].state; state = uip_ds6_if.addr_list[i].state;
if(uip_ds6_if.addr_list[i].isused && if(uip_ds6_if.addr_list[i].isused &&
(state == ADDR_TENTATIVE || state == ADDR_PREFERRED)) { (state == ADDR_TENTATIVE || state == ADDR_PREFERRED)) {
blen = 0; PRINTA(" ");
ipaddr_add(&uip_ds6_if.addr_list[i].ipaddr); uip_debug_ipaddr_print(&uip_ds6_if.addr_list[i].ipaddr);
PRINTF(" %s\n", buf); PRINTA("\n");
} }
} }
} }
#endif /* INTERNAL_WEBSERVER */
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
void void
request_prefix(void) request_prefix(void)
@ -206,9 +211,11 @@ PROCESS_THREAD(border_router_process, ev, data)
prefix_set = 0; prefix_set = 0;
PROCESS_PAUSE(); PROCESS_PAUSE();
#if INTERNAL_WEBSERVER
#if WEBSERVER
process_start(&webserver_nogui_process, NULL); process_start(&webserver_nogui_process, NULL);
#endif #endif
SENSORS_ACTIVATE(button_sensor); SENSORS_ACTIVATE(button_sensor);
PRINTF("RPL-Border router started\n"); PRINTF("RPL-Border router started\n");
@ -225,7 +232,8 @@ PROCESS_THREAD(border_router_process, ev, data)
rpl_set_prefix(dag, &prefix, 64); rpl_set_prefix(dag, &prefix, 64);
PRINTF("created a new RPL dag\n"); PRINTF("created a new RPL dag\n");
} }
#if INTERNAL_WEBSERVER
#if DEBUG || 1
print_local_addresses(); print_local_addresses();
#endif #endif