mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-10-21 20:27:47 -04:00 
			
		
		
		
	* Update History.txt and README.md for December release (#744) * Update History.txt and README.md for release * Bump mbedtls submodule to v2.28.0 (#745) * Patch project files for mbedtls (#751) * Apply group 1 patches * Apply patches for group 2 * Update project files for mbedTLS new version Signed-off-by: Gaurav Aggarwal <aggarg@amazon.com> * Fix warnings in projects Signed-off-by: Gaurav Aggarwal <aggarg@amazon.com> * Fix warnings in HTTP_S3_Download demo Signed-off-by: Gaurav Aggarwal <aggarg@amazon.com> Co-authored-by: Gaurav Aggarwal <aggarg@amazon.com> * Update changelog and history for corePKCS11 update (#752) * Update submodule pointer and manifest.yml for corePKCS11 (#754) * Update readme and history.txt to show that Sigv4 is a newly added library (#756) * Revert update to v143 of VS toolset (#757) * [AUTO][RELEASE]: Bump file header version to "202112.00" * Update file headers to satisfy core checks Co-authored-by: Muneeb Ahmed <54290492+muneebahmed10@users.noreply.github.com> Co-authored-by: Gaurav Aggarwal <aggarg@amazon.com> Co-authored-by: johnrhen <johnrhen@users.noreply.github.com>
		
			
				
	
	
		
			221 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			221 lines
		
	
	
	
		
			6.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * FreeRTOS V202112.00
 | |
|  * Copyright (C) 2020 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.
 | |
|  *
 | |
|  * https://www.FreeRTOS.org
 | |
|  * https://aws.amazon.com/freertos
 | |
|  *
 | |
|  */
 | |
| 
 | |
| /*
 | |
| Changes from V1.2.3
 | |
| 
 | |
| 	+ The function xPortInitMinimal() has been renamed to 
 | |
| 	  xSerialPortInitMinimal() and the function xPortInit() has been renamed
 | |
| 	  to xSerialPortInit().
 | |
| 
 | |
| Changes from V2.0.0
 | |
| 
 | |
| 	+ Delay periods are now specified using variables and constants of
 | |
| 	  TickType_t rather than unsigned long.
 | |
| 	+ xQueueReceiveFromISR() used in place of xQueueReceive() within the ISR.
 | |
| 
 | |
| Changes from V2.6.0
 | |
| 
 | |
| 	+ Replaced the inb() and outb() functions with direct memory
 | |
| 	  access.  This allows the port to be built with the 20050414 build of
 | |
| 	  WinAVR.
 | |
| */
 | |
| 
 | |
| /* BASIC INTERRUPT DRIVEN SERIAL PORT DRIVER. */
 | |
| 
 | |
| 
 | |
| #include <stdlib.h>
 | |
| #include <avr/interrupt.h>
 | |
| #include "FreeRTOS.h"
 | |
| #include "queue.h"
 | |
| #include "task.h"
 | |
| #include "serial.h"
 | |
| 
 | |
| #define serBAUD_DIV_CONSTANT			( ( unsigned long ) 16 )
 | |
| 
 | |
| /* Constants for writing to UCSRB. */
 | |
| #define serRX_INT_ENABLE				( ( unsigned char ) 0x80 )
 | |
| #define serRX_ENABLE					( ( unsigned char ) 0x10 )
 | |
| #define serTX_ENABLE					( ( unsigned char ) 0x08 )
 | |
| #define serTX_INT_ENABLE				( ( unsigned char ) 0x20 )
 | |
| 
 | |
| /* Constants for writing to UCSRC. */
 | |
| #define serUCSRC_SELECT					( ( unsigned char ) 0x80 )
 | |
| #define serEIGHT_DATA_BITS				( ( unsigned char ) 0x06 )
 | |
| 
 | |
| static QueueHandle_t xRxedChars; 
 | |
| static QueueHandle_t xCharsForTx; 
 | |
| 
 | |
| #define vInterruptOn()										\
 | |
| {															\
 | |
| 	unsigned char ucByte;								\
 | |
| 															\
 | |
| 	ucByte = UCSRB;											\
 | |
| 	ucByte |= serTX_INT_ENABLE;								\
 | |
| 	UCSRB = ucByte;											\
 | |
| }																				
 | |
| /*-----------------------------------------------------------*/
 | |
| 
 | |
| #define vInterruptOff()										\
 | |
| {															\
 | |
| 	unsigned char ucInByte;								\
 | |
| 															\
 | |
| 	ucInByte = UCSRB;										\
 | |
| 	ucInByte &= ~serTX_INT_ENABLE;							\
 | |
| 	UCSRB = ucInByte;										\
 | |
| }
 | |
| /*-----------------------------------------------------------*/
 | |
| 
 | |
| xComPortHandle xSerialPortInitMinimal( unsigned long ulWantedBaud, unsigned portBASE_TYPE uxQueueLength )
 | |
| {
 | |
| unsigned long ulBaudRateCounter;
 | |
| unsigned char ucByte;
 | |
| 
 | |
| 	portENTER_CRITICAL();
 | |
| 	{
 | |
| 		/* Create the queues used by the com test task. */
 | |
| 		xRxedChars = xQueueCreate( uxQueueLength, ( unsigned portBASE_TYPE ) sizeof( signed char ) );
 | |
| 		xCharsForTx = xQueueCreate( uxQueueLength, ( unsigned portBASE_TYPE ) sizeof( signed char ) );
 | |
| 
 | |
| 		/* Calculate the baud rate register value from the equation in the
 | |
| 		data sheet. */
 | |
| 		ulBaudRateCounter = ( configCPU_CLOCK_HZ / ( serBAUD_DIV_CONSTANT * ulWantedBaud ) ) - ( unsigned long ) 1;
 | |
| 
 | |
| 		/* Set the baud rate. */	
 | |
| 		ucByte = ( unsigned char ) ( ulBaudRateCounter & ( unsigned long ) 0xff );	
 | |
| 		UBRRL = ucByte;
 | |
| 
 | |
| 		ulBaudRateCounter >>= ( unsigned long ) 8;
 | |
| 		ucByte = ( unsigned char ) ( ulBaudRateCounter & ( unsigned long ) 0xff );	
 | |
| 		UBRRH = ucByte;
 | |
| 
 | |
| 		/* Enable the Rx interrupt.  The Tx interrupt will get enabled
 | |
| 		later. Also enable the Rx and Tx. */
 | |
| 		UCSRB = ( serRX_INT_ENABLE | serRX_ENABLE | serTX_ENABLE );
 | |
| 
 | |
| 		/* Set the data bits to 8. */
 | |
| 		UCSRC = ( serUCSRC_SELECT | serEIGHT_DATA_BITS );
 | |
| 	}
 | |
| 	portEXIT_CRITICAL();
 | |
| 	
 | |
| 	/* Unlike other ports, this serial code does not allow for more than one
 | |
| 	com port.  We therefore don't return a pointer to a port structure and can
 | |
| 	instead just return NULL. */
 | |
| 	return NULL;
 | |
| }
 | |
| /*-----------------------------------------------------------*/
 | |
| 
 | |
| signed portBASE_TYPE xSerialGetChar( xComPortHandle pxPort, signed char *pcRxedChar, TickType_t xBlockTime )
 | |
| {
 | |
| 	/* Only one port is supported. */
 | |
| 	( void ) pxPort;
 | |
| 
 | |
| 	/* Get the next character from the buffer.  Return false if no characters
 | |
| 	are available, or arrive before xBlockTime expires. */
 | |
| 	if( xQueueReceive( xRxedChars, pcRxedChar, xBlockTime ) )
 | |
| 	{
 | |
| 		return pdTRUE;
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		return pdFALSE;
 | |
| 	}
 | |
| }
 | |
| /*-----------------------------------------------------------*/
 | |
| 
 | |
| signed portBASE_TYPE xSerialPutChar( xComPortHandle pxPort, signed char cOutChar, TickType_t xBlockTime )
 | |
| {
 | |
| 	/* Only one port is supported. */
 | |
| 	( void ) pxPort;
 | |
| 
 | |
| 	/* Return false if after the block time there is no room on the Tx queue. */
 | |
| 	if( xQueueSend( xCharsForTx, &cOutChar, xBlockTime ) != pdPASS )
 | |
| 	{
 | |
| 		return pdFAIL;
 | |
| 	}
 | |
| 
 | |
| 	vInterruptOn();
 | |
| 
 | |
| 	return pdPASS;
 | |
| }
 | |
| /*-----------------------------------------------------------*/
 | |
| 
 | |
| void vSerialClose( xComPortHandle xPort )
 | |
| {
 | |
| unsigned char ucByte;
 | |
| 
 | |
| 	/* The parameter is not used. */
 | |
| 	( void ) xPort;
 | |
| 
 | |
| 	/* Turn off the interrupts.  We may also want to delete the queues and/or
 | |
| 	re-install the original ISR. */
 | |
| 
 | |
| 	portENTER_CRITICAL();
 | |
| 	{
 | |
| 		vInterruptOff();
 | |
| 		ucByte = UCSRB;
 | |
| 		ucByte &= ~serRX_INT_ENABLE;
 | |
| 		UCSRB = ucByte;
 | |
| 	}
 | |
| 	portEXIT_CRITICAL();
 | |
| }
 | |
| /*-----------------------------------------------------------*/
 | |
| 
 | |
| SIGNAL( USART_RXC_vect )
 | |
| {
 | |
| signed char cChar;
 | |
| signed portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;
 | |
| 
 | |
| 	/* Get the character and post it on the queue of Rxed characters.
 | |
| 	If the post causes a task to wake force a context switch as the woken task
 | |
| 	may have a higher priority than the task we have interrupted. */
 | |
| 	cChar = UDR;
 | |
| 
 | |
| 	xQueueSendFromISR( xRxedChars, &cChar, &xHigherPriorityTaskWoken );
 | |
| 
 | |
| 	if( xHigherPriorityTaskWoken != pdFALSE )
 | |
| 	{
 | |
| 		taskYIELD();
 | |
| 	}
 | |
| }
 | |
| /*-----------------------------------------------------------*/
 | |
| 
 | |
| SIGNAL( USART_UDRE_vect )
 | |
| {
 | |
| signed char cChar, cTaskWoken;
 | |
| 
 | |
| 	if( xQueueReceiveFromISR( xCharsForTx, &cChar, &cTaskWoken ) == pdTRUE )
 | |
| 	{
 | |
| 		/* Send the next character queued for Tx. */
 | |
| 		UDR = cChar;
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		/* Queue empty, nothing to send. */
 | |
| 		vInterruptOff();
 | |
| 	}
 | |
| }
 | |
| 
 |