Add networking option to the Microblaze Kintex demo.
parent
3012d9b94d
commit
18ff880e75
@ -0,0 +1,203 @@
|
|||||||
|
/*
|
||||||
|
FreeRTOS V7.0.2 - Copyright (C) 2011 Real Time Engineers Ltd.
|
||||||
|
|
||||||
|
|
||||||
|
***************************************************************************
|
||||||
|
* *
|
||||||
|
* FreeRTOS tutorial books are available in pdf and paperback. *
|
||||||
|
* Complete, revised, and edited pdf reference manuals are also *
|
||||||
|
* available. *
|
||||||
|
* *
|
||||||
|
* Purchasing FreeRTOS documentation will not only help you, by *
|
||||||
|
* ensuring you get running as quickly as possible and with an *
|
||||||
|
* in-depth knowledge of how to use FreeRTOS, it will also help *
|
||||||
|
* the FreeRTOS project to continue with its mission of providing *
|
||||||
|
* professional grade, cross platform, de facto standard solutions *
|
||||||
|
* for microcontrollers - completely free of charge! *
|
||||||
|
* *
|
||||||
|
* >>> See http://www.FreeRTOS.org/Documentation for details. <<< *
|
||||||
|
* *
|
||||||
|
* Thank you for using FreeRTOS, and thank you for your support! *
|
||||||
|
* *
|
||||||
|
***************************************************************************
|
||||||
|
|
||||||
|
|
||||||
|
This file is part of the FreeRTOS distribution.
|
||||||
|
|
||||||
|
FreeRTOS is free software; you can redistribute it and/or modify it under
|
||||||
|
the terms of the GNU General Public License (version 2) as published by the
|
||||||
|
Free Software Foundation AND MODIFIED BY the FreeRTOS exception.
|
||||||
|
>>>NOTE<<< The modification to the GPL is included to allow you to
|
||||||
|
distribute a combined work that includes FreeRTOS without being obliged to
|
||||||
|
provide the source code for proprietary components outside of the FreeRTOS
|
||||||
|
kernel. FreeRTOS is distributed in the hope that it will be useful, but
|
||||||
|
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
more details. You should have received a copy of the GNU General Public
|
||||||
|
License and the FreeRTOS license exception along with FreeRTOS; if not it
|
||||||
|
can be viewed here: http://www.freertos.org/a00114.html and also obtained
|
||||||
|
by writing to Richard Barry, contact details for whom are available on the
|
||||||
|
FreeRTOS WEB site.
|
||||||
|
|
||||||
|
1 tab == 4 spaces!
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org - Documentation, latest information, license and
|
||||||
|
contact details.
|
||||||
|
|
||||||
|
http://www.SafeRTOS.com - A version that is certified for use in safety
|
||||||
|
critical systems.
|
||||||
|
|
||||||
|
http://www.OpenRTOS.com - Commercial support, development, porting,
|
||||||
|
licensing and training services.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Standard includes. */
|
||||||
|
#include "stdlib.h"
|
||||||
|
#include "string.h"
|
||||||
|
|
||||||
|
/* lwIP core includes */
|
||||||
|
#include "lwip/opt.h"
|
||||||
|
#include "lwip/sockets.h"
|
||||||
|
|
||||||
|
/* FreeRTOS includes. */
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
|
||||||
|
/* Utils includes. */
|
||||||
|
#include "FreeRTOS_CLI.h"
|
||||||
|
|
||||||
|
/* Dimensions the buffer into which input characters are placed. */
|
||||||
|
#define cmdMAX_INPUT_SIZE 100
|
||||||
|
|
||||||
|
/* Dimensions the buffer into which string outputs can be placed. */
|
||||||
|
#define cmdMAX_OUTPUT_SIZE 1024
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
void vBasicSocketsCommandInterpreterTask( void *pvParameters )
|
||||||
|
{
|
||||||
|
long lSocket, lClientFd, lBytes, lAddrLen = sizeof( struct sockaddr_in ), lInputIndex;
|
||||||
|
struct sockaddr_in sLocalAddr;
|
||||||
|
struct sockaddr_in client_addr;
|
||||||
|
const char *pcWelcomeMessage = "FreeRTOS command server - connection accepted.\r\nType Help to view a list of registered commands.\r\n\r\n>";
|
||||||
|
char cInChar;
|
||||||
|
static char cInputString[ cmdMAX_INPUT_SIZE ], cOutputString[ cmdMAX_OUTPUT_SIZE ];
|
||||||
|
portBASE_TYPE xReturned;
|
||||||
|
extern void vRegisterSampleCLICommands( void );
|
||||||
|
|
||||||
|
( void ) pvParameters;
|
||||||
|
|
||||||
|
/* Register the standard CLI commands. */
|
||||||
|
vRegisterSampleCLICommands();
|
||||||
|
|
||||||
|
lSocket = lwip_socket(AF_INET, SOCK_STREAM, 0);
|
||||||
|
|
||||||
|
if( lSocket >= 0 )
|
||||||
|
{
|
||||||
|
memset((char *)&sLocalAddr, 0, sizeof(sLocalAddr));
|
||||||
|
sLocalAddr.sin_family = AF_INET;
|
||||||
|
sLocalAddr.sin_len = sizeof(sLocalAddr);
|
||||||
|
sLocalAddr.sin_addr.s_addr = htonl(INADDR_ANY);
|
||||||
|
sLocalAddr.sin_port = ntohs( ( ( unsigned short ) 23 ) );
|
||||||
|
|
||||||
|
if( lwip_bind( lSocket, ( struct sockaddr *) &sLocalAddr, sizeof( sLocalAddr ) ) < 0 )
|
||||||
|
{
|
||||||
|
lwip_close( lSocket );
|
||||||
|
vTaskDelete( NULL );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( lwip_listen( lSocket, 20 ) != 0 )
|
||||||
|
{
|
||||||
|
lwip_close( lSocket );
|
||||||
|
vTaskDelete( NULL );
|
||||||
|
}
|
||||||
|
|
||||||
|
for( ;; )
|
||||||
|
{
|
||||||
|
|
||||||
|
lClientFd = lwip_accept(lSocket, ( struct sockaddr * ) &client_addr, ( u32_t * ) &lAddrLen );
|
||||||
|
|
||||||
|
if( lClientFd > 0L )
|
||||||
|
{
|
||||||
|
lwip_send( lClientFd, pcWelcomeMessage, strlen( ( const char * ) pcWelcomeMessage ), 0 );
|
||||||
|
|
||||||
|
lInputIndex = 0;
|
||||||
|
memset( cInputString, 0x00, cmdMAX_INPUT_SIZE );
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
lBytes = lwip_recv( lClientFd, &cInChar, sizeof( cInChar ), 0 );
|
||||||
|
|
||||||
|
if( lBytes > 0L )
|
||||||
|
{
|
||||||
|
if( cInChar == '\n' )
|
||||||
|
{
|
||||||
|
/* The input string has been terminated. Was the
|
||||||
|
input a quit command? */
|
||||||
|
if( strcmp( "quit", ( const char * ) cInputString ) == 0 )
|
||||||
|
{
|
||||||
|
/* Set lBytes to 0 to close the connection. */
|
||||||
|
lBytes = 0L;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* The input string was not a quit command.
|
||||||
|
Pass the string to the command interpreter. */
|
||||||
|
do
|
||||||
|
{
|
||||||
|
/* Get the next output string from the command interpreter. */
|
||||||
|
xReturned = FreeRTOS_CLIProcessCommand( cInputString, cOutputString, cmdMAX_INPUT_SIZE );
|
||||||
|
lwip_send( lClientFd, cOutputString, strlen( ( const char * ) cOutputString ), 0 );
|
||||||
|
|
||||||
|
} while( xReturned != pdFALSE );
|
||||||
|
|
||||||
|
|
||||||
|
/* All the strings generated by the input
|
||||||
|
command have been sent. Clear the input
|
||||||
|
string ready to receive the next command. */
|
||||||
|
lInputIndex = 0;
|
||||||
|
memset( cInputString, 0x00, cmdMAX_INPUT_SIZE );
|
||||||
|
lwip_send( lClientFd, "\r\n>", strlen( "\r\n>" ), 0 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if( cInChar == '\r' )
|
||||||
|
{
|
||||||
|
/* Ignore the character. */
|
||||||
|
}
|
||||||
|
else if( cInChar == '\b' )
|
||||||
|
{
|
||||||
|
/* Backspace was pressed. Erase the last
|
||||||
|
character in the string - if any. */
|
||||||
|
if( lInputIndex > 0 )
|
||||||
|
{
|
||||||
|
lInputIndex--;
|
||||||
|
cInputString[ lInputIndex ] = '\0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* A character was entered. Add it to the string
|
||||||
|
entered so far. When a \n is entered the complete
|
||||||
|
string will be passed to the command interpreter. */
|
||||||
|
if( lInputIndex < cmdMAX_INPUT_SIZE )
|
||||||
|
{
|
||||||
|
cInputString[ lInputIndex ] = cInChar;
|
||||||
|
lInputIndex++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} while( lBytes > 0L );
|
||||||
|
|
||||||
|
lwip_close( lClientFd );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Will only get here if a listening socket could not be created. */
|
||||||
|
vTaskDelete( NULL );
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,177 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2001-2003 Swedish Institute of Computer Science.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
* are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||||
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
||||||
|
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
||||||
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||||||
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
* OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This file is part of the lwIP TCP/IP stack.
|
||||||
|
*
|
||||||
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#include "lwip/opt.h"
|
||||||
|
#include "lwip/def.h"
|
||||||
|
#include "fs.h"
|
||||||
|
#include "fsdata.h"
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/** Set this to 1 to include "fsdata_custom.c" instead of "fsdata.c" for the
|
||||||
|
* file system (to prevent changing the file included in CVS) */
|
||||||
|
#ifndef HTTPD_USE_CUSTUM_FSDATA
|
||||||
|
#define HTTPD_USE_CUSTUM_FSDATA 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HTTPD_USE_CUSTUM_FSDATA
|
||||||
|
#include "fsdata_custom.c"
|
||||||
|
#else /* HTTPD_USE_CUSTUM_FSDATA */
|
||||||
|
#include "fsdata.c"
|
||||||
|
#endif /* HTTPD_USE_CUSTUM_FSDATA */
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------------------*/
|
||||||
|
/* Define the number of open files that we can support. */
|
||||||
|
#ifndef LWIP_MAX_OPEN_FILES
|
||||||
|
#define LWIP_MAX_OPEN_FILES 10
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Define the file system memory allocation structure. */
|
||||||
|
struct fs_table {
|
||||||
|
struct fs_file file;
|
||||||
|
u8_t inuse;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Allocate file system memory */
|
||||||
|
struct fs_table fs_memory[LWIP_MAX_OPEN_FILES];
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_CUSTOM_FILES
|
||||||
|
int fs_open_custom(struct fs_file *file, const char *name);
|
||||||
|
void fs_close_custom(struct fs_file *file);
|
||||||
|
#endif /* LWIP_HTTPD_CUSTOM_FILES */
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------------------*/
|
||||||
|
static struct fs_file *
|
||||||
|
fs_malloc(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for(i = 0; i < LWIP_MAX_OPEN_FILES; i++) {
|
||||||
|
if(fs_memory[i].inuse == 0) {
|
||||||
|
fs_memory[i].inuse = 1;
|
||||||
|
return(&fs_memory[i].file);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------------------*/
|
||||||
|
static void
|
||||||
|
fs_free(struct fs_file *file)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for(i = 0; i < LWIP_MAX_OPEN_FILES; i++) {
|
||||||
|
if(&fs_memory[i].file == file) {
|
||||||
|
fs_memory[i].inuse = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------------------*/
|
||||||
|
struct fs_file *
|
||||||
|
fs_open(const char *name)
|
||||||
|
{
|
||||||
|
struct fs_file *file;
|
||||||
|
const struct fsdata_file *f;
|
||||||
|
|
||||||
|
file = fs_malloc();
|
||||||
|
if(file == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_CUSTOM_FILES
|
||||||
|
if(fs_open_custom(file, name)) {
|
||||||
|
file->is_custom_file = 1;
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
file->is_custom_file = 0;
|
||||||
|
#endif /* LWIP_HTTPD_CUSTOM_FILES */
|
||||||
|
|
||||||
|
for(f = FS_ROOT; f != NULL; f = f->next) {
|
||||||
|
if (!strcmp(name, (char *)f->name)) {
|
||||||
|
file->data = (const char *)f->data;
|
||||||
|
file->len = f->len;
|
||||||
|
file->index = f->len;
|
||||||
|
file->pextension = NULL;
|
||||||
|
file->http_header_included = f->http_header_included;
|
||||||
|
#if HTTPD_PRECALCULATED_CHECKSUM
|
||||||
|
file->chksum_count = f->chksum_count;
|
||||||
|
file->chksum = f->chksum;
|
||||||
|
#endif /* HTTPD_PRECALCULATED_CHECKSUM */
|
||||||
|
#if LWIP_HTTPD_FILE_STATE
|
||||||
|
file->state = fs_state_init(file, name);
|
||||||
|
#endif /* #if LWIP_HTTPD_FILE_STATE */
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fs_free(file);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------------------------------*/
|
||||||
|
void
|
||||||
|
fs_close(struct fs_file *file)
|
||||||
|
{
|
||||||
|
#if LWIP_HTTPD_CUSTOM_FILES
|
||||||
|
if (file->is_custom_file) {
|
||||||
|
fs_close_custom(file);
|
||||||
|
}
|
||||||
|
#endif /* LWIP_HTTPD_CUSTOM_FILES */
|
||||||
|
#if LWIP_HTTPD_FILE_STATE
|
||||||
|
fs_state_free(file, file->state);
|
||||||
|
#endif /* #if LWIP_HTTPD_FILE_STATE */
|
||||||
|
fs_free(file);
|
||||||
|
}
|
||||||
|
/*-----------------------------------------------------------------------------------*/
|
||||||
|
int
|
||||||
|
fs_read(struct fs_file *file, char *buffer, int count)
|
||||||
|
{
|
||||||
|
int read;
|
||||||
|
|
||||||
|
if(file->index == file->len) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
read = file->len - file->index;
|
||||||
|
if(read > count) {
|
||||||
|
read = count;
|
||||||
|
}
|
||||||
|
|
||||||
|
MEMCPY(buffer, (file->data + file->index), read);
|
||||||
|
file->index += read;
|
||||||
|
|
||||||
|
return(read);
|
||||||
|
}
|
||||||
|
/*-----------------------------------------------------------------------------------*/
|
||||||
|
int fs_bytes_left(struct fs_file *file)
|
||||||
|
{
|
||||||
|
return file->len - file->index;
|
||||||
|
}
|
@ -0,0 +1,100 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2001-2003 Swedish Institute of Computer Science.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
* are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||||
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
||||||
|
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
||||||
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||||||
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
* OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This file is part of the lwIP TCP/IP stack.
|
||||||
|
*
|
||||||
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef __FS_H__
|
||||||
|
#define __FS_H__
|
||||||
|
|
||||||
|
#include "lwip/opt.h"
|
||||||
|
|
||||||
|
/** Set this to 1 and provide the functions:
|
||||||
|
* - "int fs_open_custom(struct fs_file *file, const char *name)"
|
||||||
|
* Called first for every opened file to allow opening files
|
||||||
|
* that are not included in fsdata(_custom).c
|
||||||
|
* - "void fs_close_custom(struct fs_file *file)"
|
||||||
|
* Called to free resources allocated by fs_open_custom().
|
||||||
|
*/
|
||||||
|
#ifndef LWIP_HTTPD_CUSTOM_FILES
|
||||||
|
#define LWIP_HTTPD_CUSTOM_FILES 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** Set this to 1 to include an application state argument per file
|
||||||
|
* that is opened. This allows to keep a state per connection/file.
|
||||||
|
*/
|
||||||
|
#ifndef LWIP_HTTPD_FILE_STATE
|
||||||
|
#define LWIP_HTTPD_FILE_STATE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** HTTPD_PRECALCULATED_CHECKSUM==1: include precompiled checksums for
|
||||||
|
* predefined (MSS-sized) chunks of the files to prevent having to calculate
|
||||||
|
* the checksums at runtime. */
|
||||||
|
#ifndef HTTPD_PRECALCULATED_CHECKSUM
|
||||||
|
#define HTTPD_PRECALCULATED_CHECKSUM 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if HTTPD_PRECALCULATED_CHECKSUM
|
||||||
|
struct fsdata_chksum {
|
||||||
|
u32_t offset;
|
||||||
|
u16_t chksum;
|
||||||
|
u16_t len;
|
||||||
|
};
|
||||||
|
#endif /* HTTPD_PRECALCULATED_CHECKSUM */
|
||||||
|
|
||||||
|
struct fs_file {
|
||||||
|
const char *data;
|
||||||
|
int len;
|
||||||
|
int index;
|
||||||
|
void *pextension;
|
||||||
|
#if HTTPD_PRECALCULATED_CHECKSUM
|
||||||
|
const struct fsdata_chksum *chksum;
|
||||||
|
u16_t chksum_count;
|
||||||
|
#endif /* HTTPD_PRECALCULATED_CHECKSUM */
|
||||||
|
u8_t http_header_included;
|
||||||
|
#if LWIP_HTTPD_CUSTOM_FILES
|
||||||
|
u8_t is_custom_file;
|
||||||
|
#endif /* LWIP_HTTPD_CUSTOM_FILES */
|
||||||
|
#if LWIP_HTTPD_FILE_STATE
|
||||||
|
void *state;
|
||||||
|
#endif /* LWIP_HTTPD_FILE_STATE */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct fs_file *fs_open(const char *name);
|
||||||
|
void fs_close(struct fs_file *file);
|
||||||
|
int fs_read(struct fs_file *file, char *buffer, int count);
|
||||||
|
int fs_bytes_left(struct fs_file *file);
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_FILE_STATE
|
||||||
|
/** This user-defined function is called when a file is opened. */
|
||||||
|
void *fs_state_init(struct fs_file *file, const char *name);
|
||||||
|
/** This user-defined function is called when a file is closed. */
|
||||||
|
void fs_state_free(struct fs_file *file, void *state);
|
||||||
|
#endif /* #if LWIP_HTTPD_FILE_STATE */
|
||||||
|
|
||||||
|
#endif /* __FS_H__ */
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,50 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2001-2003 Swedish Institute of Computer Science.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
* are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||||
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
||||||
|
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
||||||
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||||||
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
* OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This file is part of the lwIP TCP/IP stack.
|
||||||
|
*
|
||||||
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef __FSDATA_H__
|
||||||
|
#define __FSDATA_H__
|
||||||
|
|
||||||
|
#include "lwip/opt.h"
|
||||||
|
#include "fs.h"
|
||||||
|
|
||||||
|
struct fsdata_file {
|
||||||
|
const struct fsdata_file *next;
|
||||||
|
const unsigned char *name;
|
||||||
|
const unsigned char *data;
|
||||||
|
int len;
|
||||||
|
u8_t http_header_included;
|
||||||
|
#if HTTPD_PRECALCULATED_CHECKSUM
|
||||||
|
u16_t chksum_count;
|
||||||
|
const struct fsdata_chksum *chksum;
|
||||||
|
#endif /* HTTPD_PRECALCULATED_CHECKSUM */
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* __FSDATA_H__ */
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,236 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2001-2003 Swedish Institute of Computer Science.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
* are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||||
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
||||||
|
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
||||||
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||||||
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
* OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This file is part of the lwIP TCP/IP stack.
|
||||||
|
*
|
||||||
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
|
*
|
||||||
|
* This version of the file has been modified by Texas Instruments to offer
|
||||||
|
* simple server-side-include (SSI) and Common Gateway Interface (CGI)
|
||||||
|
* capability.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __HTTPD_H__
|
||||||
|
#define __HTTPD_H__
|
||||||
|
|
||||||
|
#include "lwip/opt.h"
|
||||||
|
#include "lwip/err.h"
|
||||||
|
#include "lwip/pbuf.h"
|
||||||
|
|
||||||
|
|
||||||
|
/** Set this to 1 to support CGI */
|
||||||
|
#ifndef LWIP_HTTPD_CGI
|
||||||
|
#define LWIP_HTTPD_CGI 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** Set this to 1 to support SSI (Server-Side-Includes) */
|
||||||
|
#ifndef LWIP_HTTPD_SSI
|
||||||
|
#define LWIP_HTTPD_SSI 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** Set this to 1 to support HTTP POST */
|
||||||
|
#ifndef LWIP_HTTPD_SUPPORT_POST
|
||||||
|
#define LWIP_HTTPD_SUPPORT_POST 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_CGI
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Function pointer for a CGI script handler.
|
||||||
|
*
|
||||||
|
* This function is called each time the HTTPD server is asked for a file
|
||||||
|
* whose name was previously registered as a CGI function using a call to
|
||||||
|
* http_set_cgi_handler. The iIndex parameter provides the index of the
|
||||||
|
* CGI within the ppcURLs array passed to http_set_cgi_handler. Parameters
|
||||||
|
* pcParam and pcValue provide access to the parameters provided along with
|
||||||
|
* the URI. iNumParams provides a count of the entries in the pcParam and
|
||||||
|
* pcValue arrays. Each entry in the pcParam array contains the name of a
|
||||||
|
* parameter with the corresponding entry in the pcValue array containing the
|
||||||
|
* value for that parameter. Note that pcParam may contain multiple elements
|
||||||
|
* with the same name if, for example, a multi-selection list control is used
|
||||||
|
* in the form generating the data.
|
||||||
|
*
|
||||||
|
* The function should return a pointer to a character string which is the
|
||||||
|
* path and filename of the response that is to be sent to the connected
|
||||||
|
* browser, for example "/thanks.htm" or "/response/error.ssi".
|
||||||
|
*
|
||||||
|
* The maximum number of parameters that will be passed to this function via
|
||||||
|
* iNumParams is defined by LWIP_HTTPD_MAX_CGI_PARAMETERS. Any parameters in the incoming
|
||||||
|
* HTTP request above this number will be discarded.
|
||||||
|
*
|
||||||
|
* Requests intended for use by this CGI mechanism must be sent using the GET
|
||||||
|
* method (which encodes all parameters within the URI rather than in a block
|
||||||
|
* later in the request). Attempts to use the POST method will result in the
|
||||||
|
* request being ignored.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
typedef const char *(*tCGIHandler)(int iIndex, int iNumParams, char *pcParam[],
|
||||||
|
char *pcValue[]);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Structure defining the base filename (URL) of a CGI and the associated
|
||||||
|
* function which is to be called when that URL is requested.
|
||||||
|
*/
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
const char *pcCGIName;
|
||||||
|
tCGIHandler pfnCGIHandler;
|
||||||
|
} tCGI;
|
||||||
|
|
||||||
|
void http_set_cgi_handlers(const tCGI *pCGIs, int iNumHandlers);
|
||||||
|
|
||||||
|
|
||||||
|
/* The maximum number of parameters that the CGI handler can be sent. */
|
||||||
|
#ifndef LWIP_HTTPD_MAX_CGI_PARAMETERS
|
||||||
|
#define LWIP_HTTPD_MAX_CGI_PARAMETERS 16
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LWIP_HTTPD_CGI */
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_SSI
|
||||||
|
|
||||||
|
/** LWIP_HTTPD_SSI_MULTIPART==1: SSI handler function is called with 2 more
|
||||||
|
* arguments indicating a counter for insert string that are too long to be
|
||||||
|
* inserted at once: the SSI handler function must then set 'next_tag_part'
|
||||||
|
* which will be passed back to it in the next call. */
|
||||||
|
#ifndef LWIP_HTTPD_SSI_MULTIPART
|
||||||
|
#define LWIP_HTTPD_SSI_MULTIPART 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Function pointer for the SSI tag handler callback.
|
||||||
|
*
|
||||||
|
* This function will be called each time the HTTPD server detects a tag of the
|
||||||
|
* form <!--#name--> in a .shtml, .ssi or .shtm file where "name" appears as
|
||||||
|
* one of the tags supplied to http_set_ssi_handler in the ppcTags array. The
|
||||||
|
* returned insert string, which will be appended after the the string
|
||||||
|
* "<!--#name-->" in file sent back to the client,should be written to pointer
|
||||||
|
* pcInsert. iInsertLen contains the size of the buffer pointed to by
|
||||||
|
* pcInsert. The iIndex parameter provides the zero-based index of the tag as
|
||||||
|
* found in the ppcTags array and identifies the tag that is to be processed.
|
||||||
|
*
|
||||||
|
* The handler returns the number of characters written to pcInsert excluding
|
||||||
|
* any terminating NULL or a negative number to indicate a failure (tag not
|
||||||
|
* recognized, for example).
|
||||||
|
*
|
||||||
|
* Note that the behavior of this SSI mechanism is somewhat different from the
|
||||||
|
* "normal" SSI processing as found in, for example, the Apache web server. In
|
||||||
|
* this case, the inserted text is appended following the SSI tag rather than
|
||||||
|
* replacing the tag entirely. This allows for an implementation that does not
|
||||||
|
* require significant additional buffering of output data yet which will still
|
||||||
|
* offer usable SSI functionality. One downside to this approach is when
|
||||||
|
* attempting to use SSI within JavaScript. The SSI tag is structured to
|
||||||
|
* resemble an HTML comment but this syntax does not constitute a comment
|
||||||
|
* within JavaScript and, hence, leaving the tag in place will result in
|
||||||
|
* problems in these cases. To work around this, any SSI tag which needs to
|
||||||
|
* output JavaScript code must do so in an encapsulated way, sending the whole
|
||||||
|
* HTML <script>...</script> section as a single include.
|
||||||
|
*/
|
||||||
|
typedef u16_t (*tSSIHandler)(int iIndex, char *pcInsert, int iInsertLen
|
||||||
|
#if LWIP_HTTPD_SSI_MULTIPART
|
||||||
|
, u16_t current_tag_part, u16_t *next_tag_part
|
||||||
|
#endif /* LWIP_HTTPD_SSI_MULTIPART */
|
||||||
|
#if LWIP_HTTPD_FILE_STATE
|
||||||
|
, void *connection_state
|
||||||
|
#endif /* LWIP_HTTPD_FILE_STATE */
|
||||||
|
);
|
||||||
|
|
||||||
|
void http_set_ssi_handler(tSSIHandler pfnSSIHandler,
|
||||||
|
const char **ppcTags, int iNumTags);
|
||||||
|
|
||||||
|
/* The maximum length of the string comprising the tag name */
|
||||||
|
#ifndef LWIP_HTTPD_MAX_TAG_NAME_LEN
|
||||||
|
#define LWIP_HTTPD_MAX_TAG_NAME_LEN 8
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The maximum length of string that can be returned to replace any given tag */
|
||||||
|
#ifndef LWIP_HTTPD_MAX_TAG_INSERT_LEN
|
||||||
|
#define LWIP_HTTPD_MAX_TAG_INSERT_LEN 192
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* LWIP_HTTPD_SSI */
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_SUPPORT_POST
|
||||||
|
|
||||||
|
/* These functions must be implemented by the application */
|
||||||
|
|
||||||
|
/** Called when a POST request has been received. The application can decide
|
||||||
|
* whether to accept it or not.
|
||||||
|
*
|
||||||
|
* @param connection Unique connection identifier, valid until httpd_post_end
|
||||||
|
* is called.
|
||||||
|
* @param uri The HTTP header URI receiving the POST request.
|
||||||
|
* @param http_request The raw HTTP request (the first packet, normally).
|
||||||
|
* @param http_request_len Size of 'http_request'.
|
||||||
|
* @param content_len Content-Length from HTTP header.
|
||||||
|
* @param response_uri Filename of response file, to be filled when denying the
|
||||||
|
* request
|
||||||
|
* @param response_uri_len Size of the 'response_uri' buffer.
|
||||||
|
* @param post_auto_wnd Set this to 0 to let the callback code handle window
|
||||||
|
* updates by calling 'httpd_post_data_recved' (to throttle rx speed)
|
||||||
|
* default is 1 (httpd handles window updates automatically)
|
||||||
|
* @return ERR_OK: Accept the POST request, data may be passed in
|
||||||
|
* another err_t: Deny the POST request, send back 'bad request'.
|
||||||
|
*/
|
||||||
|
err_t httpd_post_begin(void *connection, const char *uri, const char *http_request,
|
||||||
|
u16_t http_request_len, int content_len, char *response_uri,
|
||||||
|
u16_t response_uri_len, u8_t *post_auto_wnd);
|
||||||
|
|
||||||
|
/** Called for each pbuf of data that has been received for a POST.
|
||||||
|
* ATTENTION: The application is responsible for freeing the pbufs passed in!
|
||||||
|
*
|
||||||
|
* @param connection Unique connection identifier.
|
||||||
|
* @param p Received data.
|
||||||
|
* @return ERR_OK: Data accepted.
|
||||||
|
* another err_t: Data denied, http_post_get_response_uri will be called.
|
||||||
|
*/
|
||||||
|
err_t httpd_post_receive_data(void *connection, struct pbuf *p);
|
||||||
|
|
||||||
|
/** Called when all data is received or when the connection is closed.
|
||||||
|
* The application must return the filename/URI of a file to send in response
|
||||||
|
* to this POST request. If the response_uri buffer is untouched, a 404
|
||||||
|
* response is returned.
|
||||||
|
*
|
||||||
|
* @param connection Unique connection identifier.
|
||||||
|
* @param response_uri Filename of response file, to be filled when denying the request
|
||||||
|
* @param response_uri_len Size of the 'response_uri' buffer.
|
||||||
|
*/
|
||||||
|
void httpd_post_finished(void *connection, char *response_uri, u16_t response_uri_len);
|
||||||
|
|
||||||
|
#ifndef LWIP_HTTPD_POST_MANUAL_WND
|
||||||
|
#define LWIP_HTTPD_POST_MANUAL_WND 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_POST_MANUAL_WND
|
||||||
|
void httpd_post_data_recved(void *connection, u16_t recved_len);
|
||||||
|
#endif /* LWIP_HTTPD_POST_MANUAL_WND */
|
||||||
|
|
||||||
|
#endif /* LWIP_HTTPD_SUPPORT_POST */
|
||||||
|
|
||||||
|
void httpd_init(void);
|
||||||
|
|
||||||
|
#endif /* __HTTPD_H__ */
|
@ -0,0 +1,115 @@
|
|||||||
|
#ifndef __HTTPD_STRUCTS_H__
|
||||||
|
#define __HTTPD_STRUCTS_H__
|
||||||
|
|
||||||
|
#include "httpd.h"
|
||||||
|
|
||||||
|
/** This string is passed in the HTTP header as "Server: " */
|
||||||
|
#ifndef HTTPD_SERVER_AGENT
|
||||||
|
#define HTTPD_SERVER_AGENT "lwIP/1.3.1 (http://savannah.nongnu.org/projects/lwip)"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** Set this to 1 if you want to include code that creates HTTP headers
|
||||||
|
* at runtime. Default is off: HTTP headers are then created statically
|
||||||
|
* by the makefsdata tool. Static headers mean smaller code size, but
|
||||||
|
* the (readonly) fsdata will grow a bit as every file includes the HTTP
|
||||||
|
* header. */
|
||||||
|
#ifndef LWIP_HTTPD_DYNAMIC_HEADERS
|
||||||
|
#define LWIP_HTTPD_DYNAMIC_HEADERS 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if LWIP_HTTPD_DYNAMIC_HEADERS
|
||||||
|
/** This struct is used for a list of HTTP header strings for various
|
||||||
|
* filename extensions. */
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
const char *extension;
|
||||||
|
int headerIndex;
|
||||||
|
} tHTTPHeader;
|
||||||
|
|
||||||
|
/** A list of strings used in HTTP headers */
|
||||||
|
static const char * const g_psHTTPHeaderStrings[] =
|
||||||
|
{
|
||||||
|
"Content-type: text/html\r\n\r\n",
|
||||||
|
"Content-type: text/html\r\nExpires: Fri, 10 Apr 2008 14:00:00 GMT\r\nPragma: no-cache\r\n\r\n",
|
||||||
|
"Content-type: image/gif\r\n\r\n",
|
||||||
|
"Content-type: image/png\r\n\r\n",
|
||||||
|
"Content-type: image/jpeg\r\n\r\n",
|
||||||
|
"Content-type: image/bmp\r\n\r\n",
|
||||||
|
"Content-type: image/x-icon\r\n\r\n",
|
||||||
|
"Content-type: application/octet-stream\r\n\r\n",
|
||||||
|
"Content-type: application/x-javascript\r\n\r\n",
|
||||||
|
"Content-type: application/x-javascript\r\n\r\n",
|
||||||
|
"Content-type: text/css\r\n\r\n",
|
||||||
|
"Content-type: application/x-shockwave-flash\r\n\r\n",
|
||||||
|
"Content-type: text/xml\r\n\r\n",
|
||||||
|
"Content-type: text/plain\r\n\r\n",
|
||||||
|
"HTTP/1.0 200 OK\r\n",
|
||||||
|
"HTTP/1.0 404 File not found\r\n",
|
||||||
|
"HTTP/1.0 400 Bad Request\r\n",
|
||||||
|
"HTTP/1.0 501 Not Implemented\r\n",
|
||||||
|
"HTTP/1.1 200 OK\r\n",
|
||||||
|
"HTTP/1.1 404 File not found\r\n",
|
||||||
|
"HTTP/1.1 400 Bad Request\r\n",
|
||||||
|
"HTTP/1.1 501 Not Implemented\r\n",
|
||||||
|
"Content-Length: ",
|
||||||
|
"Connection: Close\r\n",
|
||||||
|
"Server: "HTTPD_SERVER_AGENT"\r\n",
|
||||||
|
"\r\n<html><body><h2>404: The requested file cannot be found.</h2></body></html>\r\n"
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Indexes into the g_psHTTPHeaderStrings array */
|
||||||
|
#define HTTP_HDR_HTML 0 /* text/html */
|
||||||
|
#define HTTP_HDR_SSI 1 /* text/html Expires... */
|
||||||
|
#define HTTP_HDR_GIF 2 /* image/gif */
|
||||||
|
#define HTTP_HDR_PNG 3 /* image/png */
|
||||||
|
#define HTTP_HDR_JPG 4 /* image/jpeg */
|
||||||
|
#define HTTP_HDR_BMP 5 /* image/bmp */
|
||||||
|
#define HTTP_HDR_ICO 6 /* image/x-icon */
|
||||||
|
#define HTTP_HDR_APP 7 /* application/octet-stream */
|
||||||
|
#define HTTP_HDR_JS 8 /* application/x-javascript */
|
||||||
|
#define HTTP_HDR_RA 9 /* application/x-javascript */
|
||||||
|
#define HTTP_HDR_CSS 10 /* text/css */
|
||||||
|
#define HTTP_HDR_SWF 11 /* application/x-shockwave-flash */
|
||||||
|
#define HTTP_HDR_XML 12 /* text/xml */
|
||||||
|
#define HTTP_HDR_DEFAULT_TYPE 13 /* text/plain */
|
||||||
|
#define HTTP_HDR_OK 14 /* 200 OK */
|
||||||
|
#define HTTP_HDR_NOT_FOUND 15 /* 404 File not found */
|
||||||
|
#define HTTP_HDR_BAD_REQUEST 16 /* 400 Bad request */
|
||||||
|
#define HTTP_HDR_NOT_IMPL 17 /* 501 Not Implemented */
|
||||||
|
#define HTTP_HDR_OK_11 18 /* 200 OK */
|
||||||
|
#define HTTP_HDR_NOT_FOUND_11 19 /* 404 File not found */
|
||||||
|
#define HTTP_HDR_BAD_REQUEST_11 20 /* 400 Bad request */
|
||||||
|
#define HTTP_HDR_NOT_IMPL_11 21 /* 501 Not Implemented */
|
||||||
|
#define HTTP_HDR_CONTENT_LENGTH 22 /* Content-Length: (HTTP 1.1)*/
|
||||||
|
#define HTTP_HDR_CONN_CLOSE 23 /* Connection: Close (HTTP 1.1) */
|
||||||
|
#define HTTP_HDR_SERVER 24 /* Server: HTTPD_SERVER_AGENT */
|
||||||
|
#define DEFAULT_404_HTML 25 /* default 404 body */
|
||||||
|
|
||||||
|
/** A list of extension-to-HTTP header strings */
|
||||||
|
const static tHTTPHeader g_psHTTPHeaders[] =
|
||||||
|
{
|
||||||
|
{ "html", HTTP_HDR_HTML},
|
||||||
|
{ "htm", HTTP_HDR_HTML},
|
||||||
|
{ "shtml",HTTP_HDR_SSI},
|
||||||
|
{ "shtm", HTTP_HDR_SSI},
|
||||||
|
{ "ssi", HTTP_HDR_SSI},
|
||||||
|
{ "gif", HTTP_HDR_GIF},
|
||||||
|
{ "png", HTTP_HDR_PNG},
|
||||||
|
{ "jpg", HTTP_HDR_JPG},
|
||||||
|
{ "bmp", HTTP_HDR_BMP},
|
||||||
|
{ "ico", HTTP_HDR_ICO},
|
||||||
|
{ "class",HTTP_HDR_APP},
|
||||||
|
{ "cls", HTTP_HDR_APP},
|
||||||
|
{ "js", HTTP_HDR_JS},
|
||||||
|
{ "ram", HTTP_HDR_RA},
|
||||||
|
{ "css", HTTP_HDR_CSS},
|
||||||
|
{ "swf", HTTP_HDR_SWF},
|
||||||
|
{ "xml", HTTP_HDR_XML}
|
||||||
|
};
|
||||||
|
|
||||||
|
#define NUM_HTTP_HEADERS (sizeof(g_psHTTPHeaders) / sizeof(tHTTPHeader))
|
||||||
|
|
||||||
|
#endif /* LWIP_HTTPD_DYNAMIC_HEADERS */
|
||||||
|
|
||||||
|
#endif /* __HTTPD_STRUCTS_H__ */
|
Binary file not shown.
@ -0,0 +1,36 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<ItemGroup>
|
||||||
|
<Filter Include="Source Files">
|
||||||
|
<UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>
|
||||||
|
<Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="Header Files">
|
||||||
|
<UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>
|
||||||
|
<Extensions>h;hpp;hxx;hm;inl;inc;xsd</Extensions>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="Resource Files">
|
||||||
|
<UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>
|
||||||
|
<Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>
|
||||||
|
</Filter>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="ReadMe.txt" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClInclude Include="stdafx.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="targetver.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClCompile Include="stdafx.cpp">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="makefsdata.c">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
</ItemGroup>
|
||||||
|
</Project>
|
@ -0,0 +1,3 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
</Project>
|
@ -0,0 +1,21 @@
|
|||||||
|
<html>
|
||||||
|
<head><title>lwIP - A Lightweight TCP/IP Stack</title></head>
|
||||||
|
<body bgcolor="white" text="black">
|
||||||
|
|
||||||
|
<table width="100%">
|
||||||
|
<tr valign="top"><td width="80">
|
||||||
|
<a href="http://www.sics.se/"><img src="/img/sics.gif"
|
||||||
|
border="0" alt="SICS logo" title="SICS logo"></a>
|
||||||
|
</td><td width="500">
|
||||||
|
<h1>lwIP - A Lightweight TCP/IP Stack</h1>
|
||||||
|
<h2>404 - Page not found</h2>
|
||||||
|
<p>
|
||||||
|
Sorry, the page you are requesting was not found on this
|
||||||
|
server.
|
||||||
|
</p>
|
||||||
|
</td><td>
|
||||||
|
|
||||||
|
</td></tr>
|
||||||
|
</table>
|
||||||
|
</body>
|
||||||
|
</html>
|
@ -0,0 +1,20 @@
|
|||||||
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>FreeRTOS.org lwIP WEB server demo</title>
|
||||||
|
</head>
|
||||||
|
<BODY onLoad="window.setTimeout("location.href='index.shtml'",2000)">
|
||||||
|
<font face="arial">
|
||||||
|
<a href="index.shtml">Task Stats</a> <b>|</b> <a href="runtime.shtml">Run Time Stats</a> <b>|</b> <a href="http://www.freertos.org/">FreeRTOS Homepage</a> <b>|</b> <a href="logo.jpg">37K jpg</a>
|
||||||
|
<br><p>
|
||||||
|
<hr>
|
||||||
|
<br><p>
|
||||||
|
<h2>Task statistics</h2>
|
||||||
|
Page will refresh every 2 seconds.<p>
|
||||||
|
<font face="courier"><pre>Task State Priority Stack #<br>************************************************<br>
|
||||||
|
<!--#rtos_stats-->
|
||||||
|
</pre></font>
|
||||||
|
</font>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 28 KiB |
@ -0,0 +1,20 @@
|
|||||||
|
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>FreeRTOS.org lwIP WEB server demo</title>
|
||||||
|
</head>
|
||||||
|
<BODY onLoad="window.setTimeout("location.href='runtime.shtml'",2000)">
|
||||||
|
<font face="arial">
|
||||||
|
<a href="index.shtml">Task Stats</a> <b>|</b> <a href="runtime.shtml">Run Time Stats</a> <b>|</b> <a href="http://www.freertos.org/">FreeRTOS Homepage</a> <b>|</b> <a href="logo.jpg">37K jpg</a>
|
||||||
|
<br><p>
|
||||||
|
<hr>
|
||||||
|
<br><p>
|
||||||
|
<h2>Run-time statistics</h2>
|
||||||
|
Page will refresh every 2 seconds.<p>
|
||||||
|
<font face="courier"><pre>Task Abs Time % Time<br>****************************************<br>
|
||||||
|
<!--#run_stats-->
|
||||||
|
</pre></font>
|
||||||
|
</font>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,97 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
|
||||||
|
open(OUTPUT, "> fsdata.c");
|
||||||
|
|
||||||
|
chdir("fs");
|
||||||
|
open(FILES, "find . -type f |");
|
||||||
|
|
||||||
|
while($file = <FILES>) {
|
||||||
|
|
||||||
|
# Do not include files in CVS directories nor backup files.
|
||||||
|
if($file =~ /(CVS|~)/) {
|
||||||
|
next;
|
||||||
|
}
|
||||||
|
|
||||||
|
chop($file);
|
||||||
|
|
||||||
|
open(HEADER, "> /tmp/header") || die $!;
|
||||||
|
if($file =~ /404/) {
|
||||||
|
print(HEADER "HTTP/1.0 404 File not found\r\n");
|
||||||
|
} else {
|
||||||
|
print(HEADER "HTTP/1.0 200 OK\r\n");
|
||||||
|
}
|
||||||
|
print(HEADER "Server: lwIP/pre-0.6 (http://www.sics.se/~adam/lwip/)\r\n");
|
||||||
|
if($file =~ /\.html$/) {
|
||||||
|
print(HEADER "Content-type: text/html\r\n");
|
||||||
|
} elsif($file =~ /\.gif$/) {
|
||||||
|
print(HEADER "Content-type: image/gif\r\n");
|
||||||
|
} elsif($file =~ /\.png$/) {
|
||||||
|
print(HEADER "Content-type: image/png\r\n");
|
||||||
|
} elsif($file =~ /\.jpg$/) {
|
||||||
|
print(HEADER "Content-type: image/jpeg\r\n");
|
||||||
|
} elsif($file =~ /\.class$/) {
|
||||||
|
print(HEADER "Content-type: application/octet-stream\r\n");
|
||||||
|
} elsif($file =~ /\.ram$/) {
|
||||||
|
print(HEADER "Content-type: audio/x-pn-realaudio\r\n");
|
||||||
|
} else {
|
||||||
|
print(HEADER "Content-type: text/plain\r\n");
|
||||||
|
}
|
||||||
|
print(HEADER "\r\n");
|
||||||
|
close(HEADER);
|
||||||
|
|
||||||
|
unless($file =~ /\.plain$/ || $file =~ /cgi/) {
|
||||||
|
system("cat /tmp/header $file > /tmp/file");
|
||||||
|
} else {
|
||||||
|
system("cp $file /tmp/file");
|
||||||
|
}
|
||||||
|
|
||||||
|
open(FILE, "/tmp/file");
|
||||||
|
unlink("/tmp/file");
|
||||||
|
unlink("/tmp/header");
|
||||||
|
|
||||||
|
$file =~ s/\.//;
|
||||||
|
$fvar = $file;
|
||||||
|
$fvar =~ s-/-_-g;
|
||||||
|
$fvar =~ s-\.-_-g;
|
||||||
|
print(OUTPUT "static const unsigned char data".$fvar."[] = {\n");
|
||||||
|
print(OUTPUT "\t/* $file */\n\t");
|
||||||
|
for($j = 0; $j < length($file); $j++) {
|
||||||
|
printf(OUTPUT "%#02x, ", unpack("C", substr($file, $j, 1)));
|
||||||
|
}
|
||||||
|
printf(OUTPUT "0,\n");
|
||||||
|
|
||||||
|
|
||||||
|
$i = 0;
|
||||||
|
while(read(FILE, $data, 1)) {
|
||||||
|
if($i == 0) {
|
||||||
|
print(OUTPUT "\t");
|
||||||
|
}
|
||||||
|
printf(OUTPUT "%#02x, ", unpack("C", $data));
|
||||||
|
$i++;
|
||||||
|
if($i == 10) {
|
||||||
|
print(OUTPUT "\n");
|
||||||
|
$i = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
print(OUTPUT "};\n\n");
|
||||||
|
close(FILE);
|
||||||
|
push(@fvars, $fvar);
|
||||||
|
push(@files, $file);
|
||||||
|
}
|
||||||
|
|
||||||
|
for($i = 0; $i < @fvars; $i++) {
|
||||||
|
$file = $files[$i];
|
||||||
|
$fvar = $fvars[$i];
|
||||||
|
|
||||||
|
if($i == 0) {
|
||||||
|
$prevfile = "NULL";
|
||||||
|
} else {
|
||||||
|
$prevfile = "file" . $fvars[$i - 1];
|
||||||
|
}
|
||||||
|
print(OUTPUT "const struct fsdata_file file".$fvar."[] = {{$prevfile, data$fvar, ");
|
||||||
|
print(OUTPUT "data$fvar + ". (length($file) + 1) .", ");
|
||||||
|
print(OUTPUT "sizeof(data$fvar) - ". (length($file) + 1) ."}};\n\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
print(OUTPUT "#define FS_ROOT file$fvars[$i - 1]\n\n");
|
||||||
|
print(OUTPUT "#define FS_NUMFILES $i\n");
|
@ -0,0 +1,610 @@
|
|||||||
|
/**
|
||||||
|
* makefsdata: Converts a directory structure for use with the lwIP httpd.
|
||||||
|
*
|
||||||
|
* This file is part of the lwIP TCP/IP stack.
|
||||||
|
*
|
||||||
|
* Author: Jim Pettinato
|
||||||
|
* Simon Goldschmidt
|
||||||
|
*
|
||||||
|
* @todo:
|
||||||
|
* - take TCP_MSS, LWIP_TCP_TIMESTAMPS and
|
||||||
|
* PAYLOAD_ALIGN_TYPE/PAYLOAD_ALIGNMENT as arguments
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#ifdef WIN32
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include "windows.h"
|
||||||
|
#else
|
||||||
|
#include <dir.h>
|
||||||
|
#endif
|
||||||
|
#include <dos.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/* Compatibility defines Win32 vs. DOS */
|
||||||
|
#ifdef WIN32
|
||||||
|
|
||||||
|
#define FIND_T WIN32_FIND_DATAA
|
||||||
|
#define FIND_T_FILENAME(fInfo) (fInfo.cFileName)
|
||||||
|
#define FIND_T_IS_DIR(fInfo) ((fInfo.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0)
|
||||||
|
#define FIND_T_IS_FILE(fInfo) ((fInfo.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) == 0)
|
||||||
|
#define FIND_RET_T HANDLE
|
||||||
|
#define FINDFIRST_FILE(path, result) FindFirstFileA(path, result)
|
||||||
|
#define FINDFIRST_DIR(path, result) FindFirstFileA(path, result)
|
||||||
|
#define FINDNEXT(ff_res, result) FindNextFileA(ff_res, result)
|
||||||
|
#define FINDFIRST_SUCCEEDED(ret) (ret != INVALID_HANDLE_VALUE)
|
||||||
|
#define FINDNEXT_SUCCEEDED(ret) (ret == TRUE)
|
||||||
|
|
||||||
|
#define GETCWD(path, len) GetCurrentDirectoryA(len, path)
|
||||||
|
#define CHDIR(path) SetCurrentDirectoryA(path)
|
||||||
|
|
||||||
|
#define NEWLINE "\r\n"
|
||||||
|
#define NEWLINE_LEN 2
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#define FIND_T struct fflbk
|
||||||
|
#define FIND_T_FILENAME(fInfo) (fInfo.ff_name)
|
||||||
|
#define FIND_T_IS_DIR(fInfo) ((fInfo.ff_attrib & FA_DIREC) == FA_DIREC)
|
||||||
|
#define FIND_T_IS_FILE(fInfo) (1)
|
||||||
|
#define FIND_RET_T int
|
||||||
|
#define FINDFIRST_FILE(path, result) findfirst(path, result, FA_ARCH)
|
||||||
|
#define FINDFIRST_DIR(path, result) findfirst(path, result, FA_DIREC)
|
||||||
|
#define FINDNEXT(ff_res, result) FindNextFileA(ff_res, result)
|
||||||
|
#define FINDFIRST_SUCCEEDED(ret) (ret == 0)
|
||||||
|
#define FINDNEXT_SUCCEEDED(ret) (ret == 0)
|
||||||
|
|
||||||
|
#define GETCWD(path, len) getcwd(path, len)
|
||||||
|
#define CHDIR(path) chdir(path)
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* define this to get the header variables we use to build HTTP headers */
|
||||||
|
#define LWIP_HTTPD_DYNAMIC_HEADERS 1
|
||||||
|
#include "../httpd_structs.h"
|
||||||
|
|
||||||
|
#include "../../../lwip-1.4.0/src/core/ipv4/inet_chksum.c"
|
||||||
|
#include "../../../lwip-1.4.0/src/core/def.c"
|
||||||
|
|
||||||
|
/** (Your server name here) */
|
||||||
|
const char *serverID = "Server: "HTTPD_SERVER_AGENT"\r\n";
|
||||||
|
|
||||||
|
/* change this to suit your MEM_ALIGNMENT */
|
||||||
|
#define PAYLOAD_ALIGNMENT 4
|
||||||
|
/* set this to 0 to prevent aligning payload */
|
||||||
|
#define ALIGN_PAYLOAD 1
|
||||||
|
/* define this to a type that has the required alignment */
|
||||||
|
#define PAYLOAD_ALIGN_TYPE "unsigned int"
|
||||||
|
static int payload_alingment_dummy_counter = 0;
|
||||||
|
|
||||||
|
#define HEX_BYTES_PER_LINE 16
|
||||||
|
|
||||||
|
#define MAX_PATH_LEN 256
|
||||||
|
|
||||||
|
#define COPY_BUFSIZE 10240
|
||||||
|
|
||||||
|
int process_sub(FILE *data_file, FILE *struct_file);
|
||||||
|
int process_file(FILE *data_file, FILE *struct_file, const char *filename);
|
||||||
|
int file_write_http_header(FILE *data_file, const char *filename, int file_size,
|
||||||
|
u16_t *http_hdr_len, u16_t *http_hdr_chksum);
|
||||||
|
int file_put_ascii(FILE *file, const char *ascii_string, int len, int *i);
|
||||||
|
int s_put_ascii(char *buf, const char *ascii_string, int len, int *i);
|
||||||
|
void concat_files(const char *file1, const char *file2, const char *targetfile);
|
||||||
|
|
||||||
|
static unsigned char file_buffer_raw[COPY_BUFSIZE];
|
||||||
|
/* 5 bytes per char + 3 bytes per line */
|
||||||
|
static char file_buffer_c[COPY_BUFSIZE * 5 + ((COPY_BUFSIZE / HEX_BYTES_PER_LINE) * 3)];
|
||||||
|
|
||||||
|
char curSubdir[MAX_PATH_LEN];
|
||||||
|
char lastFileVar[MAX_PATH_LEN];
|
||||||
|
char hdr_buf[4096];
|
||||||
|
|
||||||
|
unsigned char processSubs = 1;
|
||||||
|
unsigned char includeHttpHeader = 1;
|
||||||
|
unsigned char useHttp11 = 0;
|
||||||
|
unsigned char precalcChksum = 0;
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
FIND_T fInfo;
|
||||||
|
FIND_RET_T fret;
|
||||||
|
char path[MAX_PATH_LEN];
|
||||||
|
char appPath[MAX_PATH_LEN];
|
||||||
|
FILE *data_file;
|
||||||
|
FILE *struct_file;
|
||||||
|
int filesProcessed;
|
||||||
|
int i;
|
||||||
|
char targetfile[MAX_PATH_LEN];
|
||||||
|
strcpy(targetfile, "fsdata.c");
|
||||||
|
|
||||||
|
memset(path, 0, sizeof(path));
|
||||||
|
memset(appPath, 0, sizeof(appPath));
|
||||||
|
|
||||||
|
printf(NEWLINE " makefsdata - HTML to C source converter" NEWLINE);
|
||||||
|
printf(" by Jim Pettinato - circa 2003 " NEWLINE);
|
||||||
|
printf(" extended by Simon Goldschmidt - 2009 " NEWLINE NEWLINE);
|
||||||
|
|
||||||
|
strcpy(path, "fs");
|
||||||
|
for(i = 1; i < argc; i++) {
|
||||||
|
if (argv[i][0] == '-') {
|
||||||
|
if (strstr(argv[i], "-s")) {
|
||||||
|
processSubs = 0;
|
||||||
|
} else if (strstr(argv[i], "-e")) {
|
||||||
|
includeHttpHeader = 0;
|
||||||
|
} else if (strstr(argv[i], "-11")) {
|
||||||
|
useHttp11 = 1;
|
||||||
|
} else if (strstr(argv[i], "-c")) {
|
||||||
|
precalcChksum = 1;
|
||||||
|
} else if((argv[i][1] == 'f') && (argv[i][2] == ':')) {
|
||||||
|
strcpy(targetfile, &argv[i][3]);
|
||||||
|
printf("Writing to file \"%s\"\n", targetfile);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
strcpy(path, argv[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* if command line param or subdir named 'fs' not found spout usage verbiage */
|
||||||
|
fret = FINDFIRST_DIR(path, &fInfo);
|
||||||
|
if (!FINDFIRST_SUCCEEDED(fret)) {
|
||||||
|
/* if no subdir named 'fs' (or the one which was given) exists, spout usage verbiage */
|
||||||
|
printf(" Failed to open directory \"%s\"." NEWLINE NEWLINE, path);
|
||||||
|
printf(" Usage: htmlgen [targetdir] [-s] [-i] [-f:<filename>]" NEWLINE NEWLINE);
|
||||||
|
printf(" targetdir: relative or absolute path to files to convert" NEWLINE);
|
||||||
|
printf(" switch -s: toggle processing of subdirectories (default is on)" NEWLINE);
|
||||||
|
printf(" switch -e: exclude HTTP header from file (header is created at runtime, default is off)" NEWLINE);
|
||||||
|
printf(" switch -11: include HTTP 1.1 header (1.0 is default)" NEWLINE);
|
||||||
|
printf(" switch -c: precalculate checksums for all pages (default is off)" NEWLINE);
|
||||||
|
printf(" switch -f: target filename (default is \"fsdata.c\")" NEWLINE);
|
||||||
|
printf(" if targetdir not specified, htmlgen will attempt to" NEWLINE);
|
||||||
|
printf(" process files in subdirectory 'fs'" NEWLINE);
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("HTTP %sheader will %s statically included." NEWLINE,
|
||||||
|
(includeHttpHeader ? (useHttp11 ? "1.1 " : "1.0 ") : ""),
|
||||||
|
(includeHttpHeader ? "be" : "not be"));
|
||||||
|
|
||||||
|
sprintf(curSubdir, ""); /* start off in web page's root directory - relative paths */
|
||||||
|
printf(" Processing all files in directory %s", path);
|
||||||
|
if (processSubs) {
|
||||||
|
printf(" and subdirectories..." NEWLINE NEWLINE);
|
||||||
|
} else {
|
||||||
|
printf("..." NEWLINE NEWLINE);
|
||||||
|
}
|
||||||
|
|
||||||
|
GETCWD(appPath, MAX_PATH_LEN);
|
||||||
|
data_file = fopen("fsdata.tmp", "wb");
|
||||||
|
if (data_file == NULL) {
|
||||||
|
printf("Failed to create file \"fsdata.tmp\"\n");
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
struct_file = fopen("fshdr.tmp", "wb");
|
||||||
|
if (struct_file == NULL) {
|
||||||
|
printf("Failed to create file \"fshdr.tmp\"\n");
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
CHDIR(path);
|
||||||
|
|
||||||
|
fprintf(data_file, "#include \"fs.h\"" NEWLINE);
|
||||||
|
fprintf(data_file, "#include \"lwip/def.h\"" NEWLINE);
|
||||||
|
fprintf(data_file, "#include \"fsdata.h\"" NEWLINE NEWLINE NEWLINE);
|
||||||
|
|
||||||
|
fprintf(data_file, "#define file_NULL (struct fsdata_file *) NULL" NEWLINE NEWLINE NEWLINE);
|
||||||
|
|
||||||
|
sprintf(lastFileVar, "NULL");
|
||||||
|
|
||||||
|
filesProcessed = process_sub(data_file, struct_file);
|
||||||
|
|
||||||
|
/* data_file now contains all of the raw data.. now append linked list of
|
||||||
|
* file header structs to allow embedded app to search for a file name */
|
||||||
|
fprintf(data_file, NEWLINE NEWLINE);
|
||||||
|
fprintf(struct_file, "#define FS_ROOT file_%s" NEWLINE, lastFileVar);
|
||||||
|
fprintf(struct_file, "#define FS_NUMFILES %d" NEWLINE NEWLINE, filesProcessed);
|
||||||
|
|
||||||
|
fclose(data_file);
|
||||||
|
fclose(struct_file);
|
||||||
|
|
||||||
|
CHDIR(appPath);
|
||||||
|
/* append struct_file to data_file */
|
||||||
|
printf(NEWLINE "Creating target file..." NEWLINE NEWLINE);
|
||||||
|
concat_files("fsdata.tmp", "fshdr.tmp", targetfile);
|
||||||
|
|
||||||
|
/* if succeeded, delete the temporary files */
|
||||||
|
remove("fsdata.tmp");
|
||||||
|
remove("fshdr.tmp");
|
||||||
|
|
||||||
|
printf(NEWLINE "Processed %d files - done." NEWLINE NEWLINE, filesProcessed);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void copy_file(const char *filename_in, FILE *fout)
|
||||||
|
{
|
||||||
|
FILE *fin;
|
||||||
|
size_t len;
|
||||||
|
fin = fopen(filename_in, "rb");
|
||||||
|
if (fin == NULL) {
|
||||||
|
printf("Failed to open file \"%s\"\n", filename_in);
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
while((len = fread(file_buffer_raw, 1, COPY_BUFSIZE, fin)) > 0)
|
||||||
|
{
|
||||||
|
fwrite(file_buffer_raw, 1, len, fout);
|
||||||
|
}
|
||||||
|
fclose(fin);
|
||||||
|
}
|
||||||
|
|
||||||
|
void concat_files(const char *file1, const char *file2, const char *targetfile)
|
||||||
|
{
|
||||||
|
FILE *fout;
|
||||||
|
fout = fopen(targetfile, "wb");
|
||||||
|
if (fout == NULL) {
|
||||||
|
printf("Failed to open file \"%s\"\n", targetfile);
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
copy_file(file1, fout);
|
||||||
|
copy_file(file2, fout);
|
||||||
|
fclose(fout);
|
||||||
|
}
|
||||||
|
|
||||||
|
int process_sub(FILE *data_file, FILE *struct_file)
|
||||||
|
{
|
||||||
|
FIND_T fInfo;
|
||||||
|
FIND_RET_T fret;
|
||||||
|
int filesProcessed = 0;
|
||||||
|
char oldSubdir[MAX_PATH_LEN];
|
||||||
|
|
||||||
|
if (processSubs) {
|
||||||
|
/* process subs recursively */
|
||||||
|
strcpy(oldSubdir, curSubdir);
|
||||||
|
fret = FINDFIRST_DIR("*", &fInfo);
|
||||||
|
if (FINDFIRST_SUCCEEDED(fret)) {
|
||||||
|
do {
|
||||||
|
const char *curName = FIND_T_FILENAME(fInfo);
|
||||||
|
if (curName == NULL) continue;
|
||||||
|
if (curName[0] == '.') continue;
|
||||||
|
if (strcmp(curName, "CVS") == 0) continue;
|
||||||
|
if (!FIND_T_IS_DIR(fInfo)) continue;
|
||||||
|
CHDIR(curName);
|
||||||
|
strcat(curSubdir, "/");
|
||||||
|
strcat(curSubdir, curName);
|
||||||
|
printf(NEWLINE "processing subdirectory %s/..." NEWLINE, curSubdir);
|
||||||
|
filesProcessed += process_sub(data_file, struct_file);
|
||||||
|
CHDIR("..");
|
||||||
|
strcpy(curSubdir, oldSubdir);
|
||||||
|
} while (FINDNEXT_SUCCEEDED(FINDNEXT(fret, &fInfo)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fret = FINDFIRST_FILE("*.*", &fInfo);
|
||||||
|
if (FINDFIRST_SUCCEEDED(fret)) {
|
||||||
|
/* at least one file in directory */
|
||||||
|
do {
|
||||||
|
if (FIND_T_IS_FILE(fInfo)) {
|
||||||
|
const char *curName = FIND_T_FILENAME(fInfo);
|
||||||
|
printf("processing %s/%s..." NEWLINE, curSubdir, curName);
|
||||||
|
if (process_file(data_file, struct_file, curName) < 0) {
|
||||||
|
printf(NEWLINE "Error... aborting" NEWLINE);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
filesProcessed++;
|
||||||
|
}
|
||||||
|
} while (FINDNEXT_SUCCEEDED(FINDNEXT(fret, &fInfo)));
|
||||||
|
}
|
||||||
|
return filesProcessed;
|
||||||
|
}
|
||||||
|
|
||||||
|
int get_file_size(const char* filename)
|
||||||
|
{
|
||||||
|
FILE *inFile;
|
||||||
|
int file_size = -1;
|
||||||
|
inFile = fopen(filename, "rb");
|
||||||
|
if (inFile == NULL) {
|
||||||
|
printf("Failed to open file \"%s\"\n", filename);
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
fseek(inFile, 0, SEEK_END);
|
||||||
|
file_size = ftell(inFile);
|
||||||
|
fclose(inFile);
|
||||||
|
return file_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
void process_file_data(const char *filename, FILE *data_file)
|
||||||
|
{
|
||||||
|
FILE *source_file;
|
||||||
|
size_t len, written, i, src_off=0;
|
||||||
|
|
||||||
|
source_file = fopen(filename, "rb");
|
||||||
|
|
||||||
|
do {
|
||||||
|
size_t off = 0;
|
||||||
|
len = fread(file_buffer_raw, 1, COPY_BUFSIZE, source_file);
|
||||||
|
if (len > 0) {
|
||||||
|
for (i = 0; i < len; i++) {
|
||||||
|
sprintf(&file_buffer_c[off], "0x%02.2x,", file_buffer_raw[i]);
|
||||||
|
off += 5;
|
||||||
|
if ((++src_off % HEX_BYTES_PER_LINE) == 0) {
|
||||||
|
memcpy(&file_buffer_c[off], NEWLINE, NEWLINE_LEN);
|
||||||
|
off += NEWLINE_LEN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
written = fwrite(file_buffer_c, 1, off, data_file);
|
||||||
|
}
|
||||||
|
} while(len > 0);
|
||||||
|
fclose(source_file);
|
||||||
|
}
|
||||||
|
|
||||||
|
int write_checksums(FILE *struct_file, const char *filename, const char *varname,
|
||||||
|
u16_t hdr_len, u16_t hdr_chksum)
|
||||||
|
{
|
||||||
|
int chunk_size = TCP_MSS;
|
||||||
|
int offset;
|
||||||
|
size_t len;
|
||||||
|
int i = 0;
|
||||||
|
FILE *f;
|
||||||
|
#if LWIP_TCP_TIMESTAMPS
|
||||||
|
/* when timestamps are used, usable space is 12 bytes less per segment */
|
||||||
|
chunk_size -= 12;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
fprintf(struct_file, "#if HTTPD_PRECALCULATED_CHECKSUM" NEWLINE);
|
||||||
|
fprintf(struct_file, "const struct fsdata_chksum chksums_%s[] = {" NEWLINE, varname);
|
||||||
|
|
||||||
|
memset(file_buffer_raw, 0xab, sizeof(file_buffer_raw));
|
||||||
|
f = fopen(filename, "rb");
|
||||||
|
if (f == INVALID_HANDLE_VALUE) {
|
||||||
|
printf("Failed to open file \"%s\"\n", filename);
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
if (hdr_len > 0) {
|
||||||
|
/* add checksum for HTTP header */
|
||||||
|
fprintf(struct_file, "{%d, 0x%04x, %d}," NEWLINE, 0, hdr_chksum, hdr_len);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
for (offset = hdr_len; ; offset += len) {
|
||||||
|
unsigned short chksum;
|
||||||
|
len = fread(file_buffer_raw, 1, chunk_size, f);
|
||||||
|
if (len == 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
chksum = ~inet_chksum(file_buffer_raw, (u16_t)len);
|
||||||
|
/* add checksum for data */
|
||||||
|
fprintf(struct_file, "{%d, 0x%04x, %d}," NEWLINE, offset, chksum, len);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
fclose(f);
|
||||||
|
fprintf(struct_file, "};" NEWLINE);
|
||||||
|
fprintf(struct_file, "#endif /* HTTPD_PRECALCULATED_CHECKSUM */" NEWLINE);
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
int process_file(FILE *data_file, FILE *struct_file, const char *filename)
|
||||||
|
{
|
||||||
|
char *pch;
|
||||||
|
char varname[MAX_PATH_LEN];
|
||||||
|
int i = 0;
|
||||||
|
char qualifiedName[MAX_PATH_LEN];
|
||||||
|
int file_size;
|
||||||
|
u16_t http_hdr_chksum = 0;
|
||||||
|
u16_t http_hdr_len = 0;
|
||||||
|
int chksum_count = 0;
|
||||||
|
|
||||||
|
/* create qualified name (TODO: prepend slash or not?) */
|
||||||
|
sprintf(qualifiedName,"%s/%s", curSubdir, filename);
|
||||||
|
/* create C variable name */
|
||||||
|
strcpy(varname, qualifiedName);
|
||||||
|
/* convert slashes & dots to underscores */
|
||||||
|
while ((pch = strpbrk(varname, "./\\")) != NULL) {
|
||||||
|
*pch = '_';
|
||||||
|
}
|
||||||
|
#if ALIGN_PAYLOAD
|
||||||
|
/* to force even alignment of array */
|
||||||
|
fprintf(data_file, "static const " PAYLOAD_ALIGN_TYPE " dummy_align_%s = %d;" NEWLINE, varname, payload_alingment_dummy_counter++);
|
||||||
|
#endif /* ALIGN_PAYLOAD */
|
||||||
|
fprintf(data_file, "static const unsigned char data_%s[] = {" NEWLINE, varname);
|
||||||
|
/* encode source file name (used by file system, not returned to browser) */
|
||||||
|
fprintf(data_file, "/* %s (%d chars) */" NEWLINE, qualifiedName, strlen(qualifiedName)+1);
|
||||||
|
file_put_ascii(data_file, qualifiedName, strlen(qualifiedName)+1, &i);
|
||||||
|
#if ALIGN_PAYLOAD
|
||||||
|
/* pad to even number of bytes to assure payload is on aligned boundary */
|
||||||
|
while(i % PAYLOAD_ALIGNMENT != 0) {
|
||||||
|
fprintf(data_file, "0x%02.2x,", 0);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
#endif /* ALIGN_PAYLOAD */
|
||||||
|
fprintf(data_file, NEWLINE);
|
||||||
|
|
||||||
|
file_size = get_file_size(filename);
|
||||||
|
if (includeHttpHeader) {
|
||||||
|
file_write_http_header(data_file, filename, file_size, &http_hdr_len, &http_hdr_chksum);
|
||||||
|
}
|
||||||
|
if (precalcChksum) {
|
||||||
|
chksum_count = write_checksums(struct_file, filename, varname, http_hdr_len, http_hdr_chksum);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* build declaration of struct fsdata_file in temp file */
|
||||||
|
fprintf(struct_file, "const struct fsdata_file file_%s[] = { {" NEWLINE, varname);
|
||||||
|
fprintf(struct_file, "file_%s," NEWLINE, lastFileVar);
|
||||||
|
fprintf(struct_file, "data_%s," NEWLINE, varname);
|
||||||
|
fprintf(struct_file, "data_%s + %d," NEWLINE, varname, i);
|
||||||
|
fprintf(struct_file, "sizeof(data_%s) - %d," NEWLINE, varname, i);
|
||||||
|
fprintf(struct_file, "%d," NEWLINE, includeHttpHeader);
|
||||||
|
if (precalcChksum) {
|
||||||
|
fprintf(struct_file, "#if HTTPD_PRECALCULATED_CHECKSUM" NEWLINE);
|
||||||
|
fprintf(struct_file, "%d, chksums_%s," NEWLINE, chksum_count, varname);
|
||||||
|
fprintf(struct_file, "#endif /* HTTPD_PRECALCULATED_CHECKSUM */" NEWLINE);
|
||||||
|
}
|
||||||
|
fprintf(struct_file, "}};" NEWLINE NEWLINE);
|
||||||
|
strcpy(lastFileVar, varname);
|
||||||
|
|
||||||
|
/* write actual file contents */
|
||||||
|
i = 0;
|
||||||
|
fprintf(data_file, NEWLINE "/* raw file data (%d bytes) */" NEWLINE, file_size);
|
||||||
|
process_file_data(filename, data_file);
|
||||||
|
fprintf(data_file, "};" NEWLINE NEWLINE);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int file_write_http_header(FILE *data_file, const char *filename, int file_size,
|
||||||
|
u16_t *http_hdr_len, u16_t *http_hdr_chksum)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
int response_type = HTTP_HDR_OK;
|
||||||
|
int file_type = HTTP_HDR_DEFAULT_TYPE;
|
||||||
|
const char *cur_string;
|
||||||
|
size_t cur_len;
|
||||||
|
int written = 0;
|
||||||
|
size_t hdr_len = 0;
|
||||||
|
u16_t acc;
|
||||||
|
const char *file_ext;
|
||||||
|
int j;
|
||||||
|
|
||||||
|
memset(hdr_buf, 0, sizeof(hdr_buf));
|
||||||
|
|
||||||
|
if (useHttp11) {
|
||||||
|
response_type = HTTP_HDR_OK_11;
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(data_file, NEWLINE "/* HTTP header */");
|
||||||
|
if (strstr(filename, "404") == filename) {
|
||||||
|
response_type = HTTP_HDR_NOT_FOUND;
|
||||||
|
if (useHttp11) {
|
||||||
|
response_type = HTTP_HDR_NOT_FOUND_11;
|
||||||
|
}
|
||||||
|
} else if (strstr(filename, "400") == filename) {
|
||||||
|
response_type = HTTP_HDR_BAD_REQUEST;
|
||||||
|
if (useHttp11) {
|
||||||
|
response_type = HTTP_HDR_BAD_REQUEST_11;
|
||||||
|
}
|
||||||
|
} else if (strstr(filename, "501") == filename) {
|
||||||
|
response_type = HTTP_HDR_NOT_IMPL;
|
||||||
|
if (useHttp11) {
|
||||||
|
response_type = HTTP_HDR_NOT_IMPL_11;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cur_string = g_psHTTPHeaderStrings[response_type];
|
||||||
|
cur_len = strlen(cur_string);
|
||||||
|
fprintf(data_file, NEWLINE "/* \"%s\" (%d bytes) */" NEWLINE, cur_string, cur_len);
|
||||||
|
written += file_put_ascii(data_file, cur_string, cur_len, &i);
|
||||||
|
i = 0;
|
||||||
|
if (precalcChksum) {
|
||||||
|
memcpy(&hdr_buf[hdr_len], cur_string, cur_len);
|
||||||
|
hdr_len += cur_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
cur_string = serverID;
|
||||||
|
cur_len = strlen(cur_string);
|
||||||
|
fprintf(data_file, NEWLINE "/* \"%s\" (%d bytes) */" NEWLINE, cur_string, cur_len);
|
||||||
|
written += file_put_ascii(data_file, cur_string, cur_len, &i);
|
||||||
|
i = 0;
|
||||||
|
if (precalcChksum) {
|
||||||
|
memcpy(&hdr_buf[hdr_len], cur_string, cur_len);
|
||||||
|
hdr_len += cur_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
file_ext = filename;
|
||||||
|
while(strstr(file_ext, ".") != NULL) {
|
||||||
|
file_ext = strstr(file_ext, ".");
|
||||||
|
file_ext++;
|
||||||
|
}
|
||||||
|
if((file_ext == NULL) || (*file_ext == 0)) {
|
||||||
|
printf("failed to get extension for file \"%s\", using default.\n", filename);
|
||||||
|
} else {
|
||||||
|
for(j = 0; j < NUM_HTTP_HEADERS; j++) {
|
||||||
|
if(!strcmp(file_ext, g_psHTTPHeaders[j].extension)) {
|
||||||
|
file_type = g_psHTTPHeaders[j].headerIndex;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (j >= NUM_HTTP_HEADERS) {
|
||||||
|
printf("failed to get file type for extension \"%s\", using default.\n", file_ext);
|
||||||
|
file_type = HTTP_HDR_DEFAULT_TYPE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (useHttp11) {
|
||||||
|
char intbuf[MAX_PATH_LEN];
|
||||||
|
memset(intbuf, 0, sizeof(intbuf));
|
||||||
|
|
||||||
|
cur_string = g_psHTTPHeaderStrings[HTTP_HDR_CONTENT_LENGTH];
|
||||||
|
cur_len = strlen(cur_string);
|
||||||
|
fprintf(data_file, NEWLINE "/* \"%s%d\r\n\" (%d+ bytes) */" NEWLINE, cur_string, file_size, cur_len+2);
|
||||||
|
written += file_put_ascii(data_file, cur_string, cur_len, &i);
|
||||||
|
if (precalcChksum) {
|
||||||
|
memcpy(&hdr_buf[hdr_len], cur_string, cur_len);
|
||||||
|
hdr_len += cur_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
_itoa(file_size, intbuf, 10);
|
||||||
|
strcat(intbuf, "\r\n");
|
||||||
|
cur_len = strlen(intbuf);
|
||||||
|
written += file_put_ascii(data_file, intbuf, cur_len, &i);
|
||||||
|
i = 0;
|
||||||
|
if (precalcChksum) {
|
||||||
|
memcpy(&hdr_buf[hdr_len], intbuf, cur_len);
|
||||||
|
hdr_len += cur_len;
|
||||||
|
}
|
||||||
|
|
||||||
|
cur_string = g_psHTTPHeaderStrings[HTTP_HDR_CONN_CLOSE];
|
||||||
|
cur_len = strlen(cur_string);
|
||||||
|
fprintf(data_file, NEWLINE "/* \"%s\" (%d bytes) */" NEWLINE, cur_string, cur_len);
|
||||||
|
written += file_put_ascii(data_file, cur_string, cur_len, &i);
|
||||||
|
i = 0;
|
||||||
|
if (precalcChksum) {
|
||||||
|
memcpy(&hdr_buf[hdr_len], cur_string, cur_len);
|
||||||
|
hdr_len += cur_len;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
cur_string = g_psHTTPHeaderStrings[file_type];
|
||||||
|
cur_len = strlen(cur_string);
|
||||||
|
fprintf(data_file, NEWLINE "/* \"%s\" (%d bytes) */" NEWLINE, cur_string, cur_len);
|
||||||
|
written += file_put_ascii(data_file, cur_string, cur_len, &i);
|
||||||
|
i = 0;
|
||||||
|
if (precalcChksum) {
|
||||||
|
memcpy(&hdr_buf[hdr_len], cur_string, cur_len);
|
||||||
|
hdr_len += cur_len;
|
||||||
|
|
||||||
|
LWIP_ASSERT("hdr_len <= 0xffff", hdr_len <= 0xffff);
|
||||||
|
LWIP_ASSERT("strlen(hdr_buf) == hdr_len", strlen(hdr_buf) == hdr_len);
|
||||||
|
acc = ~inet_chksum(hdr_buf, (u16_t)hdr_len);
|
||||||
|
*http_hdr_len = (u16_t)hdr_len;
|
||||||
|
*http_hdr_chksum = acc;
|
||||||
|
}
|
||||||
|
|
||||||
|
return written;
|
||||||
|
}
|
||||||
|
|
||||||
|
int file_put_ascii(FILE *file, const char* ascii_string, int len, int *i)
|
||||||
|
{
|
||||||
|
int x;
|
||||||
|
for(x = 0; x < len; x++) {
|
||||||
|
unsigned char cur = ascii_string[x];
|
||||||
|
fprintf(file, "0x%02.2x,", cur);
|
||||||
|
if ((++(*i) % HEX_BYTES_PER_LINE) == 0) {
|
||||||
|
fprintf(file, NEWLINE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
||||||
|
|
||||||
|
int s_put_ascii(char *buf, const char *ascii_string, int len, int *i)
|
||||||
|
{
|
||||||
|
int x;
|
||||||
|
int idx = 0;
|
||||||
|
for(x = 0; x < len; x++) {
|
||||||
|
unsigned char cur = ascii_string[x];
|
||||||
|
sprintf(&buf[idx], "0x%02.2x,", cur);
|
||||||
|
idx += 5;
|
||||||
|
if ((++(*i) % HEX_BYTES_PER_LINE) == 0) {
|
||||||
|
sprintf(&buf[idx], NEWLINE);
|
||||||
|
idx += NEWLINE_LEN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return len;
|
||||||
|
}
|
Binary file not shown.
@ -0,0 +1,8 @@
|
|||||||
|
// stdafx.cpp : source file that includes just the standard includes
|
||||||
|
// MakeFSData_proj.pch will be the pre-compiled header
|
||||||
|
// stdafx.obj will contain the pre-compiled type information
|
||||||
|
|
||||||
|
#include "stdafx.h"
|
||||||
|
|
||||||
|
// TODO: reference any additional headers you need in STDAFX.H
|
||||||
|
// and not in this file
|
@ -0,0 +1,15 @@
|
|||||||
|
// stdafx.h : include file for standard system include files,
|
||||||
|
// or project specific include files that are used frequently, but
|
||||||
|
// are changed infrequently
|
||||||
|
//
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "targetver.h"
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <tchar.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// TODO: reference additional headers your program requires here
|
@ -0,0 +1,8 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
// Including SDKDDKVer.h defines the highest available Windows platform.
|
||||||
|
|
||||||
|
// If you wish to build your application for a previous Windows platform, include WinSDKVer.h and
|
||||||
|
// set the _WIN32_WINNT macro to the platform you wish to support before including SDKDDKVer.h.
|
||||||
|
|
||||||
|
#include <SDKDDKVer.h>
|
@ -0,0 +1,265 @@
|
|||||||
|
/*
|
||||||
|
FreeRTOS V7.0.2 - Copyright (C) 2011 Real Time Engineers Ltd.
|
||||||
|
|
||||||
|
|
||||||
|
***************************************************************************
|
||||||
|
* *
|
||||||
|
* FreeRTOS tutorial books are available in pdf and paperback. *
|
||||||
|
* Complete, revised, and edited pdf reference manuals are also *
|
||||||
|
* available. *
|
||||||
|
* *
|
||||||
|
* Purchasing FreeRTOS documentation will not only help you, by *
|
||||||
|
* ensuring you get running as quickly as possible and with an *
|
||||||
|
* in-depth knowledge of how to use FreeRTOS, it will also help *
|
||||||
|
* the FreeRTOS project to continue with its mission of providing *
|
||||||
|
* professional grade, cross platform, de facto standard solutions *
|
||||||
|
* for microcontrollers - completely free of charge! *
|
||||||
|
* *
|
||||||
|
* >>> See http://www.FreeRTOS.org/Documentation for details. <<< *
|
||||||
|
* *
|
||||||
|
* Thank you for using FreeRTOS, and thank you for your support! *
|
||||||
|
* *
|
||||||
|
***************************************************************************
|
||||||
|
|
||||||
|
|
||||||
|
This file is part of the FreeRTOS distribution.
|
||||||
|
|
||||||
|
FreeRTOS is free software; you can redistribute it and/or modify it under
|
||||||
|
the terms of the GNU General Public License (version 2) as published by the
|
||||||
|
Free Software Foundation AND MODIFIED BY the FreeRTOS exception.
|
||||||
|
>>>NOTE<<< The modification to the GPL is included to allow you to
|
||||||
|
distribute a combined work that includes FreeRTOS without being obliged to
|
||||||
|
provide the source code for proprietary components outside of the FreeRTOS
|
||||||
|
kernel. FreeRTOS is distributed in the hope that it will be useful, but
|
||||||
|
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
more details. You should have received a copy of the GNU General Public
|
||||||
|
License and the FreeRTOS license exception along with FreeRTOS; if not it
|
||||||
|
can be viewed here: http://www.freertos.org/a00114.html and also obtained
|
||||||
|
by writing to Richard Barry, contact details for whom are available on the
|
||||||
|
FreeRTOS WEB site.
|
||||||
|
|
||||||
|
1 tab == 4 spaces!
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org - Documentation, latest information, license and
|
||||||
|
contact details.
|
||||||
|
|
||||||
|
http://www.SafeRTOS.com - A version that is certified for use in safety
|
||||||
|
critical systems.
|
||||||
|
|
||||||
|
http://www.OpenRTOS.com - Commercial support, development, porting,
|
||||||
|
licensing and training services.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Standard includes. */
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/* FreeRTOS includes. */
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "semphr.h"
|
||||||
|
|
||||||
|
/* lwIP core includes */
|
||||||
|
#include "lwip/opt.h"
|
||||||
|
#include "lwip/tcpip.h"
|
||||||
|
#include "lwip/inet.h"
|
||||||
|
#include "lwip/dhcp.h"
|
||||||
|
|
||||||
|
/* applications includes */
|
||||||
|
#include "apps/httpserver_raw_from_lwIP_download/httpd.h"
|
||||||
|
|
||||||
|
/* include the port-dependent configuration */
|
||||||
|
#include "lwipcfg_msvc.h"
|
||||||
|
|
||||||
|
/* Dimensions the cTxBuffer array - which is itself used to hold replies from
|
||||||
|
command line commands. cTxBuffer is a shared buffer, so protected by the
|
||||||
|
xTxBufferMutex mutex. */
|
||||||
|
#define lwipappsTX_BUFFER_SIZE 1024
|
||||||
|
|
||||||
|
/* The maximum time to block waiting to obtain the xTxBufferMutex to become
|
||||||
|
available. */
|
||||||
|
#define lwipappsMAX_TIME_TO_WAIT_FOR_TX_BUFFER_MS ( 100 / portTICK_RATE_MS )
|
||||||
|
|
||||||
|
/* Definitions of the various SSI callback functions within the pccSSITags
|
||||||
|
array. If pccSSITags is updated, then these definitions must also be updated. */
|
||||||
|
#define ssiTASK_STATS_INDEX 0
|
||||||
|
#define ssiRUN_TIME_STATS_INDEX 1
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The function that implements the lwIP based sockets command interpreter
|
||||||
|
* server.
|
||||||
|
*/
|
||||||
|
extern void vBasicSocketsCommandInterpreterTask( void *pvParameters );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The SSI handler callback function passed to lwIP.
|
||||||
|
*/
|
||||||
|
static unsigned short uslwIPAppsSSIHandler( int iIndex, char *pcBuffer, int iBufferLength );
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* The SSI strings that are embedded in the served html files. If this array
|
||||||
|
is changed, then the index position defined by the #defines such as
|
||||||
|
ssiTASK_STATS_INDEX above must also be updated. */
|
||||||
|
static const char *pccSSITags[] =
|
||||||
|
{
|
||||||
|
"rtos_stats",
|
||||||
|
"run_stats"
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Semaphore used to guard the Tx buffer. */
|
||||||
|
static xSemaphoreHandle xTxBufferMutex = NULL;
|
||||||
|
|
||||||
|
/* The Tx buffer itself. This is used to hold the text generated by the
|
||||||
|
execution of command line commands, and (hopefully) the execution of
|
||||||
|
server side include callbacks. It is a shared buffer so protected by the
|
||||||
|
xTxBufferMutex mutex. pcLwipAppsBlockingGetTxBuffer() and
|
||||||
|
vLwipAppsReleaseTxBuffer() are provided to obtain and release the
|
||||||
|
xTxBufferMutex respectively. pcLwipAppsBlockingGetTxBuffer() must be used with
|
||||||
|
caution as it has the potential to block. */
|
||||||
|
static signed char cTxBuffer[ lwipappsTX_BUFFER_SIZE ];
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
void vStatusCallback( struct netif *pxNetIf )
|
||||||
|
{
|
||||||
|
char pcMessage[20];
|
||||||
|
struct in_addr* pxIPAddress;
|
||||||
|
|
||||||
|
if( netif_is_up( pxNetIf ) != 0 )
|
||||||
|
{
|
||||||
|
strcpy( pcMessage, "IP=" );
|
||||||
|
pxIPAddress = ( struct in_addr* ) &( pxNetIf->ip_addr );
|
||||||
|
strcat( pcMessage, inet_ntoa( ( *pxIPAddress ) ) );
|
||||||
|
xil_printf( pcMessage );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xil_printf( "Network is down" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Called from the TCP/IP thread. */
|
||||||
|
void lwIPAppsInit( void *pvArgument )
|
||||||
|
{
|
||||||
|
ip_addr_t xIPAddr, xNetMask, xGateway;
|
||||||
|
extern err_t xemacliteif_init(struct netif *netif);
|
||||||
|
extern void xemacif_input_thread( void *netif );
|
||||||
|
static struct netif xNetIf;
|
||||||
|
|
||||||
|
( void ) pvArgument;
|
||||||
|
|
||||||
|
/* Set up the network interface. */
|
||||||
|
ip_addr_set_zero( &xGateway );
|
||||||
|
ip_addr_set_zero( &xIPAddr );
|
||||||
|
ip_addr_set_zero( &xNetMask );
|
||||||
|
|
||||||
|
LWIP_PORT_INIT_GW(&xGateway);
|
||||||
|
LWIP_PORT_INIT_IPADDR( &xIPAddr );
|
||||||
|
LWIP_PORT_INIT_NETMASK(&xNetMask);
|
||||||
|
|
||||||
|
/* Set mac address */
|
||||||
|
xNetIf.hwaddr_len = 6;
|
||||||
|
xNetIf.hwaddr[ 0 ] = configMAC_ADDR0;
|
||||||
|
xNetIf.hwaddr[ 1 ] = configMAC_ADDR1;
|
||||||
|
xNetIf.hwaddr[ 2 ] = configMAC_ADDR2;
|
||||||
|
xNetIf.hwaddr[ 3 ] = configMAC_ADDR3;
|
||||||
|
xNetIf.hwaddr[ 4 ] = configMAC_ADDR4;
|
||||||
|
xNetIf.hwaddr[ 5 ] = configMAC_ADDR5;
|
||||||
|
|
||||||
|
netif_set_default( netif_add( &xNetIf, &xIPAddr, &xNetMask, &xGateway, ( void * ) XPAR_AXI_ETHERNETLITE_0_BASEADDR, xemacliteif_init, tcpip_input ) );
|
||||||
|
netif_set_status_callback( &xNetIf, vStatusCallback );
|
||||||
|
#if LWIP_DHCP
|
||||||
|
{
|
||||||
|
dhcp_start( &xNetIf );
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
{
|
||||||
|
netif_set_up( &xNetIf );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Install the server side include handler. */
|
||||||
|
http_set_ssi_handler( uslwIPAppsSSIHandler, pccSSITags, sizeof( pccSSITags ) / sizeof( char * ) );
|
||||||
|
|
||||||
|
/* Create the mutex used to ensure mutual exclusive access to the Tx
|
||||||
|
buffer. */
|
||||||
|
xTxBufferMutex = xSemaphoreCreateMutex();
|
||||||
|
configASSERT( xTxBufferMutex );
|
||||||
|
|
||||||
|
/* Create the httpd server from the standard lwIP code. This demonstrates
|
||||||
|
use of the lwIP raw API. */
|
||||||
|
httpd_init();
|
||||||
|
|
||||||
|
sys_thread_new( "lwIP_In", xemacif_input_thread, &xNetIf, configMINIMAL_STACK_SIZE, configMAC_INPUT_TASK_PRIORITY );
|
||||||
|
|
||||||
|
/* Create the FreeRTOS defined basic command server. This demonstrates use
|
||||||
|
of the lwIP sockets API. */
|
||||||
|
xTaskCreate( vBasicSocketsCommandInterpreterTask, "CmdInt", configMINIMAL_STACK_SIZE * 5, NULL, configCLI_TASK_PRIORITY, NULL );
|
||||||
|
}
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
static unsigned short uslwIPAppsSSIHandler( int iIndex, char *pcBuffer, int iBufferLength )
|
||||||
|
{
|
||||||
|
static unsigned int uiUpdateCount = 0;
|
||||||
|
static char cUpdateString[ 200 ];
|
||||||
|
extern char *pcMainGetTaskStatusMessage( void );
|
||||||
|
|
||||||
|
/* Unused parameter. */
|
||||||
|
( void ) iBufferLength;
|
||||||
|
|
||||||
|
/* The SSI handler function that generates text depending on the index of
|
||||||
|
the SSI tag encountered. */
|
||||||
|
|
||||||
|
switch( iIndex )
|
||||||
|
{
|
||||||
|
case ssiTASK_STATS_INDEX :
|
||||||
|
vTaskList( pcBuffer );
|
||||||
|
break;
|
||||||
|
|
||||||
|
case ssiRUN_TIME_STATS_INDEX :
|
||||||
|
vTaskGetRunTimeStats( pcBuffer );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Include a count of the number of times an SSI function has been executed
|
||||||
|
in the returned string. */
|
||||||
|
uiUpdateCount++;
|
||||||
|
sprintf( cUpdateString, "\r\n\r\n%u\r\nStatus - %s", uiUpdateCount, pcMainGetTaskStatusMessage() );
|
||||||
|
strcat( pcBuffer, cUpdateString );
|
||||||
|
|
||||||
|
return strlen( pcBuffer );
|
||||||
|
}
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
signed char *pcLwipAppsBlockingGetTxBuffer( void )
|
||||||
|
{
|
||||||
|
signed char *pcReturn;
|
||||||
|
|
||||||
|
/* Attempt to obtain the semaphore that guards the Tx buffer. */
|
||||||
|
if( xSemaphoreTakeRecursive( xTxBufferMutex, lwipappsMAX_TIME_TO_WAIT_FOR_TX_BUFFER_MS ) == pdFAIL )
|
||||||
|
{
|
||||||
|
/* The semaphore could not be obtained before timing out. */
|
||||||
|
pcReturn = NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* The semaphore was obtained successfully. Return a pointer to the
|
||||||
|
Tx buffer. */
|
||||||
|
pcReturn = cTxBuffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
return pcReturn;
|
||||||
|
}
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
void vLwipAppsReleaseTxBuffer( void )
|
||||||
|
{
|
||||||
|
/* Finished with the Tx buffer. Return the mutex. */
|
||||||
|
xSemaphoreGiveRecursive( xTxBufferMutex );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,62 @@
|
|||||||
|
/*
|
||||||
|
FreeRTOS V7.0.1 - Copyright (C) 2011 Real Time Engineers Ltd.
|
||||||
|
|
||||||
|
|
||||||
|
***************************************************************************
|
||||||
|
* *
|
||||||
|
* FreeRTOS tutorial books are available in pdf and paperback. *
|
||||||
|
* Complete, revised, and edited pdf reference manuals are also *
|
||||||
|
* available. *
|
||||||
|
* *
|
||||||
|
* Purchasing FreeRTOS documentation will not only help you, by *
|
||||||
|
* ensuring you get running as quickly as possible and with an *
|
||||||
|
* in-depth knowledge of how to use FreeRTOS, it will also help *
|
||||||
|
* the FreeRTOS project to continue with its mission of providing *
|
||||||
|
* professional grade, cross platform, de facto standard solutions *
|
||||||
|
* for microcontrollers - completely free of charge! *
|
||||||
|
* *
|
||||||
|
* >>> See http://www.FreeRTOS.org/Documentation for details. <<< *
|
||||||
|
* *
|
||||||
|
* Thank you for using FreeRTOS, and thank you for your support! *
|
||||||
|
* *
|
||||||
|
***************************************************************************
|
||||||
|
|
||||||
|
|
||||||
|
This file is part of the FreeRTOS distribution.
|
||||||
|
|
||||||
|
FreeRTOS is free software; you can redistribute it and/or modify it under
|
||||||
|
the terms of the GNU General Public License (version 2) as published by the
|
||||||
|
Free Software Foundation AND MODIFIED BY the FreeRTOS exception.
|
||||||
|
>>>NOTE<<< The modification to the GPL is included to allow you to
|
||||||
|
distribute a combined work that includes FreeRTOS without being obliged to
|
||||||
|
provide the source code for proprietary components outside of the FreeRTOS
|
||||||
|
kernel. FreeRTOS is distributed in the hope that it will be useful, but
|
||||||
|
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
more details. You should have received a copy of the GNU General Public
|
||||||
|
License and the FreeRTOS license exception along with FreeRTOS; if not it
|
||||||
|
can be viewed here: http://www.freertos.org/a00114.html and also obtained
|
||||||
|
by writing to Richard Barry, contact details for whom are available on the
|
||||||
|
FreeRTOS WEB site.
|
||||||
|
|
||||||
|
1 tab == 4 spaces!
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org - Documentation, latest information, license and
|
||||||
|
contact details.
|
||||||
|
|
||||||
|
http://www.SafeRTOS.com - A version that is certified for use in safety
|
||||||
|
critical systems.
|
||||||
|
|
||||||
|
http://www.OpenRTOS.com - Commercial support, development, porting,
|
||||||
|
licensing and training services.
|
||||||
|
*/
|
||||||
|
#ifndef LWIP_APPS_H
|
||||||
|
#define LWIP_APPS_H
|
||||||
|
|
||||||
|
/* Functions used to obtain and release exclusive access to the Tx buffer. The
|
||||||
|
Get function will block if the Tx buffer is not available - use with care! */
|
||||||
|
signed char *pcLwipAppsBlockingGetTxBuffer( void );
|
||||||
|
void vLwipAppsReleaseTxBuffer( void );
|
||||||
|
|
||||||
|
#endif /* LWIP_APPS_H */
|
||||||
|
|
@ -0,0 +1,46 @@
|
|||||||
|
/**
|
||||||
|
* Additional settings for the win32 port.
|
||||||
|
* Copy this to lwipcfg_msvc.h and make the config changes you need.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* configuration for this port */
|
||||||
|
#define PPP_USERNAME "Admin"
|
||||||
|
#define PPP_PASSWORD "pass"
|
||||||
|
|
||||||
|
|
||||||
|
/** Define this to the GUID of the windows network adapter to use
|
||||||
|
* or NOT define this if you want PACKET_LIB_ADAPTER_NR to be used */
|
||||||
|
/*#define PACKET_LIB_ADAPTER_GUID "00000000-0000-0000-0000-000000000000"*/
|
||||||
|
/*#define PACKET_LIB_GET_ADAPTER_NETADDRESS(addr) IP4_ADDR((addr), 192,168,1,0)*/
|
||||||
|
/*#define PACKET_LIB_QUIET*/
|
||||||
|
|
||||||
|
#define LWIP_PORT_INIT_IPADDR(addr) IP4_ADDR((addr), configIP_ADDR0,configIP_ADDR1,configIP_ADDR2,configIP_ADDR3)
|
||||||
|
#define LWIP_PORT_INIT_GW(addr) IP4_ADDR((addr), 192,168,0,3)
|
||||||
|
#define LWIP_PORT_INIT_NETMASK(addr) IP4_ADDR((addr), 255,255,255,0)
|
||||||
|
|
||||||
|
/* remember to change this MAC address to suit your needs!
|
||||||
|
the last octet will be increased by netif->num for each netif */
|
||||||
|
#define LWIP_MAC_ADDR_BASE {0x00,0x01,0x02,0x03,0x04,0x05}
|
||||||
|
|
||||||
|
/* configuration for applications */
|
||||||
|
|
||||||
|
#define LWIP_CHARGEN_APP 0
|
||||||
|
#define LWIP_DNS_APP 0
|
||||||
|
#define LWIP_HTTPD_APP 1
|
||||||
|
/* Set this to 1 to use the netconn http server,
|
||||||
|
* otherwise the raw api server will be used. */
|
||||||
|
/*#define LWIP_HTTPD_APP_NETCONN */
|
||||||
|
#define LWIP_NETBIOS_APP 0
|
||||||
|
#define LWIP_NETIO_APP 0
|
||||||
|
#define LWIP_PING_APP 0
|
||||||
|
#define LWIP_RTP_APP 0
|
||||||
|
#define LWIP_SHELL_APP 0
|
||||||
|
#define LWIP_SNTP_APP 0
|
||||||
|
#define LWIP_SOCKET_EXAMPLES_APP 0
|
||||||
|
#define LWIP_TCPECHO_APP 0
|
||||||
|
/* Set this to 1 to use the netconn tcpecho server,
|
||||||
|
* otherwise the raw api server will be used. */
|
||||||
|
/*#define LWIP_TCPECHO_APP_NETCONN */
|
||||||
|
#define LWIP_UDPECHO_APP 0
|
||||||
|
|
||||||
|
|
@ -0,0 +1,603 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2001-2003 Swedish Institute of Computer Science.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
* are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||||
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
||||||
|
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
||||||
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||||||
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
* OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This file is part of the lwIP TCP/IP stack.
|
||||||
|
*
|
||||||
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
//*****************************************************************************
|
||||||
|
//
|
||||||
|
// Include OS functionality.
|
||||||
|
//
|
||||||
|
//*****************************************************************************
|
||||||
|
|
||||||
|
/* ------------------------ System architecture includes ----------------------------- */
|
||||||
|
#include "arch/sys_arch.h"
|
||||||
|
|
||||||
|
/* ------------------------ lwIP includes --------------------------------- */
|
||||||
|
#include "lwip/opt.h"
|
||||||
|
|
||||||
|
#include "lwip/debug.h"
|
||||||
|
#include "lwip/def.h"
|
||||||
|
#include "lwip/sys.h"
|
||||||
|
#include "lwip/mem.h"
|
||||||
|
#include "lwip/stats.h"
|
||||||
|
|
||||||
|
/* Very crude mechanism used to determine if the critical section handling
|
||||||
|
functions are being called from an interrupt context or not. This relies on
|
||||||
|
the interrupt handler setting this variable manually. */
|
||||||
|
BaseType_t xInsideISR = pdFALSE;
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_mbox_new
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Creates a new mailbox
|
||||||
|
* Inputs:
|
||||||
|
* int size -- Size of elements in the mailbox
|
||||||
|
* Outputs:
|
||||||
|
* sys_mbox_t -- Handle to new mailbox
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
err_t sys_mbox_new( sys_mbox_t *pxMailBox, int iSize )
|
||||||
|
{
|
||||||
|
err_t xReturn = ERR_MEM;
|
||||||
|
|
||||||
|
*pxMailBox = xQueueCreate( iSize, sizeof( void * ) );
|
||||||
|
|
||||||
|
if( *pxMailBox != NULL )
|
||||||
|
{
|
||||||
|
xReturn = ERR_OK;
|
||||||
|
SYS_STATS_INC_USED( mbox );
|
||||||
|
}
|
||||||
|
|
||||||
|
return xReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_mbox_free
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Deallocates a mailbox. If there are messages still present in the
|
||||||
|
* mailbox when the mailbox is deallocated, it is an indication of a
|
||||||
|
* programming error in lwIP and the developer should be notified.
|
||||||
|
* Inputs:
|
||||||
|
* sys_mbox_t mbox -- Handle of mailbox
|
||||||
|
* Outputs:
|
||||||
|
* sys_mbox_t -- Handle to new mailbox
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
void sys_mbox_free( sys_mbox_t *pxMailBox )
|
||||||
|
{
|
||||||
|
unsigned long ulMessagesWaiting;
|
||||||
|
|
||||||
|
ulMessagesWaiting = uxQueueMessagesWaiting( *pxMailBox );
|
||||||
|
configASSERT( ( ulMessagesWaiting == 0 ) );
|
||||||
|
|
||||||
|
#if SYS_STATS
|
||||||
|
{
|
||||||
|
if( ulMessagesWaiting != 0UL )
|
||||||
|
{
|
||||||
|
SYS_STATS_INC( mbox.err );
|
||||||
|
}
|
||||||
|
|
||||||
|
SYS_STATS_DEC( mbox.used );
|
||||||
|
}
|
||||||
|
#endif /* SYS_STATS */
|
||||||
|
|
||||||
|
vQueueDelete( *pxMailBox );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_mbox_post
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Post the "msg" to the mailbox.
|
||||||
|
* Inputs:
|
||||||
|
* sys_mbox_t mbox -- Handle of mailbox
|
||||||
|
* void *data -- Pointer to data to post
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
void sys_mbox_post( sys_mbox_t *pxMailBox, void *pxMessageToPost )
|
||||||
|
{
|
||||||
|
while( xQueueSendToBack( *pxMailBox, &pxMessageToPost, portMAX_DELAY ) != pdTRUE );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_mbox_trypost
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Try to post the "msg" to the mailbox. Returns immediately with
|
||||||
|
* error if cannot.
|
||||||
|
* Inputs:
|
||||||
|
* sys_mbox_t mbox -- Handle of mailbox
|
||||||
|
* void *msg -- Pointer to data to post
|
||||||
|
* Outputs:
|
||||||
|
* err_t -- ERR_OK if message posted, else ERR_MEM
|
||||||
|
* if not.
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
err_t sys_mbox_trypost( sys_mbox_t *pxMailBox, void *pxMessageToPost )
|
||||||
|
{
|
||||||
|
err_t xReturn;
|
||||||
|
portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;
|
||||||
|
|
||||||
|
if( xInsideISR != pdFALSE )
|
||||||
|
{
|
||||||
|
xReturn = xQueueSendFromISR( *pxMailBox, &pxMessageToPost, &xHigherPriorityTaskWoken );
|
||||||
|
portYIELD_FROM_ISR( xHigherPriorityTaskWoken );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xReturn = xQueueSend( *pxMailBox, &pxMessageToPost, ( TickType_t ) 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( xReturn == pdPASS )
|
||||||
|
{
|
||||||
|
xReturn = ERR_OK;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* The queue was already full. */
|
||||||
|
xReturn = ERR_MEM;
|
||||||
|
SYS_STATS_INC( mbox.err );
|
||||||
|
}
|
||||||
|
|
||||||
|
return xReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_arch_mbox_fetch
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Blocks the thread until a message arrives in the mailbox, but does
|
||||||
|
* not block the thread longer than "timeout" milliseconds (similar to
|
||||||
|
* the sys_arch_sem_wait() function). The "msg" argument is a result
|
||||||
|
* parameter that is set by the function (i.e., by doing "*msg =
|
||||||
|
* ptr"). The "msg" parameter maybe NULL to indicate that the message
|
||||||
|
* should be dropped.
|
||||||
|
*
|
||||||
|
* The return values are the same as for the sys_arch_sem_wait() function:
|
||||||
|
* Number of milliseconds spent waiting or SYS_ARCH_TIMEOUT if there was a
|
||||||
|
* timeout.
|
||||||
|
*
|
||||||
|
* Note that a function with a similar name, sys_mbox_fetch(), is
|
||||||
|
* implemented by lwIP.
|
||||||
|
* Inputs:
|
||||||
|
* sys_mbox_t mbox -- Handle of mailbox
|
||||||
|
* void **msg -- Pointer to pointer to msg received
|
||||||
|
* u32_t timeout -- Number of milliseconds until timeout
|
||||||
|
* Outputs:
|
||||||
|
* u32_t -- SYS_ARCH_TIMEOUT if timeout, else number
|
||||||
|
* of milliseconds until received.
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
u32_t sys_arch_mbox_fetch( sys_mbox_t *pxMailBox, void **ppvBuffer, u32_t ulTimeOut )
|
||||||
|
{
|
||||||
|
void *pvDummy;
|
||||||
|
TickType_t xStartTime, xEndTime, xElapsed;
|
||||||
|
unsigned long ulReturn;
|
||||||
|
|
||||||
|
xStartTime = xTaskGetTickCount();
|
||||||
|
|
||||||
|
if( NULL == ppvBuffer )
|
||||||
|
{
|
||||||
|
ppvBuffer = &pvDummy;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( ulTimeOut != 0UL )
|
||||||
|
{
|
||||||
|
configASSERT( xInsideISR == ( portBASE_TYPE ) 0 );
|
||||||
|
|
||||||
|
if( pdTRUE == xQueueReceive( *pxMailBox, &( *ppvBuffer ), ulTimeOut/ portTICK_PERIOD_MS ) )
|
||||||
|
{
|
||||||
|
xEndTime = xTaskGetTickCount();
|
||||||
|
xElapsed = ( xEndTime - xStartTime ) * portTICK_PERIOD_MS;
|
||||||
|
|
||||||
|
ulReturn = xElapsed;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Timed out. */
|
||||||
|
*ppvBuffer = NULL;
|
||||||
|
ulReturn = SYS_ARCH_TIMEOUT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
while( pdTRUE != xQueueReceive( *pxMailBox, &( *ppvBuffer ), portMAX_DELAY ) );
|
||||||
|
xEndTime = xTaskGetTickCount();
|
||||||
|
xElapsed = ( xEndTime - xStartTime ) * portTICK_PERIOD_MS;
|
||||||
|
|
||||||
|
if( xElapsed == 0UL )
|
||||||
|
{
|
||||||
|
xElapsed = 1UL;
|
||||||
|
}
|
||||||
|
|
||||||
|
ulReturn = xElapsed;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ulReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_arch_mbox_tryfetch
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Similar to sys_arch_mbox_fetch, but if message is not ready
|
||||||
|
* immediately, we'll return with SYS_MBOX_EMPTY. On success, 0 is
|
||||||
|
* returned.
|
||||||
|
* Inputs:
|
||||||
|
* sys_mbox_t mbox -- Handle of mailbox
|
||||||
|
* void **msg -- Pointer to pointer to msg received
|
||||||
|
* Outputs:
|
||||||
|
* u32_t -- SYS_MBOX_EMPTY if no messages. Otherwise,
|
||||||
|
* return ERR_OK.
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
u32_t sys_arch_mbox_tryfetch( sys_mbox_t *pxMailBox, void **ppvBuffer )
|
||||||
|
{
|
||||||
|
void *pvDummy;
|
||||||
|
unsigned long ulReturn;
|
||||||
|
long lResult;
|
||||||
|
portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;
|
||||||
|
|
||||||
|
if( ppvBuffer== NULL )
|
||||||
|
{
|
||||||
|
ppvBuffer = &pvDummy;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( xInsideISR != pdFALSE )
|
||||||
|
{
|
||||||
|
lResult = xQueueReceiveFromISR( *pxMailBox, &( *ppvBuffer ), &xHigherPriorityTaskWoken );
|
||||||
|
portYIELD_FROM_ISR( xHigherPriorityTaskWoken );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
lResult = xQueueReceive( *pxMailBox, &( *ppvBuffer ), 0UL );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( lResult == pdPASS )
|
||||||
|
{
|
||||||
|
ulReturn = ERR_OK;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ulReturn = SYS_MBOX_EMPTY;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ulReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_sem_new
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Creates and returns a new semaphore. The "ucCount" argument specifies
|
||||||
|
* the initial state of the semaphore.
|
||||||
|
* NOTE: Currently this routine only creates counts of 1 or 0
|
||||||
|
* Inputs:
|
||||||
|
* sys_mbox_t mbox -- Handle of mailbox
|
||||||
|
* u8_t ucCount -- Initial ucCount of semaphore (1 or 0)
|
||||||
|
* Outputs:
|
||||||
|
* sys_sem_t -- Created semaphore or 0 if could not create.
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
err_t sys_sem_new( sys_sem_t *pxSemaphore, u8_t ucCount )
|
||||||
|
{
|
||||||
|
err_t xReturn = ERR_MEM;
|
||||||
|
|
||||||
|
//vSemaphoreCreateBinary( ( *pxSemaphore ) );
|
||||||
|
*pxSemaphore = xSemaphoreCreateCounting( 0xffff, ( unsigned long ) ucCount );
|
||||||
|
|
||||||
|
if( *pxSemaphore != NULL )
|
||||||
|
{
|
||||||
|
if( ucCount == 0U )
|
||||||
|
{
|
||||||
|
// xSemaphoreTake( *pxSemaphore, 1UL );
|
||||||
|
}
|
||||||
|
|
||||||
|
xReturn = ERR_OK;
|
||||||
|
SYS_STATS_INC_USED( sem );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SYS_STATS_INC( sem.err );
|
||||||
|
}
|
||||||
|
|
||||||
|
return xReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_arch_sem_wait
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Blocks the thread while waiting for the semaphore to be
|
||||||
|
* signaled. If the "timeout" argument is non-zero, the thread should
|
||||||
|
* only be blocked for the specified time (measured in
|
||||||
|
* milliseconds).
|
||||||
|
*
|
||||||
|
* If the timeout argument is non-zero, the return value is the number of
|
||||||
|
* milliseconds spent waiting for the semaphore to be signaled. If the
|
||||||
|
* semaphore wasn't signaled within the specified time, the return value is
|
||||||
|
* SYS_ARCH_TIMEOUT. If the thread didn't have to wait for the semaphore
|
||||||
|
* (i.e., it was already signaled), the function may return zero.
|
||||||
|
*
|
||||||
|
* Notice that lwIP implements a function with a similar name,
|
||||||
|
* sys_sem_wait(), that uses the sys_arch_sem_wait() function.
|
||||||
|
* Inputs:
|
||||||
|
* sys_sem_t sem -- Semaphore to wait on
|
||||||
|
* u32_t timeout -- Number of milliseconds until timeout
|
||||||
|
* Outputs:
|
||||||
|
* u32_t -- Time elapsed or SYS_ARCH_TIMEOUT.
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
u32_t sys_arch_sem_wait( sys_sem_t *pxSemaphore, u32_t ulTimeout )
|
||||||
|
{
|
||||||
|
TickType_t xStartTime, xEndTime, xElapsed;
|
||||||
|
unsigned long ulReturn;
|
||||||
|
|
||||||
|
xStartTime = xTaskGetTickCount();
|
||||||
|
|
||||||
|
if( ulTimeout != 0UL )
|
||||||
|
{
|
||||||
|
if( xSemaphoreTake( *pxSemaphore, ulTimeout / portTICK_PERIOD_MS ) == pdTRUE )
|
||||||
|
{
|
||||||
|
xEndTime = xTaskGetTickCount();
|
||||||
|
xElapsed = (xEndTime - xStartTime) * portTICK_PERIOD_MS;
|
||||||
|
ulReturn = xElapsed;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ulReturn = SYS_ARCH_TIMEOUT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
while( xSemaphoreTake( *pxSemaphore, portMAX_DELAY ) != pdTRUE );
|
||||||
|
xEndTime = xTaskGetTickCount();
|
||||||
|
xElapsed = ( xEndTime - xStartTime ) * portTICK_PERIOD_MS;
|
||||||
|
|
||||||
|
if( xElapsed == 0UL )
|
||||||
|
{
|
||||||
|
xElapsed = 1UL;
|
||||||
|
}
|
||||||
|
|
||||||
|
ulReturn = xElapsed;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ulReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Create a new mutex
|
||||||
|
* @param mutex pointer to the mutex to create
|
||||||
|
* @return a new mutex */
|
||||||
|
err_t sys_mutex_new( sys_mutex_t *pxMutex )
|
||||||
|
{
|
||||||
|
err_t xReturn = ERR_MEM;
|
||||||
|
|
||||||
|
*pxMutex = xSemaphoreCreateMutex();
|
||||||
|
|
||||||
|
if( *pxMutex != NULL )
|
||||||
|
{
|
||||||
|
xReturn = ERR_OK;
|
||||||
|
SYS_STATS_INC_USED( mutex );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SYS_STATS_INC( mutex.err );
|
||||||
|
}
|
||||||
|
|
||||||
|
return xReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Lock a mutex
|
||||||
|
* @param mutex the mutex to lock */
|
||||||
|
void sys_mutex_lock( sys_mutex_t *pxMutex )
|
||||||
|
{
|
||||||
|
BaseType_t xGotSemaphore;
|
||||||
|
BaseType_t xHigherPriorityTaskWoken = pdFALSE;
|
||||||
|
|
||||||
|
if( xInsideISR == 0 )
|
||||||
|
{
|
||||||
|
while( xSemaphoreTake( *pxMutex, portMAX_DELAY ) != pdPASS );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xGotSemaphore = xSemaphoreTakeFromISR( *pxMutex, &xHigherPriorityTaskWoken );
|
||||||
|
configASSERT( xGotSemaphore );
|
||||||
|
portYIELD_FROM_ISR( xHigherPriorityTaskWoken );
|
||||||
|
|
||||||
|
/* Prevent compiler warnings if configASSERT() is not defined. */
|
||||||
|
( void ) xGotSemaphore;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Unlock a mutex
|
||||||
|
* @param mutex the mutex to unlock */
|
||||||
|
void sys_mutex_unlock(sys_mutex_t *pxMutex )
|
||||||
|
{
|
||||||
|
xSemaphoreGive( *pxMutex );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/** Delete a semaphore
|
||||||
|
* @param mutex the mutex to delete */
|
||||||
|
void sys_mutex_free( sys_mutex_t *pxMutex )
|
||||||
|
{
|
||||||
|
SYS_STATS_DEC( mutex.used );
|
||||||
|
vQueueDelete( *pxMutex );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_sem_signal
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Signals (releases) a semaphore
|
||||||
|
* Inputs:
|
||||||
|
* sys_sem_t sem -- Semaphore to signal
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
void sys_sem_signal( sys_sem_t *pxSemaphore )
|
||||||
|
{
|
||||||
|
portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;
|
||||||
|
|
||||||
|
if( xInsideISR != pdFALSE )
|
||||||
|
{
|
||||||
|
xSemaphoreGiveFromISR( *pxSemaphore, &xHigherPriorityTaskWoken );
|
||||||
|
portYIELD_FROM_ISR( xHigherPriorityTaskWoken );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xSemaphoreGive( *pxSemaphore );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_sem_free
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Deallocates a semaphore
|
||||||
|
* Inputs:
|
||||||
|
* sys_sem_t sem -- Semaphore to free
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
void sys_sem_free( sys_sem_t *pxSemaphore )
|
||||||
|
{
|
||||||
|
SYS_STATS_DEC(sem.used);
|
||||||
|
vQueueDelete( *pxSemaphore );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_init
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Initialize sys arch
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
void sys_init(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
u32_t sys_now(void)
|
||||||
|
{
|
||||||
|
return xTaskGetTickCount();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_thread_new
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* Starts a new thread with priority "prio" that will begin its
|
||||||
|
* execution in the function "thread()". The "arg" argument will be
|
||||||
|
* passed as an argument to the thread() function. The id of the new
|
||||||
|
* thread is returned. Both the id and the priority are system
|
||||||
|
* dependent.
|
||||||
|
* Inputs:
|
||||||
|
* char *name -- Name of thread
|
||||||
|
* void (* thread)(void *arg) -- Pointer to function to run.
|
||||||
|
* void *arg -- Argument passed into function
|
||||||
|
* int stacksize -- Required stack amount in bytes
|
||||||
|
* int prio -- Thread priority
|
||||||
|
* Outputs:
|
||||||
|
* sys_thread_t -- Pointer to per-thread timeouts.
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
sys_thread_t sys_thread_new( const char *pcName, void( *pxThread )( void *pvParameters ), void *pvArg, int iStackSize, int iPriority )
|
||||||
|
{
|
||||||
|
TaskHandle_t xCreatedTask;
|
||||||
|
portBASE_TYPE xResult;
|
||||||
|
sys_thread_t xReturn;
|
||||||
|
|
||||||
|
xResult = xTaskCreate( pxThread, pcName, iStackSize, pvArg, iPriority, &xCreatedTask );
|
||||||
|
|
||||||
|
if( xResult == pdPASS )
|
||||||
|
{
|
||||||
|
xReturn = xCreatedTask;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
xReturn = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return xReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_arch_protect
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* This optional function does a "fast" critical region protection and
|
||||||
|
* returns the previous protection level. This function is only called
|
||||||
|
* during very short critical regions. An embedded system which supports
|
||||||
|
* ISR-based drivers might want to implement this function by disabling
|
||||||
|
* interrupts. Task-based systems might want to implement this by using
|
||||||
|
* a mutex or disabling tasking. This function should support recursive
|
||||||
|
* calls from the same task or interrupt. In other words,
|
||||||
|
* sys_arch_protect() could be called while already protected. In
|
||||||
|
* that case the return value indicates that it is already protected.
|
||||||
|
*
|
||||||
|
* sys_arch_protect() is only required if your port is supporting an
|
||||||
|
* operating system.
|
||||||
|
* Outputs:
|
||||||
|
* sys_prot_t -- Previous protection level (not used here)
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
sys_prot_t sys_arch_protect( void )
|
||||||
|
{
|
||||||
|
if( xInsideISR == pdFALSE )
|
||||||
|
{
|
||||||
|
taskENTER_CRITICAL();
|
||||||
|
}
|
||||||
|
return ( sys_prot_t ) 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*---------------------------------------------------------------------------*
|
||||||
|
* Routine: sys_arch_unprotect
|
||||||
|
*---------------------------------------------------------------------------*
|
||||||
|
* Description:
|
||||||
|
* This optional function does a "fast" set of critical region
|
||||||
|
* protection to the value specified by pval. See the documentation for
|
||||||
|
* sys_arch_protect() for more information. This function is only
|
||||||
|
* required if your port is supporting an operating system.
|
||||||
|
* Inputs:
|
||||||
|
* sys_prot_t -- Previous protection level (not used here)
|
||||||
|
*---------------------------------------------------------------------------*/
|
||||||
|
void sys_arch_unprotect( sys_prot_t xValue )
|
||||||
|
{
|
||||||
|
(void) xValue;
|
||||||
|
if( xInsideISR == pdFALSE )
|
||||||
|
{
|
||||||
|
taskEXIT_CRITICAL();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Prints an assertion messages and aborts execution.
|
||||||
|
*/
|
||||||
|
void sys_assert( const char *pcMessage )
|
||||||
|
{
|
||||||
|
(void) pcMessage;
|
||||||
|
|
||||||
|
for (;;)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/*-------------------------------------------------------------------------*
|
||||||
|
* End of File: sys_arch.c
|
||||||
|
*-------------------------------------------------------------------------*/
|
||||||
|
|
@ -0,0 +1,194 @@
|
|||||||
|
/*
|
||||||
|
FreeRTOS V8.2.0 - Copyright (C) 2015 Real Time Engineers Ltd.
|
||||||
|
All rights reserved
|
||||||
|
|
||||||
|
VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
|
||||||
|
|
||||||
|
This file is part of the FreeRTOS distribution.
|
||||||
|
|
||||||
|
FreeRTOS is free software; you can redistribute it and/or modify it under
|
||||||
|
the terms of the GNU General Public License (version 2) as published by the
|
||||||
|
Free Software Foundation >>!AND MODIFIED BY!<< the FreeRTOS exception.
|
||||||
|
|
||||||
|
***************************************************************************
|
||||||
|
>>! NOTE: The modification to the GPL is included to allow you to !<<
|
||||||
|
>>! distribute a combined work that includes FreeRTOS without being !<<
|
||||||
|
>>! obliged to provide the source code for proprietary components !<<
|
||||||
|
>>! outside of the FreeRTOS kernel. !<<
|
||||||
|
***************************************************************************
|
||||||
|
|
||||||
|
FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||||
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||||
|
FOR A PARTICULAR PURPOSE. Full license text is available on the following
|
||||||
|
link: http://www.freertos.org/a00114.html
|
||||||
|
|
||||||
|
***************************************************************************
|
||||||
|
* *
|
||||||
|
* FreeRTOS provides completely free yet professionally developed, *
|
||||||
|
* robust, strictly quality controlled, supported, and cross *
|
||||||
|
* platform software that is more than just the market leader, it *
|
||||||
|
* is the industry's de facto standard. *
|
||||||
|
* *
|
||||||
|
* Help yourself get started quickly while simultaneously helping *
|
||||||
|
* to support the FreeRTOS project by purchasing a FreeRTOS *
|
||||||
|
* tutorial book, reference manual, or both: *
|
||||||
|
* http://www.FreeRTOS.org/Documentation *
|
||||||
|
* *
|
||||||
|
***************************************************************************
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org/FAQHelp.html - Having a problem? Start by reading
|
||||||
|
the FAQ page "My application does not run, what could be wrong?". Have you
|
||||||
|
defined configASSERT()?
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org/support - In return for receiving this top quality
|
||||||
|
embedded software for free we request you assist our global community by
|
||||||
|
participating in the support forum.
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org/training - Investing in training allows your team to
|
||||||
|
be as productive as possible as early as possible. Now you can receive
|
||||||
|
FreeRTOS training directly from Richard Barry, CEO of Real Time Engineers
|
||||||
|
Ltd, and the world's leading authority on the world's leading RTOS.
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
|
||||||
|
including FreeRTOS+Trace - an indispensable productivity tool, a DOS
|
||||||
|
compatible FAT file system, and our tiny thread aware UDP/IP stack.
|
||||||
|
|
||||||
|
http://www.FreeRTOS.org/labs - Where new FreeRTOS products go to incubate.
|
||||||
|
Come and try FreeRTOS+TCP, our new open source TCP/IP stack for FreeRTOS.
|
||||||
|
|
||||||
|
http://www.OpenRTOS.com - Real Time Engineers ltd. license FreeRTOS to High
|
||||||
|
Integrity Systems ltd. to sell under the OpenRTOS brand. Low cost OpenRTOS
|
||||||
|
licenses offer ticketed support, indemnification and commercial middleware.
|
||||||
|
|
||||||
|
http://www.SafeRTOS.com - High Integrity Systems also provide a safety
|
||||||
|
engineered and independently SIL3 certified version for use in safety and
|
||||||
|
mission critical applications that require provable dependability.
|
||||||
|
|
||||||
|
1 tab == 4 spaces!
|
||||||
|
*/
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* NOTE 1: This project provides three demo applications. A simple blinky
|
||||||
|
* style project, a more comprehensive test and demo application, and an
|
||||||
|
* lwIP example. The mainSELECTED_APPLICATION setting in main.c is used to
|
||||||
|
* select between the three. See the notes on using mainSELECTED_APPLICATION
|
||||||
|
* in main.c. This file implements the simply blinky style version.
|
||||||
|
*
|
||||||
|
* NOTE 2: This file only contains the source code that is specific to the
|
||||||
|
* basic demo. Generic functions, such FreeRTOS hook functions, and functions
|
||||||
|
* required to configure the hardware are defined in main.c.
|
||||||
|
******************************************************************************
|
||||||
|
*
|
||||||
|
* The lwIP example can be configured to use either a static or dynamic IP
|
||||||
|
* address:
|
||||||
|
* + To use a dynamically allocated IP address set LWIP_DHCP to 1 in
|
||||||
|
* lwipopts.h and connect the target to a network that includes a DHCP
|
||||||
|
* server. The obtained IP address is printed to the UART console.
|
||||||
|
* + To use a static IP address set LWIP_DHCP to 0 in lwipopts.h and set
|
||||||
|
* the static IP address using the configIP_ADDR0 to configIP_ADDR3
|
||||||
|
* constants at the bottom of FreeRTOSConfig.h. Constants used to define
|
||||||
|
* a netmask are also located at the bottom of FreeRTOSConfig.h.
|
||||||
|
*
|
||||||
|
* When connected correctly the demo uses the lwIP sockets API to create
|
||||||
|
* a FreeRTOS+CLI command console, and the lwIP raw API to create a basic HTTP
|
||||||
|
* web server with server side includes that generate dynamic run time web
|
||||||
|
* pages. See http://www.freertos.org/RTOS-Xilinx-Zynq.html for more
|
||||||
|
* information.
|
||||||
|
*
|
||||||
|
* To connect to FreeRTOS+CLI, open a command prompt and enter "telnet <ipaddr>"
|
||||||
|
* where <ipaddr> is the IP address of the target. Once connected type "help"
|
||||||
|
* to see a list of registered commands. Note this example does not implement
|
||||||
|
* a real telnet server, it just uses the telnet port number to allow easy
|
||||||
|
* connection using telnet tools.
|
||||||
|
*
|
||||||
|
* To connect to the http server simply type the IP address of the target into
|
||||||
|
* the address bar of a web browser.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Kernel includes. */
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "timers.h"
|
||||||
|
|
||||||
|
/* Standard demo includes. */
|
||||||
|
#include "partest.h"
|
||||||
|
|
||||||
|
/* lwIP includes. */
|
||||||
|
#include "lwip/tcpip.h"
|
||||||
|
|
||||||
|
/* The rate at which data is sent to the queue. The 200ms value is converted
|
||||||
|
to ticks using the portTICK_PERIOD_MS constant. */
|
||||||
|
#define mainTIMER_PERIOD_MS ( pdMS_TO_TICKS( 200 ) )
|
||||||
|
|
||||||
|
/* The LED toggled by the Rx task. */
|
||||||
|
#define mainTIMER_LED ( 0 )
|
||||||
|
|
||||||
|
/* A block time of zero just means "don't block". */
|
||||||
|
#define mainDONT_BLOCK ( 0 )
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The callback for the timer that just toggles an LED to show the system is
|
||||||
|
* running.
|
||||||
|
*/
|
||||||
|
static void prvLEDToggleTimer( TimerHandle_t pxTimer );
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Defined in lwIPApps.c.
|
||||||
|
*/
|
||||||
|
extern void lwIPAppsInit( void *pvArguments );
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
void main_lwIP( void )
|
||||||
|
{
|
||||||
|
TimerHandle_t xTimer;
|
||||||
|
|
||||||
|
/* Init lwIP and start lwIP tasks. */
|
||||||
|
tcpip_init( lwIPAppsInit, NULL );
|
||||||
|
|
||||||
|
/* A timer is used to toggle an LED just to show the application is
|
||||||
|
executing. */
|
||||||
|
xTimer = xTimerCreate( "LED", /* Text name to make debugging easier. */
|
||||||
|
mainTIMER_PERIOD_MS, /* The timer's period. */
|
||||||
|
pdTRUE, /* This is an auto reload timer. */
|
||||||
|
NULL, /* ID is not used. */
|
||||||
|
prvLEDToggleTimer ); /* The callback function. */
|
||||||
|
|
||||||
|
/* Start the timer. */
|
||||||
|
configASSERT( xTimer );
|
||||||
|
xTimerStart( xTimer, mainDONT_BLOCK );
|
||||||
|
|
||||||
|
/* Start the tasks and timer running. */
|
||||||
|
vTaskStartScheduler();
|
||||||
|
|
||||||
|
/* If all is well, the scheduler will now be running, and the following
|
||||||
|
line will never be reached. If the following line does execute, then
|
||||||
|
there was either insufficient FreeRTOS heap memory available for the idle
|
||||||
|
and/or timer tasks to be created, or vTaskStartScheduler() was called from
|
||||||
|
User mode. See the memory management section on the FreeRTOS web site for
|
||||||
|
more details on the FreeRTOS heap http://www.freertos.org/a00111.html. The
|
||||||
|
mode from which main() is called is set in the C start up code and must be
|
||||||
|
a privileged mode (not user mode). */
|
||||||
|
for( ;; );
|
||||||
|
}
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
static void prvLEDToggleTimer( TimerHandle_t pxTimer )
|
||||||
|
{
|
||||||
|
/* Prevent compiler warnings. */
|
||||||
|
( void ) pxTimer;
|
||||||
|
|
||||||
|
/* Just toggle an LED to show the application is running. */
|
||||||
|
vParTestToggleLED( mainTIMER_LED );
|
||||||
|
}
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
char *pcMainGetTaskStatusMessage( void )
|
||||||
|
{
|
||||||
|
return "Running lwIP demo";
|
||||||
|
}
|
||||||
|
/*-----------------------------------------------------------*/
|
@ -0,0 +1,335 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2001-2003 Swedish Institute of Computer Science.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without modification,
|
||||||
|
* are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
||||||
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
|
||||||
|
* SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
|
||||||
|
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
||||||
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
|
||||||
|
* OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This file is part of the lwIP TCP/IP stack.
|
||||||
|
*
|
||||||
|
* Author: Adam Dunkels <adam@sics.se>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#ifndef __LWIPOPTS_H__
|
||||||
|
#define __LWIPOPTS_H__
|
||||||
|
|
||||||
|
#include <limits.h>
|
||||||
|
#include "xparameters.h"
|
||||||
|
|
||||||
|
/* Functions used to obtain and release exclusive access to the Tx buffer. The
|
||||||
|
Get function will block if the Tx buffer is not available - use with care! */
|
||||||
|
signed char *pcLwipBlockingGetTxBuffer( void );
|
||||||
|
void vLwipAppsReleaseTxBuffer( void );
|
||||||
|
|
||||||
|
#define CONFIG_LINKSPEED_AUTODETECT 1
|
||||||
|
#define OS_IS_FREERTOS
|
||||||
|
|
||||||
|
/* SSI options. */
|
||||||
|
#define TCPIP_THREAD_NAME "tcpip"
|
||||||
|
#define LWIP_HTTPD_MAX_TAG_NAME_LEN 20
|
||||||
|
#define LWIP_HTTPD_MAX_TAG_INSERT_LEN 1024
|
||||||
|
#define TCPIP_THREAD_PRIO configLWIP_TASK_PRIORITY
|
||||||
|
#define TCPIP_THREAD_STACKSIZE configMINIMAL_STACK_SIZE * 3
|
||||||
|
|
||||||
|
#define DEFAULT_TCP_RECVMBOX_SIZE 5
|
||||||
|
#define DEFAULT_ACCEPTMBOX_SIZE 5
|
||||||
|
#define TCPIP_MBOX_SIZE 10
|
||||||
|
|
||||||
|
#define NO_SYS 0
|
||||||
|
#define LWIP_SOCKET (NO_SYS==0)
|
||||||
|
#define LWIP_NETCONN 1
|
||||||
|
|
||||||
|
#define LWIP_SNMP 0
|
||||||
|
#define LWIP_IGMP 0
|
||||||
|
#define LWIP_ICMP 1
|
||||||
|
|
||||||
|
/* DNS is not going to be used as this is a simple local example. */
|
||||||
|
#define LWIP_DNS 0
|
||||||
|
|
||||||
|
#define LWIP_HAVE_LOOPIF 0
|
||||||
|
#define TCP_LISTEN_BACKLOG 0
|
||||||
|
#define LWIP_SO_RCVTIMEO 1
|
||||||
|
#define LWIP_SO_RCVBUF 1
|
||||||
|
|
||||||
|
//#define LWIP_DEBUG
|
||||||
|
#ifdef LWIP_DEBUG
|
||||||
|
|
||||||
|
#define LWIP_DBG_MIN_LEVEL LWIP_DBG_LEVEL_ALL // LWIP_DBG_LEVEL_SERIOUS
|
||||||
|
#define PPP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define MEM_DEBUG LWIP_DBG_OFF
|
||||||
|
#define MEMP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define PBUF_DEBUG LWIP_DBG_OFF
|
||||||
|
#define API_LIB_DEBUG LWIP_DBG_OFF
|
||||||
|
#define API_MSG_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCPIP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define NETIF_DEBUG LWIP_DBG_OFF
|
||||||
|
#define SOCKETS_DEBUG LWIP_DBG_OFF
|
||||||
|
#define DNS_DEBUG LWIP_DBG_OFF
|
||||||
|
#define AUTOIP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define DHCP_DEBUG LWIP_DBG_ON
|
||||||
|
#define IP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define IP_REASS_DEBUG LWIP_DBG_OFF
|
||||||
|
#define ICMP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define IGMP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define UDP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_INPUT_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_OUTPUT_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_RTO_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_CWND_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_WND_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_FR_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_QLEN_DEBUG LWIP_DBG_OFF
|
||||||
|
#define TCP_RST_DEBUG LWIP_DBG_OFF
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define LWIP_DBG_TYPES_ON (LWIP_DBG_ON|LWIP_DBG_TRACE|LWIP_DBG_STATE|LWIP_DBG_FRESH|LWIP_DBG_HALT)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- Memory options ---------- */
|
||||||
|
/* MEM_ALIGNMENT: should be set to the alignment of the CPU for which
|
||||||
|
lwIP is compiled. 4 byte alignment -> define MEM_ALIGNMENT to 4, 2
|
||||||
|
byte alignment -> define MEM_ALIGNMENT to 2. */
|
||||||
|
/* MSVC port: intel processors don't need 4-byte alignment,
|
||||||
|
but are faster that way! */
|
||||||
|
#define MEM_ALIGNMENT 64
|
||||||
|
|
||||||
|
/* MEM_SIZE: the size of the heap memory. If the application will send
|
||||||
|
a lot of data that needs to be copied, this should be set high. */
|
||||||
|
#define MEM_SIZE 20 * 1024
|
||||||
|
|
||||||
|
/* MEMP_NUM_PBUF: the number of memp struct pbufs. If the application
|
||||||
|
sends a lot of data out of ROM (or other static memory), this
|
||||||
|
should be set high. */
|
||||||
|
#define MEMP_NUM_PBUF 10
|
||||||
|
|
||||||
|
/* MEMP_NUM_RAW_PCB: the number of UDP protocol control blocks. One
|
||||||
|
per active RAW "connection". */
|
||||||
|
#define LWIP_RAW 0
|
||||||
|
#define MEMP_NUM_RAW_PCB 0
|
||||||
|
|
||||||
|
/* MEMP_NUM_UDP_PCB: the number of UDP protocol control blocks. One
|
||||||
|
per active UDP "connection". */
|
||||||
|
#define MEMP_NUM_UDP_PCB 4
|
||||||
|
|
||||||
|
/* MEMP_NUM_TCP_PCB: the number of simultaneously active TCP
|
||||||
|
connections. */
|
||||||
|
#define MEMP_NUM_TCP_PCB 5
|
||||||
|
|
||||||
|
/* MEMP_NUM_TCP_PCB_LISTEN: the number of listening TCP
|
||||||
|
connections. */
|
||||||
|
#define MEMP_NUM_TCP_PCB_LISTEN 4
|
||||||
|
|
||||||
|
/* MEMP_NUM_TCP_SEG: the number of simultaneously queued TCP
|
||||||
|
segments. */
|
||||||
|
#define MEMP_NUM_TCP_SEG 20
|
||||||
|
|
||||||
|
/* MEMP_NUM_SYS_TIMEOUT: the number of simultaneously active
|
||||||
|
timeouts. */
|
||||||
|
#define MEMP_NUM_SYS_TIMEOUT 8
|
||||||
|
|
||||||
|
/* The following four are used only with the sequential API and can be
|
||||||
|
set to 0 if the application only will use the raw API. */
|
||||||
|
/* MEMP_NUM_NETBUF: the number of struct netbufs. */
|
||||||
|
#define MEMP_NUM_NETBUF 0
|
||||||
|
|
||||||
|
/* MEMP_NUM_NETCONN: the number of struct netconns. */
|
||||||
|
#define MEMP_NUM_NETCONN 5
|
||||||
|
|
||||||
|
/* MEMP_NUM_TCPIP_MSG_*: the number of struct tcpip_msg, which is used
|
||||||
|
for sequential API communication and incoming packets. Used in
|
||||||
|
src/api/tcpip.c. */
|
||||||
|
#define MEMP_NUM_TCPIP_MSG_API 4
|
||||||
|
#define MEMP_NUM_TCPIP_MSG_INPKT 4
|
||||||
|
|
||||||
|
#define MEMP_NUM_ARP_QUEUE 5
|
||||||
|
|
||||||
|
/* ---------- Pbuf options ---------- */
|
||||||
|
/* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */
|
||||||
|
#define PBUF_POOL_SIZE 10
|
||||||
|
|
||||||
|
/* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */
|
||||||
|
#define PBUF_POOL_BUFSIZE 512
|
||||||
|
|
||||||
|
/* PBUF_LINK_HLEN: the number of bytes that should be allocated for a
|
||||||
|
link level header. */
|
||||||
|
#define PBUF_LINK_HLEN 16
|
||||||
|
|
||||||
|
/** SYS_LIGHTWEIGHT_PROT
|
||||||
|
* define SYS_LIGHTWEIGHT_PROT in lwipopts.h if you want inter-task protection
|
||||||
|
* for certain critical regions during buffer allocation, deallocation and memory
|
||||||
|
* allocation and deallocation.
|
||||||
|
*/
|
||||||
|
#define SYS_LIGHTWEIGHT_PROT (NO_SYS==0)
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- TCP options ---------- */
|
||||||
|
#define LWIP_TCP 1
|
||||||
|
#define TCP_TTL 255
|
||||||
|
|
||||||
|
/* Controls if TCP should queue segments that arrive out of
|
||||||
|
order. Define to 0 if your device is low on memory. */
|
||||||
|
#define TCP_QUEUE_OOSEQ 1
|
||||||
|
|
||||||
|
/* TCP Maximum segment size. */
|
||||||
|
#define TCP_MSS 1460
|
||||||
|
|
||||||
|
/* TCP sender buffer space (bytes). */
|
||||||
|
#define TCP_SND_BUF 8129
|
||||||
|
|
||||||
|
/* TCP sender buffer space (pbufs). This must be at least = 2 *
|
||||||
|
TCP_SND_BUF/TCP_MSS for things to work. */
|
||||||
|
#define TCP_SND_QUEUELEN (16 * TCP_SND_BUF/TCP_MSS)
|
||||||
|
|
||||||
|
/* TCP writable space (bytes). This must be less than or equal
|
||||||
|
to TCP_SND_BUF. It is the amount of space which must be
|
||||||
|
available in the tcp snd_buf for select to return writable */
|
||||||
|
#define TCP_SNDLOWAT (TCP_SND_BUF/2)
|
||||||
|
|
||||||
|
/* TCP receive window. */
|
||||||
|
#define TCP_WND ( 2048 )
|
||||||
|
|
||||||
|
/* Maximum number of retransmissions of data segments. */
|
||||||
|
#define TCP_MAXRTX 12
|
||||||
|
|
||||||
|
/* Maximum number of retransmissions of SYN segments. */
|
||||||
|
#define TCP_SYNMAXRTX 4
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- ARP options ---------- */
|
||||||
|
#define LWIP_ARP 1
|
||||||
|
#define ARP_TABLE_SIZE 10
|
||||||
|
#define ARP_QUEUEING 1
|
||||||
|
|
||||||
|
#define ICMP_TTL 255
|
||||||
|
|
||||||
|
#define IP_OPTIONS 0
|
||||||
|
|
||||||
|
/* ---------- IP options ---------- */
|
||||||
|
/* Define IP_FORWARD to 1 if you wish to have the ability to forward
|
||||||
|
IP packets across network interfaces. If you are going to run lwIP
|
||||||
|
on a device with only one network interface, define this to 0. */
|
||||||
|
#define IP_FORWARD 0
|
||||||
|
|
||||||
|
/* IP reassembly and segmentation.These are orthogonal even
|
||||||
|
* if they both deal with IP fragments */
|
||||||
|
#define IP_REASSEMBLY 0
|
||||||
|
#define IP_REASS_MAX_PBUFS 10
|
||||||
|
#define MEMP_NUM_REASSDATA 10
|
||||||
|
#define IP_FRAG 0
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- ICMP options ---------- */
|
||||||
|
#define ICMP_TTL 255
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- DHCP options ---------- */
|
||||||
|
/* Define LWIP_DHCP to 1 if you want DHCP configuration of
|
||||||
|
interfaces. */
|
||||||
|
#define LWIP_DHCP 0
|
||||||
|
|
||||||
|
/* 1 if you want to do an ARP check on the offered address
|
||||||
|
(recommended). */
|
||||||
|
#define DHCP_DOES_ARP_CHECK (LWIP_DHCP)
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- AUTOIP options ------- */
|
||||||
|
#define LWIP_AUTOIP 0
|
||||||
|
#define LWIP_DHCP_AUTOIP_COOP (LWIP_DHCP && LWIP_AUTOIP)
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- UDP options ---------- */
|
||||||
|
#define LWIP_UDP 1
|
||||||
|
#define LWIP_UDPLITE 1
|
||||||
|
#define UDP_TTL 255
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- Statistics options ---------- */
|
||||||
|
|
||||||
|
#define LWIP_STATS 1
|
||||||
|
#define LWIP_STATS_DISPLAY 0
|
||||||
|
|
||||||
|
#if LWIP_STATS
|
||||||
|
#define LINK_STATS 1
|
||||||
|
#define IP_STATS 1
|
||||||
|
#define ICMP_STATS 0
|
||||||
|
#define IGMP_STATS 0
|
||||||
|
#define IPFRAG_STATS 0
|
||||||
|
#define UDP_STATS 1
|
||||||
|
#define TCP_STATS 1
|
||||||
|
#define MEM_STATS 1
|
||||||
|
#define MEMP_STATS 1
|
||||||
|
#define PBUF_STATS 1
|
||||||
|
#define SYS_STATS 1
|
||||||
|
#endif /* LWIP_STATS */
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- PPP options ---------- */
|
||||||
|
|
||||||
|
#define PPP_SUPPORT 0 /* Set > 0 for PPP */
|
||||||
|
|
||||||
|
#if PPP_SUPPORT
|
||||||
|
|
||||||
|
#define NUM_PPP 1 /* Max PPP sessions. */
|
||||||
|
|
||||||
|
/* Select modules to enable. Ideally these would be set in the makefile but
|
||||||
|
* we're limited by the command line length so you need to modify the settings
|
||||||
|
* in this file.
|
||||||
|
*/
|
||||||
|
#define PPPOE_SUPPORT 1
|
||||||
|
#define PPPOS_SUPPORT 1
|
||||||
|
#define PAP_SUPPORT 1 /* Set > 0 for PAP. */
|
||||||
|
#define CHAP_SUPPORT 1 /* Set > 0 for CHAP. */
|
||||||
|
#define MSCHAP_SUPPORT 0 /* Set > 0 for MSCHAP (NOT FUNCTIONAL!) */
|
||||||
|
#define CBCP_SUPPORT 0 /* Set > 0 for CBCP (NOT FUNCTIONAL!) */
|
||||||
|
#define CCP_SUPPORT 0 /* Set > 0 for CCP (NOT FUNCTIONAL!) */
|
||||||
|
#define VJ_SUPPORT 1 /* Set > 0 for VJ header compression. */
|
||||||
|
#define MD5_SUPPORT 1 /* Set > 0 for MD5 (see also CHAP) */
|
||||||
|
|
||||||
|
#endif /* PPP_SUPPORT */
|
||||||
|
|
||||||
|
#define LWIP_NETIF_STATUS_CALLBACK 1
|
||||||
|
#define LWIP_PLATFORM_BYTESWAP 0
|
||||||
|
#define LWIP_PROVIDE_ERRNO 1
|
||||||
|
|
||||||
|
/* Define platform endianness (might already be defined) */
|
||||||
|
#ifndef BYTE_ORDER
|
||||||
|
#if XPAR_MICROBLAZE_0_ENDIANNESS == 1
|
||||||
|
#define BYTE_ORDER LITTLE_ENDIAN
|
||||||
|
#else
|
||||||
|
#define BYTE_ORDER BIG_ENDIAN
|
||||||
|
#endif
|
||||||
|
#endif /* BYTE_ORDER */
|
||||||
|
|
||||||
|
|
||||||
|
/*#ifndef PORTABLE_H
|
||||||
|
#include <stdlib.h>
|
||||||
|
void vPortFree( void *pv );
|
||||||
|
void *pvPortMalloc( size_t xSize );
|
||||||
|
#endif
|
||||||
|
#define MEMP_MEM_MALLOC 1
|
||||||
|
#define MEM_LIBC_MALLOC 1
|
||||||
|
#define mem_free vPortFree
|
||||||
|
#define mem_malloc pvPortMalloc*/
|
||||||
|
|
||||||
|
#endif /* __LWIPOPTS_H__ */
|
Loading…
Reference in New Issue