mirror of
				https://github.com/FreeRTOS/FreeRTOS-Kernel.git
				synced 2025-10-24 13:47:47 -04:00 
			
		
		
		
	Sync FreeRTOS-Plus/Source/FreeRTOS-Plus-TCP with the version in GitHub at (23665258cabe49d5d68ba23968b6845a7c80eb34).
Notes: - header has version 2.2.0. - This sync did not bring in ./test directory, though we should. - New NetworkInterfaces are introduced by this merge. - Keil compiler support. - FreeRTOS_IP.h new API xApplicationGetRandomNumber(). - FreeRTOS_IP_Private.h new eIPEvent_t eNetworkTxEvent. - FreeRTOS_Stream_Buffer.h removing static xStreamBufferIsEmpty() and xStreamBufferIsFull(). - FreeRTOSConfigDefaults.h provides default ipconfigDNS_RECEIVE_BLOCK_TIME_TICKS. - other type changes.
This commit is contained in:
		
							parent
							
								
									0c1c85a9dd
								
							
						
					
					
						commit
						ec6f3d77c3
					
				
					 54 changed files with 5688 additions and 1701 deletions
				
			
		|  | @ -1,27 +1,27 @@ | |||
| /*
 | ||||
|  * FreeRTOS+TCP V2.0.11 | ||||
|  * Copyright (C) 2017 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://aws.amazon.com/freertos
 | ||||
|  * http://www.FreeRTOS.org
 | ||||
|  */ | ||||
| FreeRTOS+TCP V2.0.11 | ||||
| Copyright (C) 2017 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://aws.amazon.com/freertos
 | ||||
|  http://www.FreeRTOS.org
 | ||||
| */ | ||||
| 
 | ||||
| /* Standard includes. */ | ||||
| #include <stdint.h> | ||||
|  | @ -50,12 +50,10 @@ | |||
| /* Provided memory configured as uncached. */ | ||||
| #include "uncached_memory.h" | ||||
| 
 | ||||
| #ifndef niEMAC_HANDLER_TASK_PRIORITY | ||||
| 	#define niEMAC_HANDLER_TASK_PRIORITY	configMAX_PRIORITIES - 1 | ||||
| #ifndef	BMSR_LINK_STATUS | ||||
| 	#define BMSR_LINK_STATUS            0x0004UL | ||||
| #endif | ||||
| 
 | ||||
| #define niBMSR_LINK_STATUS         0x0004UL | ||||
| 
 | ||||
| #ifndef	PHY_LS_HIGH_CHECK_TIME_MS | ||||
| 	/* Check if the LinkSStatus in the PHY is still high after 15 seconds of not
 | ||||
| 	receiving packets. */ | ||||
|  | @ -190,7 +188,7 @@ const TickType_t xWaitLinkDelay = pdMS_TO_TICKS( 7000UL ), xWaitRelinkDelay = pd | |||
| 		possible priority to ensure the interrupt handler can return directly | ||||
| 		to it.  The task's handle is stored in xEMACTaskHandle so interrupts can | ||||
| 		notify the task when there is something to process. */ | ||||
| 		xTaskCreate( prvEMACHandlerTask, "EMAC", configEMAC_TASK_STACK_SIZE, NULL, niEMAC_HANDLER_TASK_PRIORITY, &xEMACTaskHandle ); | ||||
| 		xTaskCreate( prvEMACHandlerTask, "EMAC", configEMAC_TASK_STACK_SIZE, NULL, configMAX_PRIORITIES - 1, &xEMACTaskHandle ); | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
|  | @ -208,27 +206,7 @@ const TickType_t xWaitLinkDelay = pdMS_TO_TICKS( 7000UL ), xWaitRelinkDelay = pd | |||
| 
 | ||||
| BaseType_t xNetworkInterfaceOutput( NetworkBufferDescriptor_t * const pxBuffer, BaseType_t bReleaseAfterSend ) | ||||
| { | ||||
| 	#if( ipconfigDRIVER_INCLUDED_TX_IP_CHECKSUM != 0 ) | ||||
| 	{ | ||||
| 	ProtocolPacket_t *pxPacket; | ||||
| 
 | ||||
| 		/* If the peripheral must calculate the checksum, it wants
 | ||||
| 		the protocol checksum to have a value of zero. */ | ||||
| 		pxPacket = ( ProtocolPacket_t * ) ( pxBuffer->pucEthernetBuffer ); | ||||
| 		if( pxPacket->xICMPPacket.xIPHeader.ucProtocol == ipPROTOCOL_ICMP ) | ||||
| 		{ | ||||
| 		IPHeader_t *pxIPHeader = &( pxPacket->xUDPPacket.xIPHeader ); | ||||
| 
 | ||||
| 			pxPacket->xICMPPacket.xICMPHeader.usChecksum = ( uint16_t )0u; | ||||
| 			pxIPHeader->usHeaderChecksum = 0u; | ||||
| 			pxIPHeader->usHeaderChecksum = usGenerateChecksum( 0UL, ( uint8_t * ) &( pxIPHeader->ucVersionHeaderLength ), ipSIZE_OF_IPv4_HEADER ); | ||||
| 			pxIPHeader->usHeaderChecksum = ~FreeRTOS_htons( pxIPHeader->usHeaderChecksum ); | ||||
| 
 | ||||
| 			usGenerateProtocolChecksum( (uint8_t*)&( pxPacket->xUDPPacket ), pxBuffer->xDataLength, pdTRUE ); | ||||
| 		} | ||||
| 	} | ||||
| 	#endif /* ipconfigDRIVER_INCLUDED_TX_IP_CHECKSUM */ | ||||
| 	if( ( ulPHYLinkStatus & niBMSR_LINK_STATUS ) != 0 ) | ||||
| 	if( ( ulPHYLinkStatus & BMSR_LINK_STATUS ) != 0 ) | ||||
| 	{ | ||||
| 		iptraceNETWORK_INTERFACE_TRANSMIT(); | ||||
| 		emacps_send_message( &xEMACpsif, pxBuffer, bReleaseAfterSend ); | ||||
|  | @ -271,7 +249,7 @@ BaseType_t xReturn; | |||
| 		} | ||||
| 		ulPHYLinkStatus = ulReadMDIO( PHY_REG_01_BMSR ); | ||||
| 
 | ||||
| 		if( ( ulPHYLinkStatus & niBMSR_LINK_STATUS ) != 0 ) | ||||
| 		if( ( ulPHYLinkStatus & BMSR_LINK_STATUS ) != 0 ) | ||||
| 		{ | ||||
| 			xReturn = pdTRUE; | ||||
| 			break; | ||||
|  | @ -303,7 +281,7 @@ BaseType_t xGetPhyLinkStatus( void ) | |||
| { | ||||
| BaseType_t xReturn; | ||||
| 
 | ||||
| 	if( ( ulPHYLinkStatus & niBMSR_LINK_STATUS ) == 0 ) | ||||
| 	if( ( ulPHYLinkStatus & BMSR_LINK_STATUS ) == 0 ) | ||||
| 	{ | ||||
| 		xReturn = pdFALSE; | ||||
| 	} | ||||
|  | @ -320,12 +298,11 @@ static void prvEMACHandlerTask( void *pvParameters ) | |||
| { | ||||
| TimeOut_t xPhyTime; | ||||
| TickType_t xPhyRemTime; | ||||
| UBaseType_t uxLastMinBufferCount = 0; | ||||
| UBaseType_t uxCurrentCount; | ||||
| BaseType_t xResult = 0; | ||||
| uint32_t xStatus; | ||||
| const TickType_t ulMaxBlockTime = pdMS_TO_TICKS( 100UL ); | ||||
| UBaseType_t uxLastMinBufferCount = 0; | ||||
| UBaseType_t uxCurrentBufferCount = 0; | ||||
| 
 | ||||
| 	/* Remove compiler warnings about unused parameters. */ | ||||
| 	( void ) pvParameters; | ||||
|  | @ -339,14 +316,14 @@ UBaseType_t uxCurrentBufferCount = 0; | |||
| 
 | ||||
| 	for( ;; ) | ||||
| 	{ | ||||
| 		uxCurrentBufferCount = uxGetMinimumFreeNetworkBuffers(); | ||||
| 		if( uxLastMinBufferCount != uxCurrentBufferCount ) | ||||
| 		uxCurrentCount = uxGetMinimumFreeNetworkBuffers(); | ||||
| 		if( uxLastMinBufferCount != uxCurrentCount ) | ||||
| 		{ | ||||
| 			/* The logging produced below may be helpful
 | ||||
| 			while tuning +TCP: see how many buffers are in use. */ | ||||
| 			uxLastMinBufferCount = uxCurrentBufferCount; | ||||
| 			uxLastMinBufferCount = uxCurrentCount; | ||||
| 			FreeRTOS_printf( ( "Network buffers: %lu lowest %lu\n", | ||||
| 				uxGetNumberOfFreeNetworkBuffers(), uxCurrentBufferCount ) ); | ||||
| 				uxGetNumberOfFreeNetworkBuffers(), uxCurrentCount ) ); | ||||
| 		} | ||||
| 
 | ||||
| 		#if( ipconfigCHECK_IP_QUEUE_SPACE != 0 ) | ||||
|  | @ -395,22 +372,19 @@ UBaseType_t uxCurrentBufferCount = 0; | |||
| 			vTaskSetTimeOutState( &xPhyTime ); | ||||
| 			xPhyRemTime = pdMS_TO_TICKS( PHY_LS_HIGH_CHECK_TIME_MS ); | ||||
| 			xResult = 0; | ||||
| 			/* Indicate that the Link Status is high, so that
 | ||||
| 			xNetworkInterfaceOutput() can send packets. */ | ||||
| 			ulPHYLinkStatus |= niBMSR_LINK_STATUS; | ||||
| 		} | ||||
| 		else if( xTaskCheckForTimeOut( &xPhyTime, &xPhyRemTime ) != pdFALSE ) | ||||
| 		{ | ||||
| 			xStatus = ulReadMDIO( PHY_REG_01_BMSR ); | ||||
| 
 | ||||
| 			if( ( ulPHYLinkStatus & niBMSR_LINK_STATUS ) != ( xStatus & niBMSR_LINK_STATUS ) ) | ||||
| 			if( ( ulPHYLinkStatus & BMSR_LINK_STATUS ) != ( xStatus & BMSR_LINK_STATUS ) ) | ||||
| 			{ | ||||
| 				ulPHYLinkStatus = xStatus; | ||||
| 				FreeRTOS_printf( ( "prvEMACHandlerTask: PHY LS now %d\n", ( ulPHYLinkStatus & niBMSR_LINK_STATUS ) != 0 ) ); | ||||
| 				FreeRTOS_printf( ( "prvEMACHandlerTask: PHY LS now %d\n", ( ulPHYLinkStatus & BMSR_LINK_STATUS ) != 0 ) ); | ||||
| 			} | ||||
| 
 | ||||
| 			vTaskSetTimeOutState( &xPhyTime ); | ||||
| 			if( ( ulPHYLinkStatus & niBMSR_LINK_STATUS ) != 0 ) | ||||
| 			if( ( ulPHYLinkStatus & BMSR_LINK_STATUS ) != 0 ) | ||||
| 			{ | ||||
| 				xPhyRemTime = pdMS_TO_TICKS( PHY_LS_HIGH_CHECK_TIME_MS ); | ||||
| 			} | ||||
|  |  | |||
|  | @ -35,6 +35,7 @@ extern "C" { | |||
| #include "xil_exception.h" | ||||
| #include "xpseudo_asm.h" | ||||
| #include "xil_cache.h" | ||||
| #include "xil_printf.h" | ||||
| #include "xuartps.h" | ||||
| #include "xscugic.h" | ||||
| #include "xemacps.h"		/* defines XEmacPs API */ | ||||
|  |  | |||
|  | @ -1,27 +1,36 @@ | |||
| /*
 | ||||
|  * FreeRTOS+TCP V2.0.11 | ||||
|  * Copyright (C) 2017 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://aws.amazon.com/freertos
 | ||||
|  * http://www.FreeRTOS.org
 | ||||
|  */ | ||||
| FreeRTOS+TCP V2.0.11 | ||||
| Copyright (C) 2017 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://aws.amazon.com/freertos
 | ||||
|  http://www.FreeRTOS.org
 | ||||
| */ | ||||
| 
 | ||||
| #include "Zynq/x_emacpsif.h" | ||||
| #include "Zynq/x_topology.h" | ||||
| #include "xstatus.h" | ||||
| 
 | ||||
| #include "xparameters.h" | ||||
| #include "xparameters_ps.h" | ||||
| #include "xil_exception.h" | ||||
| #include "xil_mmu.h" | ||||
| 
 | ||||
| #include "FreeRTOS.h" | ||||
| #include "task.h" | ||||
|  | @ -34,15 +43,6 @@ | |||
| #include "FreeRTOS_IP_Private.h" | ||||
| #include "NetworkBufferManagement.h" | ||||
| 
 | ||||
| #include "Zynq/x_emacpsif.h" | ||||
| #include "Zynq/x_topology.h" | ||||
| #include "xstatus.h" | ||||
| 
 | ||||
| #include "xparameters.h" | ||||
| #include "xparameters_ps.h" | ||||
| #include "xil_exception.h" | ||||
| #include "xil_mmu.h" | ||||
| 
 | ||||
| #include "uncached_memory.h" | ||||
| 
 | ||||
| /* Two defines used to set or clear the EMAC interrupt */ | ||||
|  | @ -56,6 +56,8 @@ | |||
| #endif | ||||
| #define TX_OFFSET				ipconfigPACKET_FILLER_SIZE | ||||
| 
 | ||||
| #define RX_BUFFER_ALIGNMENT	14 | ||||
| 
 | ||||
| /* Defined in NetworkInterface.c */ | ||||
| extern TaskHandle_t xEMACTaskHandle; | ||||
| 
 | ||||
|  | @ -119,6 +121,7 @@ size_t uxCount = ( ( UBaseType_t ) ipconfigNIC_N_TX_DESC ) - uxSemaphoreGetCount | |||
| 			break; | ||||
| 		} | ||||
| #if( ipconfigZERO_COPY_TX_DRIVER != 0 ) | ||||
| #warning ipconfigZERO_COPY_TX_DRIVER is defined | ||||
| 		{ | ||||
| 		void *pvBuffer = pxDMA_tx_buffers[ tail ]; | ||||
| 		NetworkBufferDescriptor_t *pxBuffer; | ||||
|  | @ -289,8 +292,6 @@ TickType_t xBlockTimeTicks = pdMS_TO_TICKS( 5000u ); | |||
| 		/* Start transmit */ | ||||
| 		xemacpsif->txBusy = pdTRUE; | ||||
| 		XEmacPs_WriteReg( ulBaseAddress, XEMACPS_NWCTRL_OFFSET, ( ulValue | XEMACPS_NWCTRL_STARTTX_MASK ) ); | ||||
| 		/* Reading it back is important compiler is optimised. */ | ||||
| 		XEmacPs_ReadReg( ulBaseAddress, XEMACPS_NWCTRL_OFFSET ); | ||||
| 	} | ||||
| 	dsb(); | ||||
| 
 | ||||
|  | @ -313,35 +314,33 @@ void emacps_recv_handler(void *arg) | |||
| 	portYIELD_FROM_ISR( xHigherPriorityTaskWoken ); | ||||
| } | ||||
| 
 | ||||
| static void prvPassEthMessages( NetworkBufferDescriptor_t *pxDescriptor ) | ||||
| static NetworkBufferDescriptor_t *ethMsg = NULL; | ||||
| static NetworkBufferDescriptor_t *ethLast = NULL; | ||||
| 
 | ||||
| static void passEthMessages( void ) | ||||
| { | ||||
| IPStackEvent_t xRxEvent; | ||||
| 
 | ||||
| 	xRxEvent.eEventType = eNetworkRxEvent; | ||||
| 	xRxEvent.pvData = ( void * ) pxDescriptor; | ||||
| 	xRxEvent.pvData = ( void * ) ethMsg; | ||||
| 
 | ||||
| 	if( xSendEventStructToIPTask( &xRxEvent, ( TickType_t ) 1000 ) != pdPASS ) | ||||
| 	{ | ||||
| 		/* The buffer could not be sent to the stack so	must be released again.
 | ||||
| 		This is a deferred handler taskr, not a real interrupt, so it is ok to | ||||
| 		use the task level function here. */ | ||||
| 		#if( ipconfigUSE_LINKED_RX_MESSAGES != 0 ) | ||||
| 		do | ||||
| 		{ | ||||
| 			do | ||||
| 			{ | ||||
| 				NetworkBufferDescriptor_t *pxNext = pxDescriptor->pxNextBuffer; | ||||
| 				vReleaseNetworkBufferAndDescriptor( pxDescriptor ); | ||||
| 				pxDescriptor = pxNext; | ||||
| 			} while( pxDescriptor != NULL ); | ||||
| 		} | ||||
| 		#else | ||||
| 		{ | ||||
| 			vReleaseNetworkBufferAndDescriptor( pxDescriptor ); | ||||
| 		} | ||||
| 		#endif	/* ipconfigUSE_LINKED_RX_MESSAGES */ | ||||
| 			NetworkBufferDescriptor_t *xNext = ethMsg->pxNextBuffer; | ||||
| 			vReleaseNetworkBufferAndDescriptor( ethMsg ); | ||||
| 			ethMsg = xNext; | ||||
| 		} while( ethMsg != NULL ); | ||||
| 
 | ||||
| 		iptraceETHERNET_RX_EVENT_LOST(); | ||||
| 		FreeRTOS_printf( ( "prvPassEthMessages: Can not queue return packet!\n" ) ); | ||||
| 		FreeRTOS_printf( ( "passEthMessages: Can not queue return packet!\n" ) ); | ||||
| 	} | ||||
| 
 | ||||
| 	ethMsg = ethLast = NULL; | ||||
| } | ||||
| 
 | ||||
| int emacps_check_rx( xemacpsif_s *xemacpsif ) | ||||
|  | @ -350,10 +349,6 @@ NetworkBufferDescriptor_t *pxBuffer, *pxNewBuffer; | |||
| int rx_bytes; | ||||
| volatile int msgCount = 0; | ||||
| int head = xemacpsif->rxHead; | ||||
| #if( ipconfigUSE_LINKED_RX_MESSAGES != 0 ) | ||||
| 	NetworkBufferDescriptor_t *pxFirstDescriptor = NULL; | ||||
| 	NetworkBufferDescriptor_t *pxLastDescriptor = NULL; | ||||
| #endif	/* ipconfigUSE_LINKED_RX_MESSAGES */ | ||||
| 
 | ||||
| 	/* There seems to be an issue (SI# 692601), see comments below. */ | ||||
| 	resetrx_on_no_rxdata(xemacpsif); | ||||
|  | @ -369,7 +364,7 @@ int head = xemacpsif->rxHead; | |||
| 			break; | ||||
| 		} | ||||
| 
 | ||||
| 		pxNewBuffer = pxGetNetworkBufferWithDescriptor( ipTOTAL_ETHERNET_FRAME_SIZE, ( TickType_t ) 0 ); | ||||
| 		pxNewBuffer = pxGetNetworkBufferWithDescriptor( ipTOTAL_ETHERNET_FRAME_SIZE + RX_BUFFER_ALIGNMENT, ( TickType_t ) 0 ); | ||||
| 		if( pxNewBuffer == NULL ) | ||||
| 		{ | ||||
| 			/* A packet has been received, but there is no replacement for this Network Buffer.
 | ||||
|  | @ -390,6 +385,7 @@ int head = xemacpsif->rxHead; | |||
| 			rx_bytes = xemacpsif->rxSegments[ head ].flags & XEMACPS_RXBUF_LEN_MASK; | ||||
| 
 | ||||
| 			pxBuffer->xDataLength = rx_bytes; | ||||
| 
 | ||||
| 			if( ucIsCachedMemory( pxBuffer->pucEthernetBuffer ) != 0 ) | ||||
| 			{ | ||||
| 				Xil_DCacheInvalidateRange( ( ( uint32_t )pxBuffer->pucEthernetBuffer ) - ipconfigPACKET_FILLER_SIZE, (unsigned)rx_bytes ); | ||||
|  | @ -398,35 +394,26 @@ int head = xemacpsif->rxHead; | |||
| 			/* store it in the receive queue, where it'll be processed by a
 | ||||
| 			different handler. */ | ||||
| 			iptraceNETWORK_INTERFACE_RECEIVE(); | ||||
| 			#if( ipconfigUSE_LINKED_RX_MESSAGES != 0 ) | ||||
| 			pxBuffer->pxNextBuffer = NULL; | ||||
| 
 | ||||
| 			if( ethMsg == NULL ) | ||||
| 			{ | ||||
| 				pxBuffer->pxNextBuffer = NULL; | ||||
| 
 | ||||
| 				if( pxFirstDescriptor == NULL ) | ||||
| 				{ | ||||
| 					// Becomes the first message
 | ||||
| 					pxFirstDescriptor = pxBuffer; | ||||
| 				} | ||||
| 				else if( pxLastDescriptor != NULL ) | ||||
| 				{ | ||||
| 					// Add to the tail
 | ||||
| 					pxLastDescriptor->pxNextBuffer = pxBuffer; | ||||
| 				} | ||||
| 
 | ||||
| 				pxLastDescriptor = pxBuffer; | ||||
| 				// Becomes the first message
 | ||||
| 				ethMsg = pxBuffer; | ||||
| 			} | ||||
| 			#else | ||||
| 			else if( ethLast != NULL ) | ||||
| 			{ | ||||
| 				prvPassEthMessages( pxBuffer ); | ||||
| 				// Add to the tail
 | ||||
| 				ethLast->pxNextBuffer = pxBuffer; | ||||
| 			} | ||||
| 			#endif	/* ipconfigUSE_LINKED_RX_MESSAGES */ | ||||
| 
 | ||||
| 			ethLast = pxBuffer; | ||||
| 			msgCount++; | ||||
| 		} | ||||
| 		{ | ||||
| 			if( ucIsCachedMemory( pxNewBuffer->pucEthernetBuffer ) != 0 ) | ||||
| 			{ | ||||
| 				Xil_DCacheInvalidateRange( ( ( uint32_t )pxNewBuffer->pucEthernetBuffer ) - ipconfigPACKET_FILLER_SIZE, (unsigned)ipTOTAL_ETHERNET_FRAME_SIZE ); | ||||
| 				Xil_DCacheInvalidateRange( ( ( uint32_t )pxNewBuffer->pucEthernetBuffer ) - ipconfigPACKET_FILLER_SIZE, (unsigned)ipTOTAL_ETHERNET_FRAME_SIZE + RX_BUFFER_ALIGNMENT); | ||||
| 			} | ||||
| 			{ | ||||
| 				uint32_t addr = ( ( uint32_t )pxNewBuffer->pucEthernetBuffer ) & XEMACPS_RXBUF_ADD_MASK; | ||||
|  | @ -435,12 +422,8 @@ int head = xemacpsif->rxHead; | |||
| 					addr |= XEMACPS_RXBUF_WRAP_MASK; | ||||
| 				} | ||||
| 				/* Clearing 'XEMACPS_RXBUF_NEW_MASK'       0x00000001 *< Used bit.. */ | ||||
| 				xemacpsif->rxSegments[ head ].flags = 0; | ||||
| 				xemacpsif->rxSegments[ head ].address = addr; | ||||
| 				if (xemacpsif->rxSegments[ head ].address) | ||||
| 				{ | ||||
| 					// Just to read it
 | ||||
| 				} | ||||
| 				xemacpsif->rxSegments[ head ].flags = 0; | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
|  | @ -451,14 +434,10 @@ int head = xemacpsif->rxHead; | |||
| 		xemacpsif->rxHead = head; | ||||
| 	} | ||||
| 
 | ||||
| 	#if( ipconfigUSE_LINKED_RX_MESSAGES != 0 ) | ||||
| 	if( ethMsg != NULL ) | ||||
| 	{ | ||||
| 		if( pxFirstDescriptor != NULL ) | ||||
| 		{ | ||||
| 			prvPassEthMessages( pxFirstDescriptor ); | ||||
| 		} | ||||
| 		passEthMessages( ); | ||||
| 	} | ||||
| 	#endif	/* ipconfigUSE_LINKED_RX_MESSAGES */ | ||||
| 
 | ||||
| 	return msgCount; | ||||
| } | ||||
|  | @ -477,9 +456,9 @@ unsigned char *ucTxBuffer; | |||
| 		xemacpsif->txSegments[ index ].address = ( uint32_t )ucTxBuffer; | ||||
| 		xemacpsif->txSegments[ index ].flags = XEMACPS_TXBUF_USED_MASK; | ||||
| #if( ipconfigZERO_COPY_TX_DRIVER != 0 ) | ||||
| 		pxDMA_tx_buffers[ index ] = ( unsigned char * )NULL; | ||||
| 		pxDMA_tx_buffers[ index ] = ( void* )NULL; | ||||
| #else | ||||
| 		pxDMA_tx_buffers[ index ] = ( unsigned char * )( ucTxBuffer + TX_OFFSET ); | ||||
| 		pxDMA_tx_buffers[ index ] = ( void* )( ucTxBuffer + TX_OFFSET ); | ||||
| #endif | ||||
| 		ucTxBuffer += xemacpsif->uTxUnitSize; | ||||
| 	} | ||||
|  | @ -528,7 +507,7 @@ XStatus init_dma(xemacpsif_s *xemacpsif) | |||
| 		pxBuffer = pxDMA_rx_buffers[ iIndex ]; | ||||
| 		if( pxBuffer == NULL ) | ||||
| 		{ | ||||
| 			pxBuffer = pxGetNetworkBufferWithDescriptor( ipTOTAL_ETHERNET_FRAME_SIZE, ( TickType_t ) 0 ); | ||||
| 			pxBuffer = pxGetNetworkBufferWithDescriptor( ipTOTAL_ETHERNET_FRAME_SIZE + RX_BUFFER_ALIGNMENT, ( TickType_t ) 0 ); | ||||
| 			if( pxBuffer == NULL ) | ||||
| 			{ | ||||
| 				FreeRTOS_printf( ("Unable to allocate a network buffer in recv_handler\n" ) ); | ||||
|  | @ -544,7 +523,7 @@ XStatus init_dma(xemacpsif_s *xemacpsif) | |||
| 		if( ucIsCachedMemory( pxBuffer->pucEthernetBuffer ) != 0 ) | ||||
| 		{ | ||||
| 			Xil_DCacheInvalidateRange( ( ( uint32_t )pxBuffer->pucEthernetBuffer ) - ipconfigPACKET_FILLER_SIZE, | ||||
| 				(unsigned)ipTOTAL_ETHERNET_FRAME_SIZE ); | ||||
| 				(unsigned)ipTOTAL_ETHERNET_FRAME_SIZE + RX_BUFFER_ALIGNMENT); | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -22,19 +22,19 @@ | |||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #include "Zynq/x_emacpsif.h" | ||||
| 
 | ||||
| /* FreeRTOS includes. */ | ||||
| #include "FreeRTOS.h" | ||||
| #include "task.h" | ||||
| #include "queue.h" | ||||
| 
 | ||||
| ///* FreeRTOS+TCP includes. */
 | ||||
| /* FreeRTOS+TCP includes. */ | ||||
| #include "FreeRTOS_IP.h" | ||||
| #include "FreeRTOS_Sockets.h" | ||||
| #include "FreeRTOS_IP_Private.h" | ||||
| #include "NetworkBufferManagement.h" | ||||
| #include "NetworkInterface.h" | ||||
| 
 | ||||
| #include "Zynq/x_emacpsif.h" | ||||
| 
 | ||||
| extern TaskHandle_t xEMACTaskHandle; | ||||
| 
 | ||||
|  | @ -42,6 +42,8 @@ extern TaskHandle_t xEMACTaskHandle; | |||
|  *** to run it on a PEEP board | ||||
|  ***/ | ||||
| 
 | ||||
| unsigned int link_speed = 100; | ||||
| 
 | ||||
| void setup_isr( xemacpsif_s *xemacpsif ) | ||||
| { | ||||
| 	/*
 | ||||
|  | @ -139,6 +141,8 @@ int xResult; | |||
| 	return xResult; | ||||
| } | ||||
| 
 | ||||
| BaseType_t xNetworkInterfaceInitialise( void ); | ||||
| 
 | ||||
| static void emacps_handle_error(void *arg, u8 Direction, u32 ErrorWord) | ||||
| { | ||||
| 	xemacpsif_s   *xemacpsif; | ||||
|  | @ -214,6 +218,8 @@ static void emacps_handle_error(void *arg, u8 Direction, u32 ErrorWord) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| extern XEmacPs_Config mac_config; | ||||
| 
 | ||||
| void HandleTxErrors(xemacpsif_s *xemacpsif) | ||||
| { | ||||
| 	u32 netctrlreg; | ||||
|  |  | |||
|  | @ -53,23 +53,24 @@ | |||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| 
 | ||||
| #include "Zynq/x_emacpsif.h" | ||||
| //#include "lwipopts.h"
 | ||||
| #include "xparameters_ps.h" | ||||
| #include "xparameters.h" | ||||
| 
 | ||||
| /* FreeRTOS includes. */ | ||||
| #include "FreeRTOS.h" | ||||
| #include "task.h" | ||||
| #include "queue.h" | ||||
| #include "semphr.h" | ||||
| 
 | ||||
| ///* FreeRTOS+TCP includes. */
 | ||||
| /* FreeRTOS+TCP includes. */ | ||||
| #include "FreeRTOS_IP.h" | ||||
| #include "FreeRTOS_Sockets.h" | ||||
| #include "FreeRTOS_IP_Private.h" | ||||
| #include "NetworkBufferManagement.h" | ||||
| 
 | ||||
| #include "Zynq/x_emacpsif.h" | ||||
| #include "xparameters_ps.h" | ||||
| #include "xparameters.h" | ||||
| 
 | ||||
| 
 | ||||
| int phy_detected = 0; | ||||
| 
 | ||||
| /*** IMPORTANT: Define PEEP in xemacpsif.h and sys_arch_raw.c
 | ||||
|  | @ -98,8 +99,6 @@ int phy_detected = 0; | |||
| 
 | ||||
| #define IEEE_CONTROL_REG_OFFSET				0 | ||||
| #define IEEE_STATUS_REG_OFFSET				1 | ||||
| #define IEEE_PHYSID1_OFFSET					2 | ||||
| #define IEEE_PHYSID2_OFFSET					3 | ||||
| #define IEEE_AUTONEGO_ADVERTISE_REG			4 | ||||
| #define IEEE_PARTNER_ABILITIES_1_REG_OFFSET	5 | ||||
| #define IEEE_1000_ADVERTISE_REG_OFFSET		9 | ||||
|  | @ -136,6 +135,9 @@ int phy_detected = 0; | |||
| #define IEEE_PAUSE_MASK						0x0400 | ||||
| #define IEEE_AUTONEG_ERROR_MASK				0x8000 | ||||
| 
 | ||||
| #define PHY_DETECT_REG  1 | ||||
| #define PHY_DETECT_MASK 0x1808 | ||||
| 
 | ||||
| #define XEMACPS_GMII2RGMII_SPEED1000_FD		0x140 | ||||
| #define XEMACPS_GMII2RGMII_SPEED100_FD		0x2100 | ||||
| #define XEMACPS_GMII2RGMII_SPEED10_FD		0x100 | ||||
|  | @ -161,17 +163,19 @@ int phy_detected = 0; | |||
| 
 | ||||
| static int detect_phy(XEmacPs *xemacpsp) | ||||
| { | ||||
| 	u16 id_lower, id_upper; | ||||
| 	u32 phy_addr, id; | ||||
| 	u16 phy_reg; | ||||
| 	u32 phy_addr; | ||||
| 
 | ||||
| 	for (phy_addr = 0; phy_addr < 32; phy_addr++) { | ||||
| 		XEmacPs_PhyRead(xemacpsp, phy_addr, IEEE_PHYSID1_OFFSET, &id_lower); | ||||
| 	for (phy_addr = 31; phy_addr > 0; phy_addr--) { | ||||
| 		XEmacPs_PhyRead(xemacpsp, phy_addr, PHY_DETECT_REG, | ||||
| 							&phy_reg); | ||||
| 
 | ||||
| 		if ((id_lower != ( u16 )0xFFFFu) && (id_lower != ( u16 )0x0u)) { | ||||
| 
 | ||||
| 			XEmacPs_PhyRead(xemacpsp, phy_addr, IEEE_PHYSID2_OFFSET, &id_upper); | ||||
| 			id = ( ( ( uint32_t ) id_upper ) << 16 ) | ( id_lower & 0xFFF0 ); | ||||
| 			FreeRTOS_printf( ("XEmacPs detect_phy: %04lX at address %d.\n", id, phy_addr ) ); | ||||
| 		if ((phy_reg != 0xFFFF) && | ||||
| 			((phy_reg & PHY_DETECT_MASK) == PHY_DETECT_MASK)) { | ||||
| 			/* Found a valid PHY address */ | ||||
| 			FreeRTOS_printf( ("XEmacPs detect_phy: PHY detected at address %d.\r\n", | ||||
| 																	phy_addr)); | ||||
| 			FreeRTOS_printf( ("XEmacPs detect_phy: PHY detected.\n" ) ); | ||||
| 			phy_detected = phy_addr; | ||||
| 			return phy_addr; | ||||
| 		} | ||||
|  | @ -234,8 +238,8 @@ unsigned get_IEEE_phy_speed(XEmacPs *xemacpsp) | |||
| 		if (partner_capabilities & IEEE_AN1_ABILITY_MASK_10MBPS) | ||||
| 			return 10; | ||||
| 
 | ||||
| 		FreeRTOS_printf( ( "%s: unknown PHY link speed, setting TEMAC speed to be 10 Mbps\n", | ||||
| 				__FUNCTION__ ) ); | ||||
| 		xil_printf("%s: unknown PHY link speed, setting TEMAC speed to be 10 Mbps\r\n", | ||||
| 				__FUNCTION__); | ||||
| 		return 10; | ||||
| 
 | ||||
| 	} else { | ||||
|  | @ -253,8 +257,8 @@ unsigned get_IEEE_phy_speed(XEmacPs *xemacpsp) | |||
| 				case (IEEE_CTRL_LINKSPEED_10M): | ||||
| 					return 10; | ||||
| 				default: | ||||
| 					FreeRTOS_printf( ( "%s: unknown PHY link speed (%d), setting TEMAC speed to be 10 Mbps\n", | ||||
| 							__FUNCTION__, phylinkspeed ) ); | ||||
| 					xil_printf("%s: unknown PHY link speed (%d), setting TEMAC speed to be 10 Mbps\r\n", | ||||
| 							__FUNCTION__, phylinkspeed); | ||||
| 					return 10; | ||||
| 			} | ||||
| 
 | ||||
|  | @ -278,7 +282,7 @@ unsigned get_IEEE_phy_speed(XEmacPs *xemacpsp) | |||
| #else | ||||
| 	u32 phy_addr = detect_phy(xemacpsp); | ||||
| #endif | ||||
| 	FreeRTOS_printf( ( "Start PHY autonegotiation \n" ) ); | ||||
| 	xil_printf("Start PHY autonegotiation \r\n"); | ||||
| 
 | ||||
| #if XPAR_GIGE_PCS_PMA_CORE_PRESENT == 1 | ||||
| #else | ||||
|  | @ -334,24 +338,24 @@ unsigned get_IEEE_phy_speed(XEmacPs *xemacpsp) | |||
| 			break; | ||||
| 	} | ||||
| #endif | ||||
| 	FreeRTOS_printf( ( "Waiting for PHY to complete autonegotiation.\n" ) ); | ||||
| 	xil_printf("Waiting for PHY to complete autonegotiation.\r\n"); | ||||
| 
 | ||||
| 	XEmacPs_PhyRead(xemacpsp, phy_addr, IEEE_STATUS_REG_OFFSET, &status); | ||||
| 	while ( !(status & IEEE_STAT_AUTONEGOTIATE_COMPLETE) ) { | ||||
| 		vTaskDelay(1); | ||||
| 		sleep(1); | ||||
| #if XPAR_GIGE_PCS_PMA_CORE_PRESENT == 1 | ||||
| #else | ||||
| 		XEmacPs_PhyRead(xemacpsp, phy_addr, IEEE_COPPER_SPECIFIC_STATUS_REG_2, | ||||
| 																	&temp); | ||||
| 		if (temp & IEEE_AUTONEG_ERROR_MASK) { | ||||
| 			FreeRTOS_printf( ( "Auto negotiation error \n" ) ); | ||||
| 			xil_printf("Auto negotiation error \r\n"); | ||||
| 		} | ||||
| #endif | ||||
| 		XEmacPs_PhyRead(xemacpsp, phy_addr, IEEE_STATUS_REG_OFFSET, | ||||
| 																&status); | ||||
| 		} | ||||
| 
 | ||||
| 	FreeRTOS_printf( ( "autonegotiation complete \n" ) ); | ||||
| 	xil_printf("autonegotiation complete \r\n"); | ||||
| 
 | ||||
| #if XPAR_GIGE_PCS_PMA_CORE_PRESENT == 1 | ||||
| #else | ||||
|  | @ -359,7 +363,7 @@ unsigned get_IEEE_phy_speed(XEmacPs *xemacpsp) | |||
| #endif | ||||
| 
 | ||||
| #if XPAR_GIGE_PCS_PMA_CORE_PRESENT == 1 | ||||
| 	FreeRTOS_printf( ( "Waiting for Link to be up; Polling for SGMII core Reg \n" ) ); | ||||
| 	xil_printf("Waiting for Link to be up; Polling for SGMII core Reg \r\n"); | ||||
| 	XEmacPs_PhyRead(xemacpsp, phy_addr, 5, &temp); | ||||
| 	while(!(temp & 0x8000)) { | ||||
| 		XEmacPs_PhyRead(xemacpsp, phy_addr, 5, &temp); | ||||
|  | @ -376,7 +380,7 @@ unsigned get_IEEE_phy_speed(XEmacPs *xemacpsp) | |||
| 		XEmacPs_PhyRead(xemacpsp, phy_addr, 0, &temp); | ||||
| 		return 10; | ||||
| 	} else { | ||||
| 		FreeRTOS_printf( ( "get_IEEE_phy_speed(): Invalid speed bit value, Deafulting to Speed = 10 Mbps\n" ) ); | ||||
| 		xil_printf("get_IEEE_phy_speed(): Invalid speed bit value, Deafulting to Speed = 10 Mbps\r\n"); | ||||
| 		XEmacPs_PhyRead(xemacpsp, phy_addr, 0, &temp); | ||||
| 		XEmacPs_PhyWrite(xemacpsp, phy_addr, 0, 0x0100); | ||||
| 		return 10; | ||||
|  | @ -556,26 +560,26 @@ unsigned Phy_Setup (XEmacPs *xemacpsp) | |||
| 	link_speed = 1000; | ||||
| 	configure_IEEE_phy_speed(xemacpsp, link_speed); | ||||
| 	convspeeddupsetting = XEMACPS_GMII2RGMII_SPEED1000_FD; | ||||
| 	vTaskDelay(1); | ||||
| 	sleep(1); | ||||
| #elif	defined(ipconfigNIC_LINKSPEED100) | ||||
| 	SetUpSLCRDivisors(xemacpsp->Config.BaseAddress,100); | ||||
| 	link_speed = 100; | ||||
| 	configure_IEEE_phy_speed(xemacpsp, link_speed); | ||||
| 	convspeeddupsetting = XEMACPS_GMII2RGMII_SPEED100_FD; | ||||
| 	vTaskDelay(1); | ||||
| 	sleep(1); | ||||
| #elif	defined(ipconfigNIC_LINKSPEED10) | ||||
| 	SetUpSLCRDivisors(xemacpsp->Config.BaseAddress,10); | ||||
| 	link_speed = 10; | ||||
| 	configure_IEEE_phy_speed(xemacpsp, link_speed); | ||||
| 	convspeeddupsetting = XEMACPS_GMII2RGMII_SPEED10_FD; | ||||
| 	vTaskDelay(1); | ||||
| 	sleep(1); | ||||
| #endif | ||||
| 	if (conv_present) { | ||||
| 		XEmacPs_PhyWrite(xemacpsp, convphyaddr, | ||||
| 		XEMACPS_GMII2RGMII_REG_NUM, convspeeddupsetting); | ||||
| 	} | ||||
| 
 | ||||
| 	FreeRTOS_printf( ( "link speed: %d\n", link_speed ) ); | ||||
| 	xil_printf("link speed: %d\r\n", link_speed); | ||||
| 	return link_speed; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue