2016-10-20 08:40:41 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2014-2016 Cesanta Software Limited
|
|
|
|
* All rights reserved
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "mongoose.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "lwip/dhcp.h"
|
|
|
|
#include "lwip/init.h"
|
|
|
|
#include "lwip/netif.h"
|
|
|
|
#include "lwip/timers.h"
|
|
|
|
#include "netif/etharp.h"
|
|
|
|
|
|
|
|
#include "ethernetif.h"
|
|
|
|
#include "board.h"
|
|
|
|
#include "fsl_gpio.h"
|
|
|
|
#include "fsl_port.h"
|
|
|
|
|
|
|
|
#include "pin_mux.h"
|
|
|
|
|
|
|
|
/* IP address configuration. */
|
|
|
|
#define USE_DHCP 1 /* For static IP, set to 0 and configure options below */
|
|
|
|
#if !USE_DHCP
|
|
|
|
#define STATIC_IP "192.168.0.111"
|
|
|
|
#define STATIC_NM "255.255.255.0"
|
|
|
|
#define STATIC_GW "192.168.0.1"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void gpio_init() {
|
|
|
|
CLOCK_EnableClock(kCLOCK_PortA);
|
|
|
|
CLOCK_EnableClock(kCLOCK_PortB);
|
|
|
|
CLOCK_EnableClock(kCLOCK_PortE);
|
|
|
|
PORT_SetPinMux(BOARD_LED_RED_GPIO_PORT, BOARD_LED_RED_GPIO_PIN,
|
|
|
|
kPORT_MuxAsGpio);
|
|
|
|
LED_RED_INIT(0);
|
|
|
|
PORT_SetPinMux(BOARD_LED_GREEN_GPIO_PORT, BOARD_LED_GREEN_GPIO_PIN,
|
|
|
|
kPORT_MuxAsGpio);
|
|
|
|
LED_GREEN_INIT(0);
|
|
|
|
PORT_SetPinMux(BOARD_LED_BLUE_GPIO_PORT, BOARD_LED_BLUE_GPIO_PIN,
|
|
|
|
kPORT_MuxAsGpio);
|
|
|
|
LED_BLUE_INIT(0);
|
|
|
|
LED_BLUE_OFF();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ev_handler(struct mg_connection *nc, int ev, void *ev_data) {
|
|
|
|
if (ev == MG_EV_POLL) return;
|
2016-10-20 16:21:35 +03:00
|
|
|
/* printf("ev %d\r\n", ev); */
|
2016-10-20 08:40:41 +01:00
|
|
|
switch (ev) {
|
|
|
|
case MG_EV_ACCEPT: {
|
|
|
|
char addr[32];
|
|
|
|
mg_sock_addr_to_str(&nc->sa, addr, sizeof(addr),
|
|
|
|
MG_SOCK_STRINGIFY_IP | MG_SOCK_STRINGIFY_PORT);
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("%p: Connection from %s\r\n", nc, addr);
|
2016-10-20 08:40:41 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
case MG_EV_HTTP_REQUEST: {
|
|
|
|
struct http_message *hm = (struct http_message *) ev_data;
|
|
|
|
char addr[32];
|
|
|
|
mg_sock_addr_to_str(&nc->sa, addr, sizeof(addr),
|
|
|
|
MG_SOCK_STRINGIFY_IP | MG_SOCK_STRINGIFY_PORT);
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("%p: %.*s %.*s\r\n", nc, (int) hm->method.len, hm->method.p,
|
2016-10-20 08:40:41 +01:00
|
|
|
(int) hm->uri.len, hm->uri.p);
|
|
|
|
mg_send_response_line(nc, 200,
|
|
|
|
"Content-Type: text/html\r\n"
|
|
|
|
"Connection: close");
|
|
|
|
mg_printf(nc,
|
|
|
|
"\r\n<h1>Hello, %s!</h1>\r\n"
|
|
|
|
"You asked for %.*s\r\n",
|
|
|
|
addr, (int) hm->uri.len, hm->uri.p);
|
|
|
|
nc->flags |= MG_F_SEND_AND_CLOSE;
|
|
|
|
LED_BLUE_TOGGLE();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case MG_EV_CLOSE: {
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("%p: Connection closed\r\n", nc);
|
2016-10-20 08:40:41 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is a callback invoked by Mongoose to signal that a poll is needed soon.
|
|
|
|
* Since we're in a tight polling loop anyway (see below), we don't need to do
|
|
|
|
* anything.
|
|
|
|
*/
|
|
|
|
void mg_lwip_mgr_schedule_poll(struct mg_mgr *mgr) {
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void) {
|
|
|
|
struct netif eth0;
|
|
|
|
MPU_Type *base = MPU;
|
|
|
|
BOARD_InitPins();
|
|
|
|
BOARD_BootClockRUN();
|
|
|
|
BOARD_InitDebugConsole();
|
|
|
|
/* Disable MPU. */
|
|
|
|
base->CESR &= ~MPU_CESR_VLD_MASK;
|
|
|
|
lwip_init();
|
|
|
|
gpio_init();
|
|
|
|
LED_RED_ON();
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("Waiting for link...\r\n");
|
2016-10-20 08:40:41 +01:00
|
|
|
#if USE_DHCP
|
|
|
|
netif_add(ð0, NULL, NULL, NULL, NULL, ethernetif_init, ethernet_input);
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("Waiting for DHCP...\r\n");
|
2016-10-20 08:40:41 +01:00
|
|
|
LED_GREEN_ON();
|
|
|
|
dhcp_start(ð0);
|
|
|
|
u8_t os = 0xff, ds;
|
|
|
|
do {
|
|
|
|
ds = eth0.dhcp->state;
|
|
|
|
if (ds != os) {
|
2016-10-20 16:21:35 +03:00
|
|
|
printf(" DHCP state: %d\r\n", ds);
|
2016-10-20 08:40:41 +01:00
|
|
|
os = ds;
|
|
|
|
}
|
|
|
|
sys_check_timeouts();
|
|
|
|
} while (ds != DHCP_BOUND);
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("DHCP bound.\r\n");
|
2016-10-20 08:40:41 +01:00
|
|
|
#else
|
|
|
|
ip_addr_t ip, nm, gw;
|
|
|
|
if (!ipaddr_aton(STATIC_IP, &ip) || !ipaddr_aton(STATIC_NM, &nm) ||
|
|
|
|
!ipaddr_aton(STATIC_GW, &gw)) {
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("Invalid static IP configuration.\r\n");
|
2016-10-20 08:40:41 +01:00
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
netif_add(ð0, &ip, &nm, &gw, NULL, ethernetif_init, ethernet_input);
|
|
|
|
netif_set_up(ð0);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
netif_set_default(ð0);
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("Setting up HTTP server...\r\n");
|
2016-10-20 08:40:41 +01:00
|
|
|
|
|
|
|
struct mg_mgr mgr;
|
|
|
|
mg_mgr_init(&mgr, NULL);
|
|
|
|
|
|
|
|
const char *err;
|
|
|
|
struct mg_bind_opts opts = {};
|
|
|
|
opts.error_string = &err;
|
|
|
|
struct mg_connection *nc = mg_bind_opt(&mgr, "80", ev_handler, opts);
|
|
|
|
if (nc == NULL) {
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("Failed to create listener: %s\r\n", err);
|
2016-10-20 08:40:41 +01:00
|
|
|
LED_RED_ON();
|
|
|
|
LED_GREEN_OFF();
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
mg_set_protocol_http_websocket(nc);
|
2016-10-20 16:21:35 +03:00
|
|
|
printf("Server address: http://%s/\r\n", ipaddr_ntoa(ð0.ip_addr));
|
2016-10-20 08:40:41 +01:00
|
|
|
LED_RED_OFF();
|
|
|
|
LED_GREEN_ON();
|
|
|
|
|
|
|
|
while (1) {
|
|
|
|
sys_check_timeouts();
|
|
|
|
mg_mgr_poll(&mgr, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|