sync from github to svn: Wiced_CY for AFR Cypress ports.
This commit is contained in:
324
FreeRTOS/Source/portable/ThirdParty/GCC/Wiced_CY/port.c
vendored
Normal file
324
FreeRTOS/Source/portable/ThirdParty/GCC/Wiced_CY/port.c
vendored
Normal file
File diff suppressed because it is too large
Load Diff
268
FreeRTOS/Source/portable/ThirdParty/GCC/Wiced_CY/portASM.S
vendored
Normal file
268
FreeRTOS/Source/portable/ThirdParty/GCC/Wiced_CY/portASM.S
vendored
Normal file
@ -0,0 +1,268 @@
|
|||||||
|
/*
|
||||||
|
* FreeRTOS Kernel V10.2.0
|
||||||
|
* 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://www.FreeRTOS.org
|
||||||
|
* http://aws.amazon.com/freertos
|
||||||
|
*
|
||||||
|
* 1 tab == 4 spaces!
|
||||||
|
*/
|
||||||
|
|
||||||
|
.text
|
||||||
|
.arm
|
||||||
|
|
||||||
|
.set SYS_MODE, 0x1f
|
||||||
|
.set SVC_MODE, 0x13
|
||||||
|
.set IRQ_MODE, 0x12
|
||||||
|
|
||||||
|
/* Variables and functions. */
|
||||||
|
.extern ulMaxAPIPriorityMask
|
||||||
|
.extern _freertos_vector_table
|
||||||
|
.extern pxCurrentTCB
|
||||||
|
.extern vTaskSwitchContext
|
||||||
|
.extern vApplicationIRQHandler
|
||||||
|
.extern ulPortInterruptNesting
|
||||||
|
.extern ulPortTaskHasFPUContext
|
||||||
|
.extern ulICCEOIR
|
||||||
|
.extern ulPortYieldRequired
|
||||||
|
|
||||||
|
.global FreeRTOS_IRQ_Handler
|
||||||
|
.global FreeRTOS_SVC_Handler
|
||||||
|
.global vPortRestoreTaskContext
|
||||||
|
|
||||||
|
|
||||||
|
.macro portSAVE_CONTEXT
|
||||||
|
|
||||||
|
/* Save the LR and SPSR onto the system mode stack before switching to
|
||||||
|
system mode to save the remaining system mode registers. */
|
||||||
|
SRSDB sp!, #SYS_MODE
|
||||||
|
CPS #SYS_MODE
|
||||||
|
PUSH {R0-R12, R14}
|
||||||
|
|
||||||
|
/* Push the critical nesting count. */
|
||||||
|
LDR R2, ulCriticalNestingConst
|
||||||
|
LDR R1, [R2]
|
||||||
|
PUSH {R1}
|
||||||
|
|
||||||
|
/* Does the task have a floating point context that needs saving? If
|
||||||
|
ulPortTaskHasFPUContext is 0 then no. */
|
||||||
|
LDR R2, ulPortTaskHasFPUContextConst
|
||||||
|
LDR R3, [R2]
|
||||||
|
CMP R3, #0
|
||||||
|
|
||||||
|
#if configFPU == 1
|
||||||
|
/* Save the floating point context, if any. */
|
||||||
|
FMRXNE R1, FPSCR
|
||||||
|
VPUSHNE {D0-D15}
|
||||||
|
#if configFPU_D32 == 1
|
||||||
|
VPUSHNE {D16-D31}
|
||||||
|
#endif /* configFPU_D32 */
|
||||||
|
PUSHNE {R1}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Save ulPortTaskHasFPUContext itself. */
|
||||||
|
PUSH {R3}
|
||||||
|
|
||||||
|
/* Save the stack pointer in the TCB. */
|
||||||
|
LDR R0, pxCurrentTCBConst
|
||||||
|
LDR R1, [R0]
|
||||||
|
STR SP, [R1]
|
||||||
|
|
||||||
|
.endm
|
||||||
|
|
||||||
|
; /**********************************************************************/
|
||||||
|
|
||||||
|
.macro portRESTORE_CONTEXT
|
||||||
|
|
||||||
|
/* Set the SP to point to the stack of the task being restored. */
|
||||||
|
LDR R0, pxCurrentTCBConst
|
||||||
|
LDR R1, [R0]
|
||||||
|
LDR SP, [R1]
|
||||||
|
|
||||||
|
/* Is there a floating point context to restore? If the restored
|
||||||
|
ulPortTaskHasFPUContext is zero then no. */
|
||||||
|
LDR R0, ulPortTaskHasFPUContextConst
|
||||||
|
POP {R1}
|
||||||
|
STR R1, [R0]
|
||||||
|
CMP R1, #0
|
||||||
|
|
||||||
|
#if configFPU == 1
|
||||||
|
/* Restore the floating point context, if any. */
|
||||||
|
POPNE {R0}
|
||||||
|
#if configFPU_D32 == 1
|
||||||
|
VPOPNE {D16-D31}
|
||||||
|
#endif /* configFPU_D32 */
|
||||||
|
VPOPNE {D0-D15}
|
||||||
|
VMSRNE FPSCR, R0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Restore the critical section nesting depth. */
|
||||||
|
LDR R0, ulCriticalNestingConst
|
||||||
|
POP {R1}
|
||||||
|
STR R1, [R0]
|
||||||
|
|
||||||
|
/* Restore all system mode registers other than the SP (which is already
|
||||||
|
being used). */
|
||||||
|
POP {R0-R12, R14}
|
||||||
|
|
||||||
|
/* Return to the task code, loading CPSR on the way. */
|
||||||
|
RFEIA sp!
|
||||||
|
|
||||||
|
.endm
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* SVC handler is used to yield.
|
||||||
|
*****************************************************************************/
|
||||||
|
.align 4
|
||||||
|
.type FreeRTOS_SVC_Handler, %function
|
||||||
|
FreeRTOS_SVC_Handler:
|
||||||
|
/* Save the context of the current task and select a new task to run. */
|
||||||
|
portSAVE_CONTEXT
|
||||||
|
LDR R0, vTaskSwitchContextConst
|
||||||
|
BLX R0
|
||||||
|
portRESTORE_CONTEXT
|
||||||
|
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
* vPortRestoreTaskContext is used to start the scheduler.
|
||||||
|
*****************************************************************************/
|
||||||
|
.align 4
|
||||||
|
.type vPortRestoreTaskContext, %function
|
||||||
|
vPortRestoreTaskContext:
|
||||||
|
/* Switch to system mode. */
|
||||||
|
CPS #SYS_MODE
|
||||||
|
portRESTORE_CONTEXT
|
||||||
|
|
||||||
|
.align 4
|
||||||
|
.type FreeRTOS_IRQ_Handler, %function
|
||||||
|
FreeRTOS_IRQ_Handler:
|
||||||
|
/* Return to the interrupted instruction. */
|
||||||
|
SUB lr, lr, #4
|
||||||
|
|
||||||
|
/* Push the return address and SPSR. */
|
||||||
|
PUSH {lr}
|
||||||
|
MRS lr, SPSR
|
||||||
|
PUSH {lr}
|
||||||
|
|
||||||
|
/* Change to supervisor mode to allow reentry. */
|
||||||
|
CPS #0x13
|
||||||
|
|
||||||
|
/* Push used registers. */
|
||||||
|
PUSH {r0-r3, r12}
|
||||||
|
|
||||||
|
/* Increment nesting count. r3 holds the address of ulPortInterruptNesting
|
||||||
|
for future use. r1 holds the original ulPortInterruptNesting value for
|
||||||
|
future use. */
|
||||||
|
LDR r3, ulPortInterruptNestingConst
|
||||||
|
LDR r1, [r3]
|
||||||
|
ADD r0, r1, #1
|
||||||
|
STR r0, [r3]
|
||||||
|
|
||||||
|
/* Ensure bit 2 of the stack pointer is clear. r2 holds the bit 2 value for
|
||||||
|
future use. */
|
||||||
|
MOV r0, sp
|
||||||
|
AND r2, r0, #4
|
||||||
|
SUB sp, sp, r2
|
||||||
|
|
||||||
|
/* Call the interrupt handler. */
|
||||||
|
PUSH {r0-r3, lr}
|
||||||
|
LDR r1, vApplicationIRQHandlerConst
|
||||||
|
BLX r1
|
||||||
|
POP {r0-r3, lr}
|
||||||
|
ADD sp, sp, r2
|
||||||
|
|
||||||
|
CPSID i
|
||||||
|
DSB
|
||||||
|
ISB
|
||||||
|
|
||||||
|
/* Write to the EOI register. */
|
||||||
|
LDR r0, ulICCEOIRConst
|
||||||
|
LDR r2, [r0]
|
||||||
|
STR r0, [r2]
|
||||||
|
|
||||||
|
/* Restore the old nesting count. */
|
||||||
|
STR r1, [r3]
|
||||||
|
|
||||||
|
/* A context switch is never performed if the nesting count is not 0. */
|
||||||
|
CMP r1, #0
|
||||||
|
BNE exit_without_switch
|
||||||
|
|
||||||
|
/* Did the interrupt request a context switch? r1 holds the address of
|
||||||
|
ulPortYieldRequired and r0 the value of ulPortYieldRequired for future
|
||||||
|
use. */
|
||||||
|
LDR r1, ulPortYieldRequiredConst
|
||||||
|
LDR r0, [r1]
|
||||||
|
CMP r0, #0
|
||||||
|
BNE switch_before_exit
|
||||||
|
|
||||||
|
exit_without_switch:
|
||||||
|
/* No context switch. Restore used registers, LR_irq and SPSR before
|
||||||
|
returning. */
|
||||||
|
POP {r0-r3, r12}
|
||||||
|
CPS #IRQ_MODE
|
||||||
|
POP {LR}
|
||||||
|
MSR SPSR_cxsf, LR
|
||||||
|
POP {LR}
|
||||||
|
MOVS PC, LR
|
||||||
|
|
||||||
|
switch_before_exit:
|
||||||
|
/* A context swtich is to be performed. Clear the context switch pending
|
||||||
|
flag. */
|
||||||
|
MOV r0, #0
|
||||||
|
STR r0, [r1]
|
||||||
|
|
||||||
|
/* Restore used registers, LR-irq and SPSR before saving the context
|
||||||
|
to the task stack. */
|
||||||
|
POP {r0-r3, r12}
|
||||||
|
CPS #IRQ_MODE
|
||||||
|
POP {LR}
|
||||||
|
MSR SPSR_cxsf, LR
|
||||||
|
POP {LR}
|
||||||
|
portSAVE_CONTEXT
|
||||||
|
|
||||||
|
/* Call the function that selects the new task to execute.
|
||||||
|
vTaskSwitchContext() if vTaskSwitchContext() uses LDRD or STRD
|
||||||
|
instructions, or 8 byte aligned stack allocated data. LR does not need
|
||||||
|
saving as a new LR will be loaded by portRESTORE_CONTEXT anyway. */
|
||||||
|
LDR R0, vTaskSwitchContextConst
|
||||||
|
BLX R0
|
||||||
|
|
||||||
|
/* Restore the context of, and branch to, the task selected to execute
|
||||||
|
next. */
|
||||||
|
portRESTORE_CONTEXT
|
||||||
|
|
||||||
|
ulICCEOIRConst: .word ulICCEOIR
|
||||||
|
pxCurrentTCBConst: .word pxCurrentTCB
|
||||||
|
ulCriticalNestingConst: .word ulCriticalNesting
|
||||||
|
ulPortTaskHasFPUContextConst: .word ulPortTaskHasFPUContext
|
||||||
|
vTaskSwitchContextConst: .word vTaskSwitchContext
|
||||||
|
vApplicationIRQHandlerConst: .word vApplicationIRQHandler
|
||||||
|
ulPortInterruptNestingConst: .word ulPortInterruptNesting
|
||||||
|
ulPortYieldRequiredConst: .word ulPortYieldRequired
|
||||||
|
|
||||||
|
.end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
179
FreeRTOS/Source/portable/ThirdParty/GCC/Wiced_CY/portmacro.h
vendored
Normal file
179
FreeRTOS/Source/portable/ThirdParty/GCC/Wiced_CY/portmacro.h
vendored
Normal file
@ -0,0 +1,179 @@
|
|||||||
|
/*
|
||||||
|
* FreeRTOS Kernel V10.2.0
|
||||||
|
* 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://www.FreeRTOS.org
|
||||||
|
* http://aws.amazon.com/freertos
|
||||||
|
*
|
||||||
|
* 1 tab == 4 spaces!
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PORTMACRO_H
|
||||||
|
#define PORTMACRO_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------
|
||||||
|
* Port specific definitions.
|
||||||
|
*
|
||||||
|
* The settings in this file configure FreeRTOS correctly for the given hardware
|
||||||
|
* and compiler.
|
||||||
|
*
|
||||||
|
* These settings should not be altered.
|
||||||
|
*-----------------------------------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Type definitions. */
|
||||||
|
#define portCHAR char
|
||||||
|
#define portFLOAT float
|
||||||
|
#define portDOUBLE double
|
||||||
|
#define portLONG long
|
||||||
|
#define portSHORT short
|
||||||
|
#define portSTACK_TYPE uint32_t
|
||||||
|
#define portBASE_TYPE long
|
||||||
|
|
||||||
|
typedef portSTACK_TYPE StackType_t;
|
||||||
|
typedef long BaseType_t;
|
||||||
|
typedef unsigned long UBaseType_t;
|
||||||
|
|
||||||
|
typedef uint32_t TickType_t;
|
||||||
|
#define portMAX_DELAY ( TickType_t ) 0xffffffffUL
|
||||||
|
|
||||||
|
/* 32-bit tick type on a 32-bit architecture, so reads of the tick count do
|
||||||
|
not need to be guarded with a critical section. */
|
||||||
|
#define portTICK_TYPE_IS_ATOMIC 1
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* Hardware specifics. */
|
||||||
|
#define portSTACK_GROWTH ( -1 )
|
||||||
|
#define portTICK_PERIOD_MS ( ( TickType_t ) 1000 / configTICK_RATE_HZ )
|
||||||
|
#define portBYTE_ALIGNMENT 8
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* Task utilities. */
|
||||||
|
|
||||||
|
/* Called at the end of an ISR that can cause a context switch. */
|
||||||
|
#define portEND_SWITCHING_ISR( xSwitchRequired )\
|
||||||
|
{ \
|
||||||
|
extern volatile uint32_t ulPortYieldRequired; \
|
||||||
|
\
|
||||||
|
if( xSwitchRequired != pdFALSE ) \
|
||||||
|
{ \
|
||||||
|
ulPortYieldRequired = pdTRUE; \
|
||||||
|
} \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define portYIELD_FROM_ISR( x ) portEND_SWITCHING_ISR( x )
|
||||||
|
#define portYIELD() __asm volatile ( "SWI 0 \n" \
|
||||||
|
"ISB " );
|
||||||
|
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------
|
||||||
|
* Critical section control
|
||||||
|
*----------------------------------------------------------*/
|
||||||
|
|
||||||
|
extern void vPortEnterCritical( void );
|
||||||
|
extern void vPortExitCritical( void );
|
||||||
|
extern uint32_t ulPortSetInterruptMask( void );
|
||||||
|
extern void vPortClearInterruptMask( uint32_t ulNewMaskValue );
|
||||||
|
extern void vPortInstallFreeRTOSVectorTable( void );
|
||||||
|
|
||||||
|
/* The I bit within the CPSR. */
|
||||||
|
#define portINTERRUPT_ENABLE_BIT ( 1 << 7 )
|
||||||
|
|
||||||
|
/* In the absence of a priority mask register, these functions and macros
|
||||||
|
globally enable and disable interrupts. */
|
||||||
|
#define portENTER_CRITICAL() vPortEnterCritical();
|
||||||
|
#define portEXIT_CRITICAL() vPortExitCritical();
|
||||||
|
#define portENABLE_INTERRUPTS() __asm volatile ( "CPSIE i \n" );
|
||||||
|
#define portDISABLE_INTERRUPTS() __asm volatile ( "CPSID i \n" \
|
||||||
|
"DSB \n" \
|
||||||
|
"ISB " );
|
||||||
|
|
||||||
|
__attribute__( ( always_inline ) ) static __inline uint32_t portINLINE_SET_INTERRUPT_MASK_FROM_ISR( void )
|
||||||
|
{
|
||||||
|
volatile uint32_t ulCPSR;
|
||||||
|
|
||||||
|
__asm volatile ( "MRS %0, CPSR" : "=r" (ulCPSR) );
|
||||||
|
ulCPSR &= portINTERRUPT_ENABLE_BIT;
|
||||||
|
portDISABLE_INTERRUPTS();
|
||||||
|
return ulCPSR;
|
||||||
|
}
|
||||||
|
|
||||||
|
#define portSET_INTERRUPT_MASK_FROM_ISR() portINLINE_SET_INTERRUPT_MASK_FROM_ISR()
|
||||||
|
#define portCLEAR_INTERRUPT_MASK_FROM_ISR(x) if( x == 0 ) portENABLE_INTERRUPTS()
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* Task function macros as described on the FreeRTOS.org WEB site. These are
|
||||||
|
not required for this port but included in case common demo code that uses these
|
||||||
|
macros is used. */
|
||||||
|
#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters )
|
||||||
|
#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )
|
||||||
|
|
||||||
|
/* Tickless idle/low power functionality. */
|
||||||
|
#ifndef portSUPPRESS_TICKS_AND_SLEEP
|
||||||
|
extern void vPortSuppressTicksAndSleep( TickType_t xExpectedIdleTime );
|
||||||
|
#define portSUPPRESS_TICKS_AND_SLEEP( xExpectedIdleTime ) vPortSuppressTicksAndSleep( xExpectedIdleTime )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Prototype of the FreeRTOS tick handler. This must be installed as the
|
||||||
|
handler for whichever peripheral is used to generate the RTOS tick. */
|
||||||
|
void FreeRTOS_Tick_Handler( void );
|
||||||
|
|
||||||
|
/* Any task that uses the floating point unit MUST call vPortTaskUsesFPU()
|
||||||
|
before any floating point instructions are executed. */
|
||||||
|
void vPortTaskUsesFPU( void );
|
||||||
|
#define portTASK_USES_FLOATING_POINT() vPortTaskUsesFPU()
|
||||||
|
|
||||||
|
#define portLOWEST_INTERRUPT_PRIORITY ( ( ( uint32_t ) configUNIQUE_INTERRUPT_PRIORITIES ) - 1UL )
|
||||||
|
#define portLOWEST_USABLE_INTERRUPT_PRIORITY ( portLOWEST_INTERRUPT_PRIORITY - 1UL )
|
||||||
|
|
||||||
|
/* Architecture specific optimisations. */
|
||||||
|
#ifndef configUSE_PORT_OPTIMISED_TASK_SELECTION
|
||||||
|
#define configUSE_PORT_OPTIMISED_TASK_SELECTION 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if configUSE_PORT_OPTIMISED_TASK_SELECTION == 1
|
||||||
|
|
||||||
|
/* Store/clear the ready priorities in a bit map. */
|
||||||
|
#define portRECORD_READY_PRIORITY( uxPriority, uxReadyPriorities ) ( uxReadyPriorities ) |= ( 1UL << ( uxPriority ) )
|
||||||
|
#define portRESET_READY_PRIORITY( uxPriority, uxReadyPriorities ) ( uxReadyPriorities ) &= ~( 1UL << ( uxPriority ) )
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
#define portGET_HIGHEST_PRIORITY( uxTopPriority, uxReadyPriorities ) uxTopPriority = ( 31UL - ( uint32_t ) __builtin_clz( uxReadyPriorities ) )
|
||||||
|
|
||||||
|
#endif /* configUSE_PORT_OPTIMISED_TASK_SELECTION */
|
||||||
|
|
||||||
|
#define portNOP() __asm volatile( "NOP" )
|
||||||
|
#define portINLINE __inline
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
} /* extern C */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* PORTMACRO_H */
|
||||||
|
|
Reference in New Issue
Block a user