OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [freertos-6.1.1/] [Source/] [portable/] [MPLAB/] [PIC32MX/] [portmacro.h] - Blame information for rev 664

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 572 jeremybenn
/*
2
    FreeRTOS V6.1.1 - Copyright (C) 2011 Real Time Engineers Ltd.
3
 
4
    ***************************************************************************
5
    *                                                                         *
6
    * If you are:                                                             *
7
    *                                                                         *
8
    *    + New to FreeRTOS,                                                   *
9
    *    + Wanting to learn FreeRTOS or multitasking in general quickly       *
10
    *    + Looking for basic training,                                        *
11
    *    + Wanting to improve your FreeRTOS skills and productivity           *
12
    *                                                                         *
13
    * then take a look at the FreeRTOS books - available as PDF or paperback  *
14
    *                                                                         *
15
    *        "Using the FreeRTOS Real Time Kernel - a Practical Guide"        *
16
    *                  http://www.FreeRTOS.org/Documentation                  *
17
    *                                                                         *
18
    * A pdf reference manual is also available.  Both are usually delivered   *
19
    * to your inbox within 20 minutes to two hours when purchased between 8am *
20
    * and 8pm GMT (although please allow up to 24 hours in case of            *
21
    * exceptional circumstances).  Thank you for your support!                *
22
    *                                                                         *
23
    ***************************************************************************
24
 
25
    This file is part of the FreeRTOS distribution.
26
 
27
    FreeRTOS is free software; you can redistribute it and/or modify it under
28
    the terms of the GNU General Public License (version 2) as published by the
29
    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.
30
    ***NOTE*** The exception to the GPL is included to allow you to distribute
31
    a combined work that includes FreeRTOS without being obliged to provide the
32
    source code for proprietary components outside of the FreeRTOS kernel.
33
    FreeRTOS is distributed in the hope that it will be useful, but WITHOUT
34
    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
35
    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
36
    more details. You should have received a copy of the GNU General Public
37
    License and the FreeRTOS license exception along with FreeRTOS; if not it
38
    can be viewed here: http://www.freertos.org/a00114.html and also obtained
39
    by writing to Richard Barry, contact details for whom are available on the
40
    FreeRTOS WEB site.
41
 
42
    1 tab == 4 spaces!
43
 
44
    http://www.FreeRTOS.org - Documentation, latest information, license and
45
    contact details.
46
 
47
    http://www.SafeRTOS.com - A version that is certified for use in safety
48
    critical systems.
49
 
50
    http://www.OpenRTOS.com - Commercial support, development, porting,
51
    licensing and training services.
52
*/
53
 
54
#ifndef PORTMACRO_H
55
#define PORTMACRO_H
56
 
57
/* System include files */
58
#include <plib.h>
59
 
60
#ifdef __cplusplus
61
extern "C" {
62
#endif
63
 
64
/*-----------------------------------------------------------
65
 * Port specific definitions.
66
 *
67
 * The settings in this file configure FreeRTOS correctly for the
68
 * given hardware and compiler.
69
 *
70
 * These settings should not be altered.
71
 *-----------------------------------------------------------
72
 */
73
 
74
/* Type definitions. */
75
#define portCHAR                char
76
#define portFLOAT               float
77
#define portDOUBLE              double
78
#define portLONG                long
79
#define portSHORT               short
80
#define portSTACK_TYPE  unsigned long
81
#define portBASE_TYPE   long
82
 
83
#if( configUSE_16_BIT_TICKS == 1 )
84
        typedef unsigned portSHORT portTickType;
85
        #define portMAX_DELAY ( portTickType ) 0xffff
86
#else
87
        typedef unsigned portLONG portTickType;
88
        #define portMAX_DELAY ( portTickType ) 0xffffffff
89
#endif
90
/*-----------------------------------------------------------*/
91
 
92
/* Hardware specifics. */
93
#define portBYTE_ALIGNMENT                      8
94
#define portSTACK_GROWTH                        -1
95
#define portTICK_RATE_MS                        ( ( portTickType ) 1000 / configTICK_RATE_HZ )          
96
/*-----------------------------------------------------------*/
97
 
98
/* Critical section management. */
99
#define portIPL_SHIFT                           ( 10 )
100
#define portALL_IPL_BITS                        ( 0x3f << portIPL_SHIFT )
101
#define portSW0_BIT                                     ( 0x01 << 8 )
102
 
103
#define portDISABLE_INTERRUPTS()                                                                                        \
104
{                                                                                                                                                       \
105
unsigned portLONG ulStatus;                                                                                                     \
106
                                                                                                                                                        \
107
        /* Mask interrupts at and below the kernel interrupt priority. */               \
108
        ulStatus = _CP0_GET_STATUS();                                                                                   \
109
        ulStatus |= ( configMAX_SYSCALL_INTERRUPT_PRIORITY << portIPL_SHIFT );  \
110
        _CP0_SET_STATUS( ulStatus );                                                                                    \
111
}
112
 
113
#define portENABLE_INTERRUPTS()                                                                                         \
114
{                                                                                                                                                       \
115
unsigned portLONG ulStatus;                                                                                                     \
116
                                                                                                                                                        \
117
        /* Unmask all interrupts. */                                                                                    \
118
        ulStatus = _CP0_GET_STATUS();                                                                                   \
119
        ulStatus &= ~portALL_IPL_BITS;                                                                                  \
120
        _CP0_SET_STATUS( ulStatus );                                                                                    \
121
}
122
 
123
 
124
extern void vTaskEnterCritical( void );
125
extern void vTaskExitCritical( void );
126
#define portCRITICAL_NESTING_IN_TCB     1
127
#define portENTER_CRITICAL()            vTaskEnterCritical()
128
#define portEXIT_CRITICAL()                     vTaskExitCritical()
129
 
130
extern unsigned portBASE_TYPE uxPortSetInterruptMaskFromISR();
131
extern void vPortClearInterruptMaskFromISR( unsigned portBASE_TYPE );
132
#define portSET_INTERRUPT_MASK_FROM_ISR() uxPortSetInterruptMaskFromISR()
133
#define portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedStatusRegister ) vPortClearInterruptMaskFromISR( uxSavedStatusRegister )
134
 
135
/*-----------------------------------------------------------*/
136
 
137
/* Task utilities. */
138
 
139
#define portYIELD()                                                             \
140
{                                                                                               \
141
unsigned portLONG ulStatus;                                             \
142
                                                                                                \
143
        /* Trigger software interrupt. */                       \
144
        ulStatus = _CP0_GET_CAUSE();                            \
145
        ulStatus |= portSW0_BIT;                                        \
146
        _CP0_SET_CAUSE( ulStatus );                                     \
147
}
148
 
149
 
150
#define portNOP()       asm volatile (  "nop" )
151
 
152
/*-----------------------------------------------------------*/
153
 
154
/* Task function macros as described on the FreeRTOS.org WEB site. */
155
#define portTASK_FUNCTION_PROTO( vFunction, pvParameters ) void vFunction( void *pvParameters ) __attribute__((noreturn))
156
#define portTASK_FUNCTION( vFunction, pvParameters ) void vFunction( void *pvParameters )
157
/*-----------------------------------------------------------*/
158
 
159
#define portEND_SWITCHING_ISR( xSwitchRequired )        if( xSwitchRequired )   \
160
                                                                                                        {                                               \
161
                                                                                                                portYIELD();            \
162
                                                                                                        }
163
 
164
/* Required by the kernel aware debugger. */
165
#ifdef __DEBUG
166
        #define portREMOVE_STATIC_QUALIFIER
167
#endif
168
 
169
#ifdef __cplusplus
170
}
171
#endif
172
 
173
#endif /* PORTMACRO_H */
174
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.