mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-10-24 21:57:46 -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>
		
			
				
	
	
		
			104 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
	
		
			3 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 V3.0.0
 | |
| 	+ ISRcode pulled inline to reduce stack-usage.
 | |
| 
 | |
| 	+ Added functionality to only call vTaskSwitchContext() once
 | |
| 	  when handling multiple interruptsources in a single interruptcall.
 | |
| 
 | |
| 	+ Filename changed to a .c extension to allow stepping through code
 | |
| 	  using F7.
 | |
| 
 | |
| Changes from V3.0.1
 | |
| */
 | |
| 
 | |
| #ifndef _FREERTOS_SERIAL_ISRSERIALRX_C
 | |
| #define _FREERTOS_SERIAL_ISRSERIALRX_C
 | |
| 
 | |
| #define serCONTINUOUS_RX		( 1 )
 | |
| #define serCLEAR_OVERRUN		( 0 )
 | |
| 
 | |
| {
 | |
| 	/*
 | |
| 	 * Was the interrupt a byte being received?
 | |
| 	 */
 | |
| 	if( bRCIF && bRCIE)
 | |
| 	{
 | |
| 		/*
 | |
| 		 * Queue to interface between comms API and interrupt routine.
 | |
| 		*/
 | |
| 		extern QueueHandle_t xRxedChars;
 | |
| 		
 | |
| 		/*
 | |
| 		 * Because we are not allowed to use local variables here,
 | |
| 		 * PRODL is (ab)used as temporary storage.  This is allowed
 | |
| 		 * because this SFR will be restored before exiting the ISR.
 | |
| 		 */
 | |
| 		extern char			cChar;
 | |
| 		extern portBASE_TYPE xHigherPriorityTaskWoken;
 | |
| 		#pragma locate cChar	&PRODL
 | |
| 
 | |
| 		/*
 | |
| 		 * If there was a framing error, just get and ignore
 | |
| 		 * the character
 | |
| 		 */
 | |
| 		if( bFERR )
 | |
| 		{
 | |
| 			cChar = RCREG;
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			/*
 | |
| 			 * Get the character and post it on the queue of Rxed
 | |
| 			 * characters. If the post causes a task to wake ask
 | |
| 			 * for a context switch as the woken task may have a
 | |
| 			 * higher priority than the task we have interrupted.
 | |
| 			 */
 | |
| 			cChar = RCREG;
 | |
| 
 | |
| 			/*
 | |
| 			 * Clear any overrun errors.
 | |
| 			 */
 | |
| 			if( bOERR )
 | |
| 			{
 | |
| 				bCREN = serCLEAR_OVERRUN;
 | |
| 				bCREN = serCONTINUOUS_RX;	
 | |
| 			}
 | |
| 
 | |
| 			xHigherPriorityTaskWoken = pdFALSE;
 | |
| 			xQueueSendFromISR( xRxedChars, ( const void * ) &cChar, &xHigherPriorityTaskWoken );
 | |
| 
 | |
| 			if( xHigherPriorityTaskWoken )
 | |
| 			{
 | |
| 				uxSwitchRequested = pdTRUE;
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| #endif	/* _FREERTOS_SERIAL_ISRSERIALRX_C */
 |