You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
197 lines
6.6 KiB
C
197 lines
6.6 KiB
C
/*
|
|
* FreeRTOS Kernel V10.1.0
|
|
* Copyright (C) 2018 Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
* this software and associated documentation files (the "Software"), to deal in
|
|
* the Software without restriction, including without limitation the rights to
|
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
* the Software, and to permit persons to whom the Software is furnished to do so,
|
|
* subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
* copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
* http://www.FreeRTOS.org
|
|
* http://aws.amazon.com/freertos
|
|
*
|
|
* 1 tab == 4 spaces!
|
|
*/
|
|
|
|
#include "FreeRTOS.h"
|
|
#include "task.h"
|
|
#include "semphr.h"
|
|
|
|
/* lwIP core includes */
|
|
#include "lwip/opt.h"
|
|
#include "lwip/tcpip.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_PERIOD_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 SemaphoreHandle_t 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 ];
|
|
|
|
/*-----------------------------------------------------------*/
|
|
|
|
|
|
/* Called from the TCP/IP thread. */
|
|
void lwIPAppsInit( void *pvArgument )
|
|
{
|
|
ip_addr_t xIPAddr, xNetMask, xGateway;
|
|
extern err_t ethernetif_init( struct netif *xNetIf );
|
|
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);
|
|
printf("Starting lwIP, local interface IP is %s\n", ip_ntoa(&xIPAddr));
|
|
|
|
netif_set_default( netif_add( &xNetIf, &xIPAddr, &xNetMask, &xGateway, NULL, ethernetif_init, tcpip_input ) );
|
|
netif_set_up( &xNetIf );
|
|
|
|
/* 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();
|
|
|
|
/* Create the FreeRTOS defined basic command server. This demonstrates use
|
|
of the lwIP sockets API. */
|
|
xTaskCreate( vBasicSocketsCommandInterpreterTask, "CmdInt", configMINIMAL_STACK_SIZE * 10, NULL, configMAX_PRIORITIES - 2, 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 );
|
|
}
|
|
|
|
|
|
|